[AArch64,ELF] Restrict MOVZ/MOVK to non-PIC large code model (#70178)
[llvm-project.git] / llvm / test / CodeGen / ARM / ifcvt6.ll
blobf76f87eb5dcf1d790d9d58cc8f56dbab544e5b45
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=armv7-apple-ios | FileCheck %s
4 define 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
17 entry:
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
23 cond_true:              ; preds = %entry
24         %tmp10 = call i32 (...) @bar( )         ; <i32> [#uses=0]
25         ret void
27 UnifiedReturnBlock:             ; preds = %entry
28         ret void
31 declare i32 @bar(...)