[AArch64,ELF] Restrict MOVZ/MOVK to non-PIC large code model (#70178)
[llvm-project.git] / llvm / test / CodeGen / X86 / 2008-09-19-RegAllocBug.ll
blobf027f3aa77d787f5e7b913409d7f184e2157b8a3
1 ; RUN: llc < %s -mtriple=i386-apple-darwin
2 ; PR2808
4 @g_3 = external global i32              ; <ptr> [#uses=1]
6 define i32 @func_4() nounwind {
7 entry:
8         %0 = load i32, ptr @g_3, align 4                ; <i32> [#uses=2]
9         %1 = trunc i32 %0 to i8         ; <i8> [#uses=1]
10         %2 = sub i8 1, %1               ; <i8> [#uses=1]
11         %3 = sext i8 %2 to i32          ; <i32> [#uses=1]
12         %s = select i1 icmp ne (i8 zext (i1 icmp ugt (i32 ptrtoint (ptr @func_4 to i32), i32 3) to i8), i8 0), i32 0, i32 ptrtoint (ptr @func_4 to i32)
13         %ashr = ashr i32 %3, %s
14         %urem = urem i32 %0, %ashr
15         %cmp = icmp eq i32 %urem, 0
16         br i1 %cmp, label %return, label %bb4
18 bb4:            ; preds = %entry
19         ret i32 undef
21 return:         ; preds = %entry
22         ret i32 undef