[llvm-dev] Enabling IRCE pass or Adding something similar in the pipeline of new pass manager

Jingu Kang via llvm-dev llvm-dev at lists.llvm.org
Tue May 4 04:44:44 PDT 2021


Philip, I appreciate your kind comments.

>In this example, forming the full pre/main/post loop structure of IRCE is overkill.  Instead, we could simply restrict the loop bounds in the following manner:

>loop.ph<http://loop.ph>:

>  ;; Warning: psuedo code, might have edge conditions wrong

>  %c = icmp sgt %iv, %n

>  %min = umax(%n, %a)

>  br i1 %c, label %exit, label %loop.ph<http://loop.ph>

>

>loop.ph.split:

>  br label %loop

>

>loop:

>  %iv = phi i64 [ %inc, %loop ], [ 1, %loop.ph<http://loop.ph> ]

>  %src.arrayidx = getelementptr inbounds i64, i64* %src, i64 %iv

>  %val = load i64, i64* %src.arrayidx

>  %dst.arrayidx = getelementptr inbounds i64, i64* %dst, i64 %iv

>  store i64 %val, i64* %dst.arrayidx

>  %inc = add nuw nsw i64 %iv, 1

>  %cond = icmp eq i64 %inc, %min

>  br i1 %cond, label %exit, label %loop

>

>exit:

>  ret void

>}

>

>I'm not quite sure what to call this transform, but it's not IRCE.  If this example is actually general enough to cover your use cases, it's going to be a lot easier to judge profitability on than the general form of iteration set splitting

I agree with you. If the llvm community is ok to accept above approach as a pass or a part of a certain pass, I would be happy to implement it because I am aiming to handle this case with llvm upstream.


>Another way to frame this special case might be to recognize the conditional block can be inverted into an early exit.  (Reasoning: %iv is strictly increasing, condition is monotonic, path if not taken has no observable effect)  Consider:

>loop.ph<http://loop.ph>:

>  br label %loop

>

>loop:

>  %iv = phi i64 [ %inc, %for.inc ], [ 1, %loop.ph<http://loop.ph> ]

>  %cmp = icmp sge i64 %iv, %a

>  br i1 %cmp, label %exit, label %for.inc

>

>for.inc:

>  %src.arrayidx = getelementptr inbounds i64, i64* %src, i64 %iv

>  %val = load i64, i64* %src.arrayidx

>  %dst.arrayidx = getelementptr inbounds i64, i64* %dst, i64 %iv

>  store i64 %val, i64* %dst.arrayidx

>  %inc = add nuw nsw i64 %iv, 1

>  %cond = icmp eq i64 %inc, %n

>  br i1 %cond, label %exit, label %loop

>

>exit:

>  ret void

>}

>Once that's done, the multiple exit vectorization work should vectorize this loop. Thinking about it, I really like this variant.
 I have not looked at the multiple exit vectorization work yet but it looks we could consider the inverted condition as early exit’s condition.

>The costing here seems quite off.  I have not looked at how the vectorize costs predicated loads on hardware without predication, but needing to scalarize a conditional VF-times and form a vector again does not have a cost of 3 million.  This could definitely be improved.
I agree with you.

Additionally, if possible, I would like to suggest to enable or add transformations in order to help vectorization. For example, as removing conditional branch inside loop, we could split a loop with dependency, which blocks vectorization, into vectorizable loop and non-vectorizable one using transformations like loop distribution. I am not sure why these features have not been enabled as default on pass manager but it would make more loops vectorizable.

Thanks
JinGu Kang
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20210504/8d7322e6/attachment.html>


More information about the llvm-dev mailing list