[PATCH][CodeGenPrepare] Split branch conditions into multiple branches.
Juergen Ributzka
juergen at apple.com
Thu Dec 4 15:59:19 PST 2014
Updated patch. This time with a test case and the optimization only kicks in when FastISel is enabled.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0002-CodeGenPrepare-Split-branch-conditions-into-multiple-v2.patch
Type: application/octet-stream
Size: 8699 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20141204/7d0858c0/attachment.obj>
-------------- next part --------------
> On Dec 4, 2014, at 2:57 PM, Juergen Ributzka <juergen at apple.com> wrote:
>
> Hi @ll,
>
> SimplifyCFG likes to fold conditional branches to a common destination into a single conditional branch, where the original conditions can be combined with an and/or instruction (FoldBranchToCommonDest).
>
> Example:
> bb1:
> %0 = icmp eq i32 %a, 0
> br i1 %0, label %bb3, label %bb2, !prof !0
>
> bb2:
> %1 = icmp eq i32 %b, 0
> br i1 %1, label %bb3, label %bb4, !prof !1
>
> is optimized to:
>
> bb1:
> %0 = icmp eq i32 %a, 0
> %1 = icmp eq i32 %b, 0
> %or.cond = or i1 %0, %1
> br i1 %or.cond, label %bb3, label %bb4, !prof !0
>
>
> During SelectionDAG time this transformation is reversed, because it is usually more efficient (code size and performance) to express this code as multiple branches. SelectionDAG can do this, because it can generate new MachineBasicBlocks. FastISel on the other side cannot do this and generates inefficient code (I see 10% regression on some benchmarks).
>
> The attached patch fixes this by performing the splitting early during CodeGenPrepare. In theory this code can be shared now by SelectionDAG and FastISel and the original implementation in SelectionDAG could be removed.
>
>
> Any comments and/or ideas about this approach in general? Is there a better way to do this?
>
> Thanks
>
> Cheers,
> Juergen
>
> <0001-Move-function-to-obtain-branch-weights-into-the-Bran.patch><0002-CodeGenPrepare-Split-branch-conditions-into-multiple.patch>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
More information about the llvm-commits
mailing list