blob: dc56e5390e53c736f1d3d6000cd8465877a35d86 [file] [log] [blame]
Duncan P. N. Exon Smith73686d32014-06-17 00:19:35 +00001; RUN: opt < %s -sroa -S | FileCheck %s
Reid Klecknerc36f48f2014-08-22 00:09:56 +00002target datalayout = "e-p:64:64:64-p1:16:16:16-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:64:64-f80:128-v64:64:64-v128:128:128-a0:0:64-n8:16:32:64"
Duncan P. N. Exon Smith73686d32014-06-17 00:19:35 +00003
4declare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind
Reid Klecknerc36f48f2014-08-22 00:09:56 +00005declare void @llvm.memset.p0i8.i32(i8* nocapture, i8, i32, i32, i1) nounwind
Duncan P. N. Exon Smith73686d32014-06-17 00:19:35 +00006
7define void @no_split_on_non_byte_width(i32) {
8; This tests that allocas are not split into slices that are not byte width multiple
9 %arg = alloca i32 , align 8
10 store i32 %0, i32* %arg
11 br label %load_i32
12
13load_i32:
14; CHECK-LABEL: load_i32:
15; CHECK-NOT: bitcast {{.*}} to i1
16; CHECK-NOT: zext i1
17 %r0 = load i32* %arg
18 br label %load_i1
19
20load_i1:
21; CHECK-LABEL: load_i1:
22; CHECK: bitcast {{.*}} to i1
23 %p1 = bitcast i32* %arg to i1*
24 %t1 = load i1* %p1
25 ret void
26}
Reid Klecknerc36f48f2014-08-22 00:09:56 +000027
28; PR18726: Check that we use memcpy and memset to fill out padding when we have
29; a slice with a simple single type whose store size is smaller than the slice
30; size.
31
32%union.Foo = type { x86_fp80, i64, i64 }
33
34@foo_copy_source = external constant %union.Foo
35@i64_sink = global i64 0
36
37define void @memcpy_fp80_padding() {
38 %x = alloca %union.Foo
39
40 ; Copy from a global.
41 %x_i8 = bitcast %union.Foo* %x to i8*
42 call void @llvm.memcpy.p0i8.p0i8.i32(i8* %x_i8, i8* bitcast (%union.Foo* @foo_copy_source to i8*), i32 32, i32 16, i1 false)
43
44 ; Access a slice of the alloca to trigger SROA.
45 %mid_p = getelementptr %union.Foo* %x, i32 0, i32 1
46 %elt = load i64* %mid_p
47 store i64 %elt, i64* @i64_sink
48 ret void
49}
50; CHECK-LABEL: define void @memcpy_fp80_padding
51; CHECK: alloca x86_fp80
52; CHECK: call void @llvm.memcpy.p0i8.p0i8.i32
53; CHECK: load i64* getelementptr inbounds (%union.Foo* @foo_copy_source, i64 0, i32 1)
54; CHECK: load i64* getelementptr inbounds (%union.Foo* @foo_copy_source, i64 0, i32 2)
55
56define void @memset_fp80_padding() {
57 %x = alloca %union.Foo
58
59 ; Set to all ones.
60 %x_i8 = bitcast %union.Foo* %x to i8*
61 call void @llvm.memset.p0i8.i32(i8* %x_i8, i8 -1, i32 32, i32 16, i1 false)
62
63 ; Access a slice of the alloca to trigger SROA.
64 %mid_p = getelementptr %union.Foo* %x, i32 0, i32 1
65 %elt = load i64* %mid_p
66 store i64 %elt, i64* @i64_sink
67 ret void
68}
69; CHECK-LABEL: define void @memset_fp80_padding
70; CHECK: alloca x86_fp80
71; CHECK: call void @llvm.memset.p0i8.i32(i8* %{{.*}}, i8 -1, i32 16, i32 16, i1 false)
72; CHECK: store i64 -1, i64* @i64_sink