blob: 68d7390b0e6bccec803ef3d22afc4da97329f111 [file] [log] [blame]
Peter Collingbourne10c500d2017-02-17 17:36:52 +00001; RUN: opt < %s -data-layout="e-p:64:64:64-p1:16:16:16-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64" -instcombine -S | FileCheck %s --check-prefix=LE
2; RUN: opt < %s -data-layout="E-p:64:64:64-p1:16:16:16-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64" -instcombine -S | FileCheck %s --check-prefix=BE
Chris Lattnered00b802009-10-23 06:23:49 +00003
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +00004; {{ 0xDEADBEEF, 0xBA }, 0xCAFEBABE}
Chris Lattner9e2d5b32009-10-24 05:22:15 +00005@g1 = constant {{i32,i8},i32} {{i32,i8} { i32 -559038737, i8 186 }, i32 -889275714 }
6@g2 = constant double 1.0
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +00007; { 0x7B, 0x06B1BFF8 }
Chris Lattner9e2d5b32009-10-24 05:22:15 +00008@g3 = constant {i64, i64} { i64 123, i64 112312312 }
Chris Lattnered00b802009-10-23 06:23:49 +00009
10; Simple load
11define i32 @test1() {
David Blaikief72d05b2015-03-13 18:20:45 +000012 %r = load i32, i32* getelementptr ({{i32,i8},i32}, {{i32,i8},i32}* @g1, i32 0, i32 0, i32 0)
Chris Lattnered00b802009-10-23 06:23:49 +000013 ret i32 %r
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000014
15; 0xDEADBEEF
Stephen Linc1c7a132013-07-14 01:42:54 +000016; LE-LABEL: @test1(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000017; LE: ret i32 -559038737
18
19; 0xDEADBEEF
Stephen Linc1c7a132013-07-14 01:42:54 +000020; BE-LABEL: @test1(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000021; BE: ret i32 -559038737
Chris Lattnered00b802009-10-23 06:23:49 +000022}
23
24; PR3152
25; Load of first 16 bits of 32-bit value.
26define i16 @test2() {
David Blaikief72d05b2015-03-13 18:20:45 +000027 %r = load i16, i16* bitcast(i32* getelementptr ({{i32,i8},i32}, {{i32,i8},i32}* @g1, i32 0, i32 0, i32 0) to i16*)
Chris Lattnered00b802009-10-23 06:23:49 +000028 ret i16 %r
29
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000030; 0xBEEF
Stephen Linc1c7a132013-07-14 01:42:54 +000031; LE-LABEL: @test2(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000032; LE: ret i16 -16657
33
34; 0xDEAD
Stephen Linc1c7a132013-07-14 01:42:54 +000035; BE-LABEL: @test2(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000036; BE: ret i16 -8531
Chris Lattnered00b802009-10-23 06:23:49 +000037}
38
Matt Arsenaultcaa9c712014-07-14 22:39:26 +000039define i16 @test2_addrspacecast() {
David Blaikief72d05b2015-03-13 18:20:45 +000040 %r = load i16, i16 addrspace(1)* addrspacecast(i32* getelementptr ({{i32,i8},i32}, {{i32,i8},i32}* @g1, i32 0, i32 0, i32 0) to i16 addrspace(1)*)
Matt Arsenaultcaa9c712014-07-14 22:39:26 +000041 ret i16 %r
42
Matt Arsenault95365ca2015-07-27 18:31:03 +000043; FIXME: Should be able to load through a constant addrspacecast.
Matt Arsenaultcaa9c712014-07-14 22:39:26 +000044; 0xBEEF
45; LE-LABEL: @test2_addrspacecast(
Matt Arsenault95365ca2015-07-27 18:31:03 +000046; XLE: ret i16 -16657
47; LE: load i16, i16 addrspace(1)* addrspacecast
Matt Arsenaultcaa9c712014-07-14 22:39:26 +000048
49; 0xDEAD
50; BE-LABEL: @test2_addrspacecast(
Matt Arsenault95365ca2015-07-27 18:31:03 +000051; XBE: ret i16 -8531
52; BE: load i16, i16 addrspace(1)* addrspacecast
Matt Arsenaultcaa9c712014-07-14 22:39:26 +000053}
54
Chris Lattnered00b802009-10-23 06:23:49 +000055; Load of second 16 bits of 32-bit value.
56define i16 @test3() {
David Blaikief72d05b2015-03-13 18:20:45 +000057 %r = load i16, i16* getelementptr(i16, i16* bitcast(i32* getelementptr ({{i32,i8},i32}, {{i32,i8},i32}* @g1, i32 0, i32 0, i32 0) to i16*), i32 1)
Chris Lattnered00b802009-10-23 06:23:49 +000058 ret i16 %r
59
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000060; 0xDEAD
Stephen Linc1c7a132013-07-14 01:42:54 +000061; LE-LABEL: @test3(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000062; LE: ret i16 -8531
63
64; 0xBEEF
Stephen Linc1c7a132013-07-14 01:42:54 +000065; BE-LABEL: @test3(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000066; BE: ret i16 -16657
Chris Lattnered00b802009-10-23 06:23:49 +000067}
68
69; Load of 8 bit field + tail padding.
70define i16 @test4() {
David Blaikief72d05b2015-03-13 18:20:45 +000071 %r = load i16, i16* getelementptr(i16, i16* bitcast(i32* getelementptr ({{i32,i8},i32}, {{i32,i8},i32}* @g1, i32 0, i32 0, i32 0) to i16*), i32 2)
Chris Lattnered00b802009-10-23 06:23:49 +000072 ret i16 %r
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000073
74; 0x00BA
Stephen Linc1c7a132013-07-14 01:42:54 +000075; LE-LABEL: @test4(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000076; LE: ret i16 186
77
78; 0xBA00
Stephen Linc1c7a132013-07-14 01:42:54 +000079; BE-LABEL: @test4(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000080; BE: ret i16 -17920
Chris Lattnered00b802009-10-23 06:23:49 +000081}
82
83; Load of double bits.
84define i64 @test6() {
David Blaikiea79ac142015-02-27 21:17:42 +000085 %r = load i64, i64* bitcast(double* @g2 to i64*)
Chris Lattnered00b802009-10-23 06:23:49 +000086 ret i64 %r
87
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000088; 0x3FF_0000000000000
Stephen Linc1c7a132013-07-14 01:42:54 +000089; LE-LABEL: @test6(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000090; LE: ret i64 4607182418800017408
91
92; 0x3FF_0000000000000
Stephen Linc1c7a132013-07-14 01:42:54 +000093; BE-LABEL: @test6(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +000094; BE: ret i64 4607182418800017408
Chris Lattnered00b802009-10-23 06:23:49 +000095}
96
97; Load of double bits.
98define i16 @test7() {
David Blaikiea79ac142015-02-27 21:17:42 +000099 %r = load i16, i16* bitcast(double* @g2 to i16*)
Chris Lattnered00b802009-10-23 06:23:49 +0000100 ret i16 %r
101
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000102; 0x0000
Stephen Linc1c7a132013-07-14 01:42:54 +0000103; LE-LABEL: @test7(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000104; LE: ret i16 0
105
106; 0x3FF0
Stephen Linc1c7a132013-07-14 01:42:54 +0000107; BE-LABEL: @test7(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000108; BE: ret i16 16368
Chris Lattnered00b802009-10-23 06:23:49 +0000109}
110
111; Double load.
112define double @test8() {
David Blaikiea79ac142015-02-27 21:17:42 +0000113 %r = load double, double* bitcast({{i32,i8},i32}* @g1 to double*)
Chris Lattnered00b802009-10-23 06:23:49 +0000114 ret double %r
115
Stephen Linc1c7a132013-07-14 01:42:54 +0000116; LE-LABEL: @test8(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000117; LE: ret double 0xBADEADBEEF
118
Stephen Linc1c7a132013-07-14 01:42:54 +0000119; BE-LABEL: @test8(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000120; BE: ret double 0xDEADBEEFBA000000
Chris Lattnered00b802009-10-23 06:23:49 +0000121}
Chris Lattner59f94c02009-10-23 06:50:36 +0000122
123
124; i128 load.
125define i128 @test9() {
David Blaikiea79ac142015-02-27 21:17:42 +0000126 %r = load i128, i128* bitcast({i64, i64}* @g3 to i128*)
Chris Lattner59f94c02009-10-23 06:50:36 +0000127 ret i128 %r
128
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000129; 0x00000000_06B1BFF8_00000000_0000007B
Stephen Linc1c7a132013-07-14 01:42:54 +0000130; LE-LABEL: @test9(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000131; LE: ret i128 2071796475790618158476296315
132
133; 0x00000000_0000007B_00000000_06B1BFF8
Stephen Linc1c7a132013-07-14 01:42:54 +0000134; BE-LABEL: @test9(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000135; BE: ret i128 2268949521066387161080
Chris Lattner59f94c02009-10-23 06:50:36 +0000136}
Chris Lattnerccf1e842009-10-23 06:57:37 +0000137
138; vector load.
139define <2 x i64> @test10() {
David Blaikiea79ac142015-02-27 21:17:42 +0000140 %r = load <2 x i64>, <2 x i64>* bitcast({i64, i64}* @g3 to <2 x i64>*)
Chris Lattnerccf1e842009-10-23 06:57:37 +0000141 ret <2 x i64> %r
142
Stephen Linc1c7a132013-07-14 01:42:54 +0000143; LE-LABEL: @test10(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000144; LE: ret <2 x i64> <i64 123, i64 112312312>
145
Stephen Linc1c7a132013-07-14 01:42:54 +0000146; BE-LABEL: @test10(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000147; BE: ret <2 x i64> <i64 123, i64 112312312>
Chris Lattnerccf1e842009-10-23 06:57:37 +0000148}
149
Chris Lattner9e2d5b32009-10-24 05:22:15 +0000150
151; PR5287
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000152; { 0xA1, 0x08 }
Chris Lattner9e2d5b32009-10-24 05:22:15 +0000153@g4 = internal constant { i8, i8 } { i8 -95, i8 8 }
154
155define i16 @test11() nounwind {
156entry:
David Blaikiea79ac142015-02-27 21:17:42 +0000157 %a = load i16, i16* bitcast ({ i8, i8 }* @g4 to i16*)
Chris Lattner9e2d5b32009-10-24 05:22:15 +0000158 ret i16 %a
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000159
160; 0x08A1
Stephen Linc1c7a132013-07-14 01:42:54 +0000161; LE-LABEL: @test11(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000162; LE: ret i16 2209
163
164; 0xA108
Stephen Linc1c7a132013-07-14 01:42:54 +0000165; BE-LABEL: @test11(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000166; BE: ret i16 -24312
Chris Lattner9e2d5b32009-10-24 05:22:15 +0000167}
168
169
Chris Lattner1ddfd9f2009-12-04 06:29:29 +0000170; PR5551
171@test12g = private constant [6 x i8] c"a\00b\00\00\00"
172
173define i16 @test12() {
David Blaikief72d05b2015-03-13 18:20:45 +0000174 %a = load i16, i16* getelementptr inbounds ([3 x i16], [3 x i16]* bitcast ([6 x i8]* @test12g to [3 x i16]*), i32 0, i64 1)
Chris Lattner1ddfd9f2009-12-04 06:29:29 +0000175 ret i16 %a
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000176
177; 0x0062
Stephen Linc1c7a132013-07-14 01:42:54 +0000178; LE-LABEL: @test12(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000179; LE: ret i16 98
180
181; 0x6200
Stephen Linc1c7a132013-07-14 01:42:54 +0000182; BE-LABEL: @test12(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000183; BE: ret i16 25088
Chris Lattner1ddfd9f2009-12-04 06:29:29 +0000184}
Chris Lattnera69f89c2010-01-08 19:02:23 +0000185
186
187; PR5978
188@g5 = constant i8 4
189define i1 @test13() {
David Blaikiea79ac142015-02-27 21:17:42 +0000190 %A = load i1, i1* bitcast (i8* @g5 to i1*)
Chris Lattnera69f89c2010-01-08 19:02:23 +0000191 ret i1 %A
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000192
Stephen Linc1c7a132013-07-14 01:42:54 +0000193; LE-LABEL: @test13(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000194; LE: ret i1 false
195
Stephen Linc1c7a132013-07-14 01:42:54 +0000196; BE-LABEL: @test13(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000197; BE: ret i1 false
Chris Lattnera69f89c2010-01-08 19:02:23 +0000198}
Anders Carlssond21b06a2011-02-06 20:11:56 +0000199
200@g6 = constant [2 x i8*] [i8* inttoptr (i64 1 to i8*), i8* inttoptr (i64 2 to i8*)]
201define i64 @test14() nounwind {
202entry:
David Blaikiea79ac142015-02-27 21:17:42 +0000203 %tmp = load i64, i64* bitcast ([2 x i8*]* @g6 to i64*)
Anders Carlssond21b06a2011-02-06 20:11:56 +0000204 ret i64 %tmp
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000205
Stephen Linc1c7a132013-07-14 01:42:54 +0000206; LE-LABEL: @test14(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000207; LE: ret i64 1
208
Stephen Linc1c7a132013-07-14 01:42:54 +0000209; BE-LABEL: @test14(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000210; BE: ret i64 1
Anders Carlssond21b06a2011-02-06 20:11:56 +0000211}
212
Matt Arsenault7a960a82013-08-20 21:20:04 +0000213; Check with address space pointers
214@g6_as1 = constant [2 x i8 addrspace(1)*] [i8 addrspace(1)* inttoptr (i16 1 to i8 addrspace(1)*), i8 addrspace(1)* inttoptr (i16 2 to i8 addrspace(1)*)]
215define i16 @test14_as1() nounwind {
216entry:
David Blaikiea79ac142015-02-27 21:17:42 +0000217 %tmp = load i16, i16* bitcast ([2 x i8 addrspace(1)*]* @g6_as1 to i16*)
Matt Arsenault7a960a82013-08-20 21:20:04 +0000218 ret i16 %tmp
219
220; LE: @test14_as1
221; LE: ret i16 1
222
223; BE: @test14_as1
224; BE: ret i16 1
225}
226
Anders Carlssond21b06a2011-02-06 20:11:56 +0000227define i64 @test15() nounwind {
228entry:
David Blaikief72d05b2015-03-13 18:20:45 +0000229 %tmp = load i64, i64* bitcast (i8** getelementptr inbounds ([2 x i8*], [2 x i8*]* @g6, i32 0, i64 1) to i64*)
Anders Carlssond21b06a2011-02-06 20:11:56 +0000230 ret i64 %tmp
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000231
Stephen Linc1c7a132013-07-14 01:42:54 +0000232; LE-LABEL: @test15(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000233; LE: ret i64 2
234
Stephen Linc1c7a132013-07-14 01:42:54 +0000235; BE-LABEL: @test15(
NAKAMURA Takumi43ab4ef2012-11-08 20:34:25 +0000236; BE: ret i64 2
Anders Carlssond21b06a2011-02-06 20:11:56 +0000237}
Chandler Carrutha0e56952014-05-15 09:56:28 +0000238
239@gv7 = constant [4 x i8*] [i8* null, i8* inttoptr (i64 -14 to i8*), i8* null, i8* null]
240define i64 @test16.1() {
David Blaikiea79ac142015-02-27 21:17:42 +0000241 %v = load i64, i64* bitcast ([4 x i8*]* @gv7 to i64*), align 8
Chandler Carrutha0e56952014-05-15 09:56:28 +0000242 ret i64 %v
243
244; LE-LABEL: @test16.1(
245; LE: ret i64 0
246
247; BE-LABEL: @test16.1(
248; BE: ret i64 0
249}
250
251define i64 @test16.2() {
David Blaikief72d05b2015-03-13 18:20:45 +0000252 %v = load i64, i64* bitcast (i8** getelementptr inbounds ([4 x i8*], [4 x i8*]* @gv7, i64 0, i64 1) to i64*), align 8
Chandler Carrutha0e56952014-05-15 09:56:28 +0000253 ret i64 %v
254
255; LE-LABEL: @test16.2(
256; LE: ret i64 -14
257
258; BE-LABEL: @test16.2(
259; BE: ret i64 -14
260}
261
262define i64 @test16.3() {
David Blaikief72d05b2015-03-13 18:20:45 +0000263 %v = load i64, i64* bitcast (i8** getelementptr inbounds ([4 x i8*], [4 x i8*]* @gv7, i64 0, i64 2) to i64*), align 8
Chandler Carrutha0e56952014-05-15 09:56:28 +0000264 ret i64 %v
265
266; LE-LABEL: @test16.3(
267; LE: ret i64 0
268
269; BE-LABEL: @test16.3(
270; BE: ret i64 0
271}
Nikita Popov79c994d2018-12-11 20:29:16 +0000272
273@g7 = constant {[0 x i32], [0 x i8], {}*} { [0 x i32] undef, [0 x i8] undef, {}* null }
274
275define i64* @test_leading_zero_size_elems() {
276 %v = load i64*, i64** bitcast ({[0 x i32], [0 x i8], {}*}* @g7 to i64**)
277 ret i64* %v
278
279; LE-LABEL: @test_leading_zero_size_elems(
280; LE: ret i64* null
281
282; BE-LABEL: @test_leading_zero_size_elems(
283; BE: ret i64* null
284}
285
286@g8 = constant {[4294967295 x [0 x i32]], i64} { [4294967295 x [0 x i32]] undef, i64 123 }
287
288define i64 @test_leading_zero_size_elems_big() {
289 %v = load i64, i64* bitcast ({[4294967295 x [0 x i32]], i64}* @g8 to i64*)
290 ret i64 %v
291
292; LE-LABEL: @test_leading_zero_size_elems_big(
293; LE: ret i64 123
294
295; BE-LABEL: @test_leading_zero_size_elems_big(
296; BE: ret i64 123
297}
298
299@g9 = constant [4294967295 x [0 x i32]] zeroinitializer
300
301define i64 @test_array_of_zero_size_array() {
302 %v = load i64, i64* bitcast ([4294967295 x [0 x i32]]* @g9 to i64*)
303 ret i64 %v
304
305; LE-LABEL: @test_array_of_zero_size_array(
306; LE: ret i64 0
307
308; BE-LABEL: @test_array_of_zero_size_array(
309; BE: ret i64 0
310}