[AArch64,ELF] Restrict MOVZ/MOVK to non-PIC large code model (#70178)
[llvm-project.git] / llvm / test / CodeGen / X86 / pr37916.ll
blob2f8f0fdae1848c0153ce093fee141484385f6655
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=i386-unknown-linux-gnu %s -o - | FileCheck %s
4 @f = external dso_local local_unnamed_addr global ptr, align 4
5 @a = external dso_local global i64, align 8
7 define void @fn1() local_unnamed_addr {
8 ; CHECK-LABEL: fn1:
9 ; CHECK:       # %bb.0: # %entry
10 ; CHECK-NEXT:    .p2align 4, 0x90
11 ; CHECK-NEXT:  .LBB0_1: # %if.end
12 ; CHECK-NEXT:    # =>This Inner Loop Header: Depth=1
13 ; CHECK-NEXT:    movl a+4, %eax
14 ; CHECK-NEXT:    orl a, %eax
15 ; CHECK-NEXT:    movl $a, f
16 ; CHECK-NEXT:    je .LBB0_3
17 ; CHECK-NEXT:  # %bb.2: # %if.end
18 ; CHECK-NEXT:    # in Loop: Header=BB0_1 Depth=1
19 ; CHECK-NEXT:    jne .LBB0_1
20 ; CHECK-NEXT:  .LBB0_3: # %cond.false
21 entry:
22   br label %if.end
24 if.end:                                           ; preds = %cond.end, %entry
25   br label %if.then7
27 if.then7:                                         ; preds = %if.end
28   store ptr @a, ptr @f, align 4
29   %0 = load ptr, ptr @f, align 4
30   %1 = load i64, ptr %0, align 4
31   %tobool12 = icmp ne i64 %1, 0
32   %2 = load i64, ptr @a, align 8
33   %tobool13 = icmp ne i64 %2, 0
34   %3 = and i1 %tobool12, %tobool13
35   %tobool14.demorgan = and i1 %tobool12, %tobool13
36   br i1 %tobool14.demorgan, label %cond.end, label %cond.false
38 cond.false:                                       ; preds = %if.then7
39   unreachable
41 cond.end:                                         ; preds = %if.then7
42   %conv17 = sext i1 %3 to i8
43   br label %if.end