Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 1 | ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| 2 | ; RUN: llc < %s -mtriple=i686-unknown -mcpu=pentium4 | FileCheck %s |
| 3 | |
| 4 | %struct.Foo = type { i32, %struct.Bar } |
| 5 | %struct.Bar = type { i32, %struct.Buffer, i32 } |
| 6 | %struct.Buffer = type { i8*, i32 } |
| 7 | |
| 8 | ; This test checks that the load of store %2 is not dropped. |
| 9 | ; |
| 10 | define i32 @pr34088() local_unnamed_addr { |
| 11 | ; CHECK-LABEL: pr34088: |
Francis Visoiu Mistrih | 25528d6 | 2017-12-04 17:18:51 +0000 | [diff] [blame] | 12 | ; CHECK: # %bb.0: # %entry |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 13 | ; CHECK-NEXT: pushl %ebp |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 14 | ; CHECK-NEXT: .cfi_def_cfa_offset 8 |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 15 | ; CHECK-NEXT: .cfi_offset %ebp, -8 |
| 16 | ; CHECK-NEXT: movl %esp, %ebp |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 17 | ; CHECK-NEXT: .cfi_def_cfa_register %ebp |
| 18 | ; CHECK-NEXT: andl $-16, %esp |
| 19 | ; CHECK-NEXT: subl $32, %esp |
| 20 | ; CHECK-NEXT: xorps %xmm0, %xmm0 |
| 21 | ; CHECK-NEXT: movaps {{.*#+}} xmm1 = [205,205,205,205,205,205,205,205,205,205,205,205,205,205,205,205] |
| 22 | ; CHECK-NEXT: xorl %eax, %eax |
| 23 | ; CHECK-NEXT: movaps %xmm0, (%esp) |
| 24 | ; CHECK-NEXT: movsd {{.*#+}} xmm0 = mem[0],zero |
Balaram Makam | c5698be | 2017-08-16 14:17:43 +0000 | [diff] [blame] | 25 | ; CHECK-NEXT: movl $-842150451, {{[0-9]+}}(%esp) # imm = 0xCDCDCDCD |
Balaram Makam | 42adadf | 2017-08-30 14:57:12 +0000 | [diff] [blame] | 26 | ; CHECK-NEXT: movaps %xmm1, (%esp) |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 27 | ; CHECK-NEXT: movsd %xmm0, {{[0-9]+}}(%esp) |
| 28 | ; CHECK-NEXT: movl %ebp, %esp |
| 29 | ; CHECK-NEXT: popl %ebp |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 30 | ; CHECK-NEXT: retl |
| 31 | entry: |
| 32 | %foo = alloca %struct.Foo, align 4 |
| 33 | %0 = bitcast %struct.Foo* %foo to i8* |
Daniel Neilson | 1e68724 | 2018-01-19 17:13:12 +0000 | [diff] [blame] | 34 | call void @llvm.memset.p0i8.i32(i8* align 4 nonnull %0, i8 0, i32 20, i1 false) |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 35 | %buffer1 = getelementptr inbounds %struct.Foo, %struct.Foo* %foo, i32 0, i32 1, i32 1 |
| 36 | %1 = bitcast %struct.Buffer* %buffer1 to i64* |
| 37 | %2 = load i64, i64* %1, align 4 |
Daniel Neilson | 1e68724 | 2018-01-19 17:13:12 +0000 | [diff] [blame] | 38 | call void @llvm.memset.p0i8.i32(i8* align 4 nonnull %0, i8 -51, i32 20, i1 false) |
Nirav Dave | 926e2d3 | 2017-08-10 15:12:32 +0000 | [diff] [blame] | 39 | store i64 %2, i64* %1, align 4 |
| 40 | ret i32 0 |
| 41 | } |
| 42 | |
Daniel Neilson | 1e68724 | 2018-01-19 17:13:12 +0000 | [diff] [blame] | 43 | declare void @llvm.memset.p0i8.i32(i8* nocapture writeonly, i8, i32, i1) |