blob: 5718b2dbdfb0349b89e792bbecbced007e5c22c5 [file] [log] [blame]
Nirav Dave5217bbc2018-07-18 18:34:52 +00001; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -o - %s -mtriple=x86_64--unknown-linux-gnu | FileCheck %s
3
4; When compiled and run this should print zero.
5
6
7@c = common local_unnamed_addr global i32 0, align 4
8@f = common local_unnamed_addr global i32 0, align 4
9@e = common local_unnamed_addr global i32 0, align 4
10@.str.1 = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1
11
12; FIXME The generated code here is incorrect. We should only see a
13; single store to f (a bytes store to f+3).
14define void @k(i32 %l) {
15; CHECK-LABEL: k:
16; CHECK: # %bb.0:
17; CHECK-NEXT: movl {{.*}}(%rip), %eax
18; CHECK-NEXT: movl %eax, %ecx
19; CHECK-NEXT: andl $2097151, %ecx # imm = 0x1FFFFF
20; CHECK-NEXT: xorl {{.*}}(%rip), %ecx
21; CHECK-NEXT: xorl $2097151, %ecx # imm = 0x1FFFFF
22; CHECK-NEXT: andl $-16777216, %eax # imm = 0xFF000000
23; CHECK-NEXT: orl %ecx, %eax
24; CHECK-NEXT: movl %eax, {{.*}}(%rip)
25; CHECK-NEXT: shrl $24, %eax
26; CHECK-NEXT: movb %al, f+{{.*}}(%rip)
27; CHECK-NEXT: retq
28 %load = load i32, i32* @c, align 4
29 %load6 = load i32, i32* @f, align 4
30 %clear7 = and i32 %load6, 16777215
31 store i32 %clear7, i32* @c, align 4
32 %neg = and i32 %load6, 2097151
33 %value = xor i32 %neg, 2097151
34 store i32 %load, i32* @c, align 4
35 %t0 = load i32, i32* @e, align 4
36 %value15 = xor i32 %t0, %value
37 %clear16 = and i32 %load6, -16777216
38 %set17 = or i32 %value15, %clear16
39 store i32 %set17, i32* @f, align 4
40 %clear25 = and i32 %set17, -16777216
41 %set26 = or i32 %clear25, %clear7
42 store i32 %set26, i32* @f, align 4
43 ret void
44}
45
46declare i32 @printf(i8* nocapture readonly, ...)
47
48define i32 @main() {
49; CHECK-LABEL: main:
50; CHECK: # %bb.0:
51; CHECK-NEXT: pushq %rax
52; CHECK-NEXT: .cfi_def_cfa_offset 16
53; CHECK-NEXT: movl $1, %edi
54; CHECK-NEXT: callq k
55; CHECK-NEXT: movl {{.*}}(%rip), %esi
56; CHECK-NEXT: movl $.L.str.1, %edi
57; CHECK-NEXT: xorl %eax, %eax
58; CHECK-NEXT: callq printf
59; CHECK-NEXT: xorl %eax, %eax
60; CHECK-NEXT: popq %rcx
61; CHECK-NEXT: .cfi_def_cfa_offset 8
62; CHECK-NEXT: retq
63 tail call void @k(i32 1)
64 %load = load i32, i32* @f, align 4
65 %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str.1, i64 0, i64 0), i32 %load)
66 ret i32 0
67}