| ; RUN: llc -mtriple=arm64-apple-ios -mcpu=cyclone < %s | FileCheck %s |
| ; Do not generate redundant select in early if-converstion pass. |
| |
| define i32 @foo(i32 %a, i32 %b) { |
| entry: |
| ;CHECK-LABEL: foo: |
| ;CHECK: csinc |
| ;CHECK-NOT: csel |
| %sub = sub nsw i32 %b, %a |
| %cmp10 = icmp sgt i32 %a, 0 |
| br i1 %cmp10, label %while.body.lr.ph, label %while.end |
| |
| while.body.lr.ph: |
| br label %while.body |
| |
| while.body: |
| %j.012 = phi i32 [ %sub, %while.body.lr.ph ], [ %inc, %if.then ], [ %inc, %if.else ] |
| %i.011 = phi i32 [ %a, %while.body.lr.ph ], [ %inc2, %if.then ], [ %dec, %if.else ] |
| %cmp1 = icmp slt i32 %i.011, %j.012 |
| br i1 %cmp1, label %while.end, label %while.cond |
| |
| while.cond: |
| %inc = add nsw i32 %j.012, 5 |
| %cmp2 = icmp slt i32 %inc, %b |
| br i1 %cmp2, label %if.then, label %if.else |
| |
| if.then: |
| %inc2 = add nsw i32 %i.011, 1 |
| br label %while.body |
| |
| if.else: |
| %dec = add nsw i32 %i.011, -1 |
| br label %while.body |
| |
| while.end: |
| %j.0.lcssa = phi i32 [ %j.012, %while.body ], [ %sub, %entry ] |
| %i.0.lcssa = phi i32 [ %i.011, %while.body ], [ %a, %entry ] |
| %add = add nsw i32 %j.0.lcssa, %i.0.lcssa |
| ret i32 %add |
| } |
| |