blob: 2fb000f3538e0a69e480af20f834e832ca21a7d5 [file] [log] [blame]
Nirav Dave926e2d32017-08-10 15:12:32 +00001; 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;
10define i32 @pr34088() local_unnamed_addr {
11; CHECK-LABEL: pr34088:
Francis Visoiu Mistrih25528d62017-12-04 17:18:51 +000012; CHECK: # %bb.0: # %entry
Nirav Dave926e2d32017-08-10 15:12:32 +000013; CHECK-NEXT: pushl %ebp
Nirav Dave926e2d32017-08-10 15:12:32 +000014; CHECK-NEXT: .cfi_def_cfa_offset 8
Nirav Dave926e2d32017-08-10 15:12:32 +000015; CHECK-NEXT: .cfi_offset %ebp, -8
16; CHECK-NEXT: movl %esp, %ebp
Nirav Dave926e2d32017-08-10 15:12:32 +000017; 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 Makamc5698be2017-08-16 14:17:43 +000025; CHECK-NEXT: movl $-842150451, {{[0-9]+}}(%esp) # imm = 0xCDCDCDCD
Balaram Makam42adadf2017-08-30 14:57:12 +000026; CHECK-NEXT: movaps %xmm1, (%esp)
Nirav Dave926e2d32017-08-10 15:12:32 +000027; CHECK-NEXT: movsd %xmm0, {{[0-9]+}}(%esp)
28; CHECK-NEXT: movl %ebp, %esp
29; CHECK-NEXT: popl %ebp
Nirav Dave926e2d32017-08-10 15:12:32 +000030; CHECK-NEXT: retl
31entry:
32 %foo = alloca %struct.Foo, align 4
33 %0 = bitcast %struct.Foo* %foo to i8*
Daniel Neilson1e687242018-01-19 17:13:12 +000034 call void @llvm.memset.p0i8.i32(i8* align 4 nonnull %0, i8 0, i32 20, i1 false)
Nirav Dave926e2d32017-08-10 15:12:32 +000035 %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 Neilson1e687242018-01-19 17:13:12 +000038 call void @llvm.memset.p0i8.i32(i8* align 4 nonnull %0, i8 -51, i32 20, i1 false)
Nirav Dave926e2d32017-08-10 15:12:32 +000039 store i64 %2, i64* %1, align 4
40 ret i32 0
41}
42
Daniel Neilson1e687242018-01-19 17:13:12 +000043declare void @llvm.memset.p0i8.i32(i8* nocapture writeonly, i8, i32, i1)