Nirav Dave | 5217bbc | 2018-07-18 18:34:52 +0000 | [diff] [blame^] | 1 | ; 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). |
| 14 | define 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 | |
| 46 | declare i32 @printf(i8* nocapture readonly, ...) |
| 47 | |
| 48 | define 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 | } |