xref: /llvm-project/llvm/test/CodeGen/ARM/ifcvt6.ll (revision 9c4c2f24725e9f98b96fb360894276d342c3ba50)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc < %s -mtriple=armv7-apple-ios | FileCheck %s
3
4define void @foo(i32 %X, i32 %Y) {
5; CHECK-LABEL: foo:
6; CHECK:       @ %bb.0: @ %entry
7; CHECK-NEXT:    cmp r1, #0
8; CHECK-NEXT:    beq LBB0_2
9; CHECK-NEXT:  @ %bb.1: @ %entry
10; CHECK-NEXT:    cmp r0, #4
11; CHECK-NEXT:    bxhs lr
12; CHECK-NEXT:  LBB0_2: @ %cond_true
13; CHECK-NEXT:    push {lr}
14; CHECK-NEXT:    bl _bar
15; CHECK-NEXT:    pop {lr}
16; CHECK-NEXT:    bx lr
17entry:
18	%tmp1 = icmp ult i32 %X, 4		; <i1> [#uses=1]
19	%tmp4 = icmp eq i32 %Y, 0		; <i1> [#uses=1]
20	%tmp7 = or i1 %tmp4, %tmp1		; <i1> [#uses=1]
21	br i1 %tmp7, label %cond_true, label %UnifiedReturnBlock
22
23cond_true:		; preds = %entry
24	%tmp10 = call i32 (...) @bar( )		; <i32> [#uses=0]
25	ret void
26
27UnifiedReturnBlock:		; preds = %entry
28	ret void
29}
30
31declare i32 @bar(...)
32