| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 |
| ; RUN: llc < %s -mtriple=aarch64 -O3 | FileCheck %s --check-prefixes=CHECK,CHECK-SD |
| ; RUN: llc < %s -mtriple=aarch64 -O3 -global-isel | FileCheck %s --check-prefixes=CHECK,CHECK-GI |
| |
| declare void @t() |
| |
| define void @test1(i32 %a) { |
| ; CHECK-LABEL: test1: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp w0, #12 |
| ; CHECK-NEXT: b.mi .LBB0_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB0_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = add nsw i32 %a, -12 |
| %cmp = icmp slt i32 %sub, 0 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test2(i64 %a) { |
| ; CHECK-LABEL: test2: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp x0, #12 |
| ; CHECK-NEXT: b.mi .LBB1_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB1_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = add nsw i64 %a, -12 |
| %cmp = icmp slt i64 %sub, 0 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test3(i32 %a) { |
| ; CHECK-LABEL: test3: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp w0, #12 |
| ; CHECK-NEXT: b.mi .LBB2_2 |
| ; CHECK-NEXT: // %bb.1: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB2_2: // %if.end |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = add nsw i32 %a, -12 |
| %cmp = icmp sgt i32 %sub, -1 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test4(i64 %a) { |
| ; CHECK-LABEL: test4: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp x0, #12 |
| ; CHECK-NEXT: b.mi .LBB3_2 |
| ; CHECK-NEXT: // %bb.1: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB3_2: // %if.end |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = add nsw i64 %a, -12 |
| %cmp = icmp sgt i64 %sub, -1 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test5(i32 %a) { |
| ; CHECK-LABEL: test5: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp w0, #12 |
| ; CHECK-NEXT: b.mi .LBB4_2 |
| ; CHECK-NEXT: // %bb.1: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB4_2: // %if.end |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = add nsw i32 %a, -12 |
| %cmp = icmp sge i32 %sub, 0 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test6(i64 %a) { |
| ; CHECK-LABEL: test6: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp x0, #12 |
| ; CHECK-NEXT: b.mi .LBB5_2 |
| ; CHECK-NEXT: // %bb.1: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB5_2: // %if.end |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = add nsw i64 %a, -12 |
| %cmp = icmp sge i64 %sub, 0 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test7(i32 %a) { |
| ; CHECK-LABEL: test7: |
| ; CHECK: // %bb.0: // %entry |
| ; CHECK-NEXT: cmp w0, #12 |
| ; CHECK-NEXT: b.mi .LBB6_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB6_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| entry: |
| %sub = sub nsw i32 %a, 12 |
| %cmp = icmp slt i32 %sub, 0 |
| br i1 %cmp, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test8(i64 %val1, i64 %val2, i64 %val3) { |
| ; CHECK-SD-LABEL: test8: |
| ; CHECK-SD: // %bb.0: |
| ; CHECK-SD-NEXT: tst x0, x1 |
| ; CHECK-SD-NEXT: b.pl .LBB7_3 |
| ; CHECK-SD-NEXT: // %bb.1: |
| ; CHECK-SD-NEXT: and x8, x1, x2 |
| ; CHECK-SD-NEXT: tbnz x8, #63, .LBB7_3 |
| ; CHECK-SD-NEXT: // %bb.2: // %if.then2 |
| ; CHECK-SD-NEXT: tst x0, x1, lsl #63 |
| ; CHECK-SD-NEXT: b.mi .LBB7_4 |
| ; CHECK-SD-NEXT: .LBB7_3: // %if.end |
| ; CHECK-SD-NEXT: ret |
| ; CHECK-SD-NEXT: .LBB7_4: // %if.then3 |
| ; CHECK-SD-NEXT: tst x0, x1, lsl #62 |
| ; CHECK-SD-NEXT: b.mi .LBB7_3 |
| ; CHECK-SD-NEXT: // %bb.5: // %if.then4 |
| ; CHECK-SD-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-SD-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-SD-NEXT: .cfi_offset w30, -16 |
| ; CHECK-SD-NEXT: bl t |
| ; CHECK-SD-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-SD-NEXT: ret |
| ; |
| ; CHECK-GI-LABEL: test8: |
| ; CHECK-GI: // %bb.0: |
| ; CHECK-GI-NEXT: tst x0, x1 |
| ; CHECK-GI-NEXT: b.pl .LBB7_3 |
| ; CHECK-GI-NEXT: // %bb.1: |
| ; CHECK-GI-NEXT: tst x1, x2 |
| ; CHECK-GI-NEXT: b.mi .LBB7_3 |
| ; CHECK-GI-NEXT: // %bb.2: // %if.then2 |
| ; CHECK-GI-NEXT: tst x0, x1, lsl #63 |
| ; CHECK-GI-NEXT: b.mi .LBB7_4 |
| ; CHECK-GI-NEXT: .LBB7_3: // %if.end |
| ; CHECK-GI-NEXT: ret |
| ; CHECK-GI-NEXT: .LBB7_4: // %if.then3 |
| ; CHECK-GI-NEXT: tst x0, x1, lsl #62 |
| ; CHECK-GI-NEXT: b.mi .LBB7_3 |
| ; CHECK-GI-NEXT: // %bb.5: // %if.then4 |
| ; CHECK-GI-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-GI-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-GI-NEXT: .cfi_offset w30, -16 |
| ; CHECK-GI-NEXT: bl t |
| ; CHECK-GI-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-GI-NEXT: ret |
| %and1 = and i64 %val1, %val2 |
| %tst1 = icmp slt i64 %and1, 0 |
| br i1 %tst1, label %if.then1, label %if.end |
| |
| |
| if.then1: |
| %and2 = and i64 %val2, %val3 |
| %tst2 = icmp sge i64 %and2, 0 |
| br i1 %tst2, label %if.then2, label %if.end |
| |
| |
| if.then2: |
| %shifted_op1 = shl i64 %val2, 63 |
| %shifted_and1 = and i64 %val1, %shifted_op1 |
| %tst3 = icmp slt i64 %shifted_and1, 0 |
| br i1 %tst3, label %if.then3, label %if.end |
| |
| |
| if.then3: |
| %shifted_op2 = shl i64 %val2, 62 |
| %shifted_and2 = and i64 %val1, %shifted_op2 |
| %tst4 = icmp sge i64 %shifted_and2, 0 |
| br i1 %tst4, label %if.then4, label %if.end |
| |
| |
| if.then4: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test9(i64 %val1) { |
| ; CHECK-LABEL: test9: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz x0, #63, .LBB8_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB8_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| %tst = icmp slt i64 %val1, 0 |
| br i1 %tst, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test10(i64 %val1) { |
| ; CHECK-LABEL: test10: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz x0, #63, .LBB9_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB9_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| %tst = icmp slt i64 %val1, 0 |
| br i1 %tst, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test11(i64 %val1, ptr %ptr) { |
| ; CHECK-LABEL: test11: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: ldr x8, [x1] |
| ; CHECK-NEXT: tbnz x8, #63, .LBB10_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB10_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| |
| |
| %val = load i64, ptr %ptr |
| %tst = icmp slt i64 %val, 0 |
| br i1 %tst, label %if.then, label %if.end |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test12(i64 %val1) { |
| ; CHECK-LABEL: test12: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz x0, #63, .LBB11_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB11_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| %tst = icmp slt i64 %val1, 0 |
| br i1 %tst, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test13(i64 %val1, i64 %val2) { |
| ; CHECK-LABEL: test13: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: orr x8, x0, x1 |
| ; CHECK-NEXT: tbnz x8, #63, .LBB12_2 |
| ; CHECK-NEXT: // %bb.1: // %if.end |
| ; CHECK-NEXT: ret |
| ; CHECK-NEXT: .LBB12_2: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: ret |
| %or = or i64 %val1, %val2 |
| %tst = icmp slt i64 %or, 0 |
| br i1 %tst, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test14(i1 %cond) { |
| ; CHECK-LABEL: test14: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #0, .LBB13_2 |
| ; CHECK-NEXT: // %bb.1: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB13_2: // %if.end |
| ; CHECK-NEXT: ret |
| br i1 %cond, label %if.end, label %if.then |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test15(i1 %cond) { |
| ; CHECK-LABEL: test15: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #0, .LBB14_2 |
| ; CHECK-NEXT: // %bb.1: // %if.then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB14_2: // %if.end |
| ; CHECK-NEXT: ret |
| %cond1 = xor i1 %cond, -1 |
| br i1 %cond1, label %if.then, label %if.end |
| |
| |
| if.then: |
| call void @t() |
| br label %if.end |
| |
| if.end: |
| ret void |
| } |
| |
| define void @test16(i64 %in) { |
| ; CHECK-LABEL: test16: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #2, .LBB15_2 |
| ; CHECK-NEXT: // %bb.1: // %then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB15_2: // %end |
| ; CHECK-NEXT: ret |
| %shl = shl i64 %in, 3 |
| %and = and i64 %shl, 32 |
| %cond = icmp eq i64 %and, 0 |
| br i1 %cond, label %then, label %end |
| |
| |
| then: |
| call void @t() |
| br label %end |
| |
| end: |
| ret void |
| } |
| |
| define void @test17(i64 %in) { |
| ; CHECK-LABEL: test17: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #3, .LBB16_2 |
| ; CHECK-NEXT: // %bb.1: // %then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB16_2: // %end |
| ; CHECK-NEXT: ret |
| %shr = ashr i64 %in, 3 |
| %and = and i64 %shr, 1 |
| %cond = icmp eq i64 %and, 0 |
| br i1 %cond, label %then, label %end |
| |
| |
| then: |
| call void @t() |
| br label %end |
| |
| end: |
| ret void |
| } |
| |
| define void @test18(i32 %in) { |
| ; CHECK-LABEL: test18: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #31, .LBB17_2 |
| ; CHECK-NEXT: // %bb.1: // %then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB17_2: // %end |
| ; CHECK-NEXT: ret |
| %shr = ashr i32 %in, 2 |
| %cond = icmp sge i32 %shr, 0 |
| br i1 %cond, label %then, label %end |
| |
| |
| then: |
| call void @t() |
| br label %end |
| |
| end: |
| ret void |
| } |
| |
| define void @test19(i64 %in) { |
| ; CHECK-LABEL: test19: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #3, .LBB18_2 |
| ; CHECK-NEXT: // %bb.1: // %then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset w30, -16 |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB18_2: // %end |
| ; CHECK-NEXT: ret |
| %shl = lshr i64 %in, 3 |
| %trunc = trunc i64 %shl to i32 |
| %and = and i32 %trunc, 1 |
| %cond = icmp eq i32 %and, 0 |
| br i1 %cond, label %then, label %end |
| |
| |
| then: |
| call void @t() |
| br label %end |
| |
| end: |
| ret void |
| } |
| |
| define void @test20(i32 %in) nounwind { |
| ; CHECK-LABEL: test20: |
| ; CHECK: // %bb.0: |
| ; CHECK-NEXT: tbnz w0, #2, .LBB19_2 |
| ; CHECK-NEXT: // %bb.1: // %then |
| ; CHECK-NEXT: str x30, [sp, #-16]! // 8-byte Folded Spill |
| ; CHECK-NEXT: bl t |
| ; CHECK-NEXT: ldr x30, [sp], #16 // 8-byte Folded Reload |
| ; CHECK-NEXT: .LBB19_2: // %end |
| ; CHECK-NEXT: ret |
| %shl = shl i32 %in, 3 |
| %zext = zext i32 %shl to i64 |
| %and = and i64 %zext, 32 |
| %cond = icmp eq i64 %and, 0 |
| br i1 %cond, label %then, label %end |
| |
| |
| then: |
| call void @t() |
| br label %end |
| |
| end: |
| ret void |
| } |
| |
| define ptr @tbnz_wzr(i1 %cmp1.not.i, ptr %locflg) { |
| ; CHECK-SD-LABEL: tbnz_wzr: |
| ; CHECK-SD: // %bb.0: // %entry |
| ; CHECK-SD-NEXT: tbz w0, #0, .LBB20_2 |
| ; CHECK-SD-NEXT: // %bb.1: |
| ; CHECK-SD-NEXT: tbnz wzr, #0, .LBB20_3 |
| ; CHECK-SD-NEXT: b .LBB20_4 |
| ; CHECK-SD-NEXT: .LBB20_2: // %opnfil.exit.thread |
| ; CHECK-SD-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: tbz w8, #0, .LBB20_4 |
| ; CHECK-SD-NEXT: .LBB20_3: // %if.else25 |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: .LBB20_4: // %common.ret |
| ; CHECK-SD-NEXT: mov x0, xzr |
| ; CHECK-SD-NEXT: ret |
| ; |
| ; CHECK-GI-LABEL: tbnz_wzr: |
| ; CHECK-GI: // %bb.0: // %entry |
| ; CHECK-GI-NEXT: mov w8, #0 // =0x0 |
| ; CHECK-GI-NEXT: tbz w0, #0, .LBB20_3 |
| ; CHECK-GI-NEXT: // %bb.1: // %if.end10 |
| ; CHECK-GI-NEXT: tbnz w8, #0, .LBB20_4 |
| ; CHECK-GI-NEXT: .LBB20_2: // %common.ret |
| ; CHECK-GI-NEXT: mov x0, xzr |
| ; CHECK-GI-NEXT: ret |
| ; CHECK-GI-NEXT: .LBB20_3: // %opnfil.exit.thread |
| ; CHECK-GI-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: tbz w8, #0, .LBB20_2 |
| ; CHECK-GI-NEXT: .LBB20_4: // %if.else25 |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: mov x0, xzr |
| ; CHECK-GI-NEXT: ret |
| entry: |
| br i1 %cmp1.not.i, label %if.end10, label %opnfil.exit.thread |
| |
| opnfil.exit.thread: ; preds = %entry |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end10 |
| |
| if.end10: ; preds = %opnfil.exit.thread, %entry |
| %cmp5 = phi i1 [ true, %opnfil.exit.thread ], [ false, %entry ] |
| br i1 %cmp5, label %if.else25, label %if.then12 |
| |
| if.then12: ; preds = %if.end10 |
| %call20 = load i32, ptr null, align 4 |
| br label %if.end26 |
| |
| if.else25: ; preds = %if.end10 |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end26 |
| |
| if.end26: ; preds = %if.else25, %if.then12 |
| br i1 %cmp5, label %common.ret, label %if.then28 |
| |
| common.ret: ; preds = %if.then28, %if.end26 |
| %common.ret.op = phi ptr [ null, %if.then28 ], [ null, %if.end26 ] |
| ret ptr %common.ret.op |
| |
| if.then28: ; preds = %if.end26 |
| %0 = load ptr, ptr null, align 8 |
| br label %common.ret |
| } |
| |
| define ptr @tbz_wzr(i1 %cmp1.not.i, ptr %locflg) { |
| ; CHECK-SD-LABEL: tbz_wzr: |
| ; CHECK-SD: // %bb.0: // %entry |
| ; CHECK-SD-NEXT: tbz w0, #0, .LBB21_2 |
| ; CHECK-SD-NEXT: // %bb.1: |
| ; CHECK-SD-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-SD-NEXT: tbnz w8, #0, .LBB21_3 |
| ; CHECK-SD-NEXT: b .LBB21_4 |
| ; CHECK-SD-NEXT: .LBB21_2: // %opnfil.exit.thread |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: tbz wzr, #0, .LBB21_4 |
| ; CHECK-SD-NEXT: .LBB21_3: // %if.else25 |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: .LBB21_4: // %common.ret |
| ; CHECK-SD-NEXT: mov x0, xzr |
| ; CHECK-SD-NEXT: ret |
| ; |
| ; CHECK-GI-LABEL: tbz_wzr: |
| ; CHECK-GI: // %bb.0: // %entry |
| ; CHECK-GI-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-GI-NEXT: tbz w0, #0, .LBB21_3 |
| ; CHECK-GI-NEXT: // %bb.1: // %if.end10 |
| ; CHECK-GI-NEXT: tbnz w8, #0, .LBB21_4 |
| ; CHECK-GI-NEXT: .LBB21_2: // %common.ret |
| ; CHECK-GI-NEXT: mov x0, xzr |
| ; CHECK-GI-NEXT: ret |
| ; CHECK-GI-NEXT: .LBB21_3: // %opnfil.exit.thread |
| ; CHECK-GI-NEXT: mov w8, #0 // =0x0 |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: tbz w8, #0, .LBB21_2 |
| ; CHECK-GI-NEXT: .LBB21_4: // %if.else25 |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: mov x0, xzr |
| ; CHECK-GI-NEXT: ret |
| entry: |
| br i1 %cmp1.not.i, label %if.end10, label %opnfil.exit.thread |
| |
| opnfil.exit.thread: ; preds = %entry |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end10 |
| |
| if.end10: ; preds = %opnfil.exit.thread, %entry |
| %cmp5 = phi i1 [ false, %opnfil.exit.thread ], [ true, %entry ] |
| br i1 %cmp5, label %if.else25, label %if.then12 |
| |
| if.then12: ; preds = %if.end10 |
| %call20 = load i32, ptr null, align 4 |
| br label %if.end26 |
| |
| if.else25: ; preds = %if.end10 |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end26 |
| |
| if.end26: ; preds = %if.else25, %if.then12 |
| br i1 %cmp5, label %common.ret, label %if.then28 |
| |
| common.ret: ; preds = %if.then28, %if.end26 |
| %common.ret.op = phi ptr [ null, %if.then28 ], [ null, %if.end26 ] |
| ret ptr %common.ret.op |
| |
| if.then28: ; preds = %if.end26 |
| %0 = load ptr, ptr null, align 8 |
| br label %common.ret |
| } |
| |
| define ptr @cbnz_wzr(i1 %cmp1.not.i, ptr %locflg) { |
| ; CHECK-SD-LABEL: cbnz_wzr: |
| ; CHECK-SD: // %bb.0: // %entry |
| ; CHECK-SD-NEXT: tbz w0, #0, .LBB22_2 |
| ; CHECK-SD-NEXT: // %bb.1: |
| ; CHECK-SD-NEXT: cbnz wzr, .LBB22_3 |
| ; CHECK-SD-NEXT: b .LBB22_4 |
| ; CHECK-SD-NEXT: .LBB22_2: // %opnfil.exit.thread |
| ; CHECK-SD-NEXT: mov w8, #10 // =0xa |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: cbz w8, .LBB22_4 |
| ; CHECK-SD-NEXT: .LBB22_3: // %if.else25 |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: .LBB22_4: // %common.ret |
| ; CHECK-SD-NEXT: mov x0, xzr |
| ; CHECK-SD-NEXT: ret |
| ; |
| ; CHECK-GI-LABEL: cbnz_wzr: |
| ; CHECK-GI: // %bb.0: // %entry |
| ; CHECK-GI-NEXT: mov w8, wzr |
| ; CHECK-GI-NEXT: tbnz w0, #0, .LBB22_2 |
| ; CHECK-GI-NEXT: // %bb.1: // %opnfil.exit.thread |
| ; CHECK-GI-NEXT: mov w8, #10 // =0xa |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: .LBB22_2: // %if.end10 |
| ; CHECK-GI-NEXT: cbz w8, .LBB22_4 |
| ; CHECK-GI-NEXT: // %bb.3: // %if.else25 |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: .LBB22_4: // %common.ret |
| ; CHECK-GI-NEXT: mov x0, xzr |
| ; CHECK-GI-NEXT: ret |
| entry: |
| br i1 %cmp1.not.i, label %if.end10, label %opnfil.exit.thread |
| |
| opnfil.exit.thread: ; preds = %entry |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end10 |
| |
| if.end10: ; preds = %opnfil.exit.thread, %entry |
| %cmp5 = phi i32 [ 10, %opnfil.exit.thread ], [ 0, %entry ] |
| %cmp5b = icmp ne i32 %cmp5, 0 |
| br i1 %cmp5b, label %if.else25, label %if.then12 |
| |
| if.then12: ; preds = %if.end10 |
| %call20 = load i32, ptr null, align 4 |
| br label %if.end26 |
| |
| if.else25: ; preds = %if.end10 |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end26 |
| |
| if.end26: ; preds = %if.else25, %if.then12 |
| br i1 %cmp5b, label %common.ret, label %if.then28 |
| |
| common.ret: ; preds = %if.then28, %if.end26 |
| %common.ret.op = phi ptr [ null, %if.then28 ], [ null, %if.end26 ] |
| ret ptr %common.ret.op |
| |
| if.then28: ; preds = %if.end26 |
| %0 = load ptr, ptr null, align 8 |
| br label %common.ret |
| } |
| |
| define ptr @cbz_wzr(i1 %cmp1.not.i, ptr %locflg) { |
| ; CHECK-SD-LABEL: cbz_wzr: |
| ; CHECK-SD: // %bb.0: // %entry |
| ; CHECK-SD-NEXT: tbz w0, #0, .LBB23_2 |
| ; CHECK-SD-NEXT: // %bb.1: |
| ; CHECK-SD-NEXT: mov w8, #10 // =0xa |
| ; CHECK-SD-NEXT: cbnz w8, .LBB23_3 |
| ; CHECK-SD-NEXT: b .LBB23_4 |
| ; CHECK-SD-NEXT: .LBB23_2: // %opnfil.exit.thread |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: cbz wzr, .LBB23_4 |
| ; CHECK-SD-NEXT: .LBB23_3: // %if.else25 |
| ; CHECK-SD-NEXT: str wzr, [x1] |
| ; CHECK-SD-NEXT: .LBB23_4: // %common.ret |
| ; CHECK-SD-NEXT: mov x0, xzr |
| ; CHECK-SD-NEXT: ret |
| ; |
| ; CHECK-GI-LABEL: cbz_wzr: |
| ; CHECK-GI: // %bb.0: // %entry |
| ; CHECK-GI-NEXT: mov w8, #10 // =0xa |
| ; CHECK-GI-NEXT: tbnz w0, #0, .LBB23_2 |
| ; CHECK-GI-NEXT: // %bb.1: // %opnfil.exit.thread |
| ; CHECK-GI-NEXT: mov w8, wzr |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: .LBB23_2: // %if.end10 |
| ; CHECK-GI-NEXT: cbz w8, .LBB23_4 |
| ; CHECK-GI-NEXT: // %bb.3: // %if.else25 |
| ; CHECK-GI-NEXT: str wzr, [x1] |
| ; CHECK-GI-NEXT: .LBB23_4: // %common.ret |
| ; CHECK-GI-NEXT: mov x0, xzr |
| ; CHECK-GI-NEXT: ret |
| entry: |
| br i1 %cmp1.not.i, label %if.end10, label %opnfil.exit.thread |
| |
| opnfil.exit.thread: ; preds = %entry |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end10 |
| |
| if.end10: ; preds = %opnfil.exit.thread, %entry |
| %cmp5 = phi i32 [ 0, %opnfil.exit.thread ], [ 10, %entry ] |
| %cmp5b = icmp ne i32 %cmp5, 0 |
| br i1 %cmp5b, label %if.else25, label %if.then12 |
| |
| if.then12: ; preds = %if.end10 |
| %call20 = load i32, ptr null, align 4 |
| br label %if.end26 |
| |
| if.else25: ; preds = %if.end10 |
| store i32 0, ptr %locflg, align 4 |
| br label %if.end26 |
| |
| if.end26: ; preds = %if.else25, %if.then12 |
| br i1 %cmp5b, label %common.ret, label %if.then28 |
| |
| common.ret: ; preds = %if.then28, %if.end26 |
| %common.ret.op = phi ptr [ null, %if.then28 ], [ null, %if.end26 ] |
| ret ptr %common.ret.op |
| |
| if.then28: ; preds = %if.end26 |
| %0 = load ptr, ptr null, align 8 |
| br label %common.ret |
| } |
| |
| define i1 @avifSequenceHeaderParse() { |
| ; CHECK-SD-LABEL: avifSequenceHeaderParse: |
| ; CHECK-SD: // %bb.0: // %entry |
| ; CHECK-SD-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-SD-NEXT: cbz w8, .LBB24_2 |
| ; CHECK-SD-NEXT: .LBB24_1: // %bb6 |
| ; CHECK-SD-NEXT: mov w0, wzr |
| ; CHECK-SD-NEXT: ret |
| ; CHECK-SD-NEXT: .LBB24_2: // %bb1 |
| ; CHECK-SD-NEXT: cbz w8, .LBB24_4 |
| ; CHECK-SD-NEXT: // %bb.3: |
| ; CHECK-SD-NEXT: tbz xzr, #63, .LBB24_1 |
| ; CHECK-SD-NEXT: b .LBB24_5 |
| ; CHECK-SD-NEXT: .LBB24_4: // %bb2 |
| ; CHECK-SD-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-SD-NEXT: tbz x8, #63, .LBB24_1 |
| ; CHECK-SD-NEXT: .LBB24_5: // %bb4 |
| ; CHECK-SD-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-SD-NEXT: mov w0, wzr |
| ; CHECK-SD-NEXT: ret |
| ; |
| ; CHECK-GI-LABEL: avifSequenceHeaderParse: |
| ; CHECK-GI: // %bb.0: // %entry |
| ; CHECK-GI-NEXT: mov w0, wzr |
| ; CHECK-GI-NEXT: mov w8, #1 // =0x1 |
| ; CHECK-GI-NEXT: ret |
| entry: |
| %a = icmp slt i64 0, 0 |
| br i1 %a, label %bb1, label %bb6 |
| |
| bb1: ; preds = %entry |
| %b = icmp eq i32 1, 0 |
| br i1 %b, label %bb2, label %bb3 |
| |
| bb2: ; preds = %bb1 |
| %c = load i8, ptr null, align 1 |
| %d = zext i8 1 to i64 |
| %e = shl i64 %d, 0 |
| br label %bb3 |
| |
| bb3: ; preds = %bb2, %bb1 |
| %f = phi i64 [ %e, %bb2 ], [ 0, %bb1 ] |
| %g = icmp slt i64 %f, 0 |
| br i1 %g, label %bb4, label %bb6 |
| |
| bb4: ; preds = %bb3 |
| %h = icmp eq i32 1, 0 |
| br i1 %h, label %bb5, label %bb7 |
| |
| bb5: ; preds = %bb4 |
| %i = load i8, ptr null, align 1 |
| %j = shl i64 0, 0 |
| br label %bb7 |
| |
| bb6: ; preds = %bb7, %bb3, %entry |
| %k = phi i1 [ false, %bb7 ], [ false, %bb3 ], [ false, %entry ] |
| ret i1 %k |
| |
| bb7: ; preds = %bb5, %bb4 |
| %l = phi ptr [ inttoptr (i64 1 to ptr), %bb5 ], [ null, %bb4 ] |
| %m = phi i64 [ %j, %bb5 ], [ 0, %bb4 ] |
| %n = icmp ult ptr %l, null |
| br label %bb6 |
| } |