[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / InstSimplify / ConstProp / loads.ll
blob3bc301743a183547fd199cdc077e0d98e86369c3
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -data-layout="e-p:64:64:64-p1:16:16:16-p2:64:64:64-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-ni:2" -passes=instsimplify -S | FileCheck %s --check-prefixes=CHECK,LE
3 ; RUN: opt < %s -data-layout="E-p:64:64:64-p1:16:16:16-p2:64:64:64-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-ni:2" -passes=instsimplify -S | FileCheck %s --check-prefixes=CHECK,BE
5 ; {{ 0xDEADBEEF, 0xBA }, 0xCAFEBABE}
6 @g1 = constant {{i32,i8},i32} {{i32,i8} { i32 -559038737, i8 186 }, i32 -889275714 }
7 @g2 = constant double 1.0
8 ; { 0x7B, 0x06B1BFF8 }
9 @g3 = constant {i64, i64} { i64 123, i64 112312312 }
11 ; Simple load
12 define i32 @test1() {
13 ; CHECK-LABEL: @test1(
14 ; CHECK-NEXT:    ret i32 -559038737
16   %r = load i32, ptr getelementptr ({{i32,i8},i32}, ptr @g1, i32 0, i32 0, i32 0)
17   ret i32 %r
20 ; PR3152
21 ; Load of first 16 bits of 32-bit value.
22 define i16 @test2() {
23 ; LE-LABEL: @test2(
24 ; LE-NEXT:    ret i16 -16657
26 ; BE-LABEL: @test2(
27 ; BE-NEXT:    ret i16 -8531
29   %r = load i16, ptr getelementptr ({{i32,i8},i32}, ptr @g1, i32 0, i32 0, i32 0)
30   ret i16 %r
33 define i16 @test2_addrspacecast() {
34 ; LE-LABEL: @test2_addrspacecast(
35 ; LE-NEXT:    ret i16 -16657
37 ; BE-LABEL: @test2_addrspacecast(
38 ; BE-NEXT:    ret i16 -8531
40   %r = load i16, ptr addrspace(1) addrspacecast(ptr getelementptr ({{i32,i8},i32}, ptr @g1, i32 0, i32 0, i32 0) to ptr addrspace(1))
41   ret i16 %r
44 ; Load of second 16 bits of 32-bit value.
45 define i16 @test3() {
46 ; LE-LABEL: @test3(
47 ; LE-NEXT:    ret i16 -8531
49 ; BE-LABEL: @test3(
50 ; BE-NEXT:    ret i16 -16657
52   %r = load i16, ptr getelementptr(i16, ptr getelementptr ({{i32,i8},i32}, ptr @g1, i32 0, i32 0, i32 0), i32 1)
53   ret i16 %r
56 ; Load of 8 bit field + tail padding.
57 define i16 @test4() {
58 ; LE-LABEL: @test4(
59 ; LE-NEXT:    ret i16 186
61 ; BE-LABEL: @test4(
62 ; BE-NEXT:    ret i16 -17920
64   %r = load i16, ptr getelementptr(i16, ptr getelementptr ({{i32,i8},i32}, ptr @g1, i32 0, i32 0, i32 0), i32 2)
65   ret i16 %r
68 ; Load of double bits.
69 define i64 @test6() {
70 ; CHECK-LABEL: @test6(
71 ; CHECK-NEXT:    ret i64 4607182418800017408
73   %r = load i64, ptr @g2
74   ret i64 %r
77 ; Load of double bits.
78 define i16 @test7() {
79 ; LE-LABEL: @test7(
80 ; LE-NEXT:    ret i16 0
82 ; BE-LABEL: @test7(
83 ; BE-NEXT:    ret i16 16368
85   %r = load i16, ptr @g2
86   ret i16 %r
89 ; Double load.
90 define double @test8() {
91 ; LE-LABEL: @test8(
92 ; LE-NEXT:    ret double 0xBADEADBEEF
94 ; BE-LABEL: @test8(
95 ; BE-NEXT:    ret double 0xDEADBEEFBA000000
97   %r = load double, ptr @g1
98   ret double %r
102 ; i128 load.
103 define i128 @test_i128() {
104 ; LE-LABEL: @test_i128(
105 ; LE-NEXT:    ret i128 2071796475790618158476296315
107 ; BE-LABEL: @test_i128(
108 ; BE-NEXT:    ret i128 2268949521066387161080
110   %r = load i128, ptr @g3
111   ret i128 %r
114 define fp128 @test_fp128() {
115 ; LE-LABEL: @test_fp128(
116 ; LE-NEXT:    ret fp128 0xL000000000000007B0000000006B1BFF8
118 ; BE-LABEL: @test_fp128(
119 ; BE-NEXT:    ret fp128 0xL0000000006B1BFF8000000000000007B
121   %r = load fp128, ptr @g3
122   ret fp128 %r
125 define ppc_fp128 @test_ppc_fp128() {
126 ; LE-LABEL: @test_ppc_fp128(
127 ; LE-NEXT:    ret ppc_fp128 bitcast (i128 2071796475790618158476296315 to ppc_fp128)
129 ; BE-LABEL: @test_ppc_fp128(
130 ; BE-NEXT:    ret ppc_fp128 bitcast (i128 2268949521066387161080 to ppc_fp128)
132   %r = load ppc_fp128, ptr @g3
133   ret ppc_fp128 %r
136 define x86_fp80 @test_x86_fp80() {
137 ; LE-LABEL: @test_x86_fp80(
138 ; LE-NEXT:    ret x86_fp80 0xKFFFF000000000000007B
140 ; BE-LABEL: @test_x86_fp80(
141 ; BE-NEXT:    ret x86_fp80 0xK000000000000007B0000
143   %r = load x86_fp80, ptr @g3
144   ret x86_fp80 %r
147 define bfloat @test_bfloat() {
148 ; LE-LABEL: @test_bfloat(
149 ; LE-NEXT:    ret bfloat 0xR007B
151 ; BE-LABEL: @test_bfloat(
152 ; BE-NEXT:    ret bfloat 0xR0000
154   %r = load bfloat, ptr @g3
155   ret bfloat %r
158 ; vector load.
159 define <2 x i64> @test10() {
160 ; CHECK-LABEL: @test10(
161 ; CHECK-NEXT:    ret <2 x i64> <i64 123, i64 112312312>
163   %r = load <2 x i64>, ptr @g3
164   ret <2 x i64> %r
168 ; PR5287
169 ; { 0xA1, 0x08 }
170 @g4 = internal constant { i8, i8 } { i8 -95, i8 8 }
172 define i16 @test11() nounwind {
173 ; LE-LABEL: @test11(
174 ; LE-NEXT:  entry:
175 ; LE-NEXT:    ret i16 2209
177 ; BE-LABEL: @test11(
178 ; BE-NEXT:  entry:
179 ; BE-NEXT:    ret i16 -24312
181 entry:
182   %a = load i16, ptr @g4
183   ret i16 %a
187 ; PR5551
188 @test12g = private constant [6 x i8] c"a\00b\00\00\00"
190 define i16 @test12() {
191 ; LE-LABEL: @test12(
192 ; LE-NEXT:    ret i16 98
194 ; BE-LABEL: @test12(
195 ; BE-NEXT:    ret i16 25088
197   %a = load i16, ptr getelementptr inbounds ([3 x i16], ptr @test12g, i32 0, i64 1)
198   ret i16 %a
202 ; PR5978
203 @g5 = constant i8 4
204 define i1 @test13() {
205 ; CHECK-LABEL: @test13(
206 ; CHECK-NEXT:    ret i1 false
208   %A = load i1, ptr @g5
209   ret i1 %A
212 @g6 = constant [2 x ptr] [ptr inttoptr (i64 1 to ptr), ptr inttoptr (i64 2 to ptr)]
213 define i64 @test14() nounwind {
214 ; CHECK-LABEL: @test14(
215 ; CHECK-NEXT:  entry:
216 ; CHECK-NEXT:    ret i64 1
218 entry:
219   %tmp = load i64, ptr @g6
220   ret i64 %tmp
223 ; Check with address space pointers
224 @g6_as1 = constant [2 x ptr addrspace(1)] [ptr addrspace(1) inttoptr (i16 1 to ptr addrspace(1)), ptr addrspace(1) inttoptr (i16 2 to ptr addrspace(1))]
225 define i16 @test14_as1() nounwind {
226 ; CHECK-LABEL: @test14_as1(
227 ; CHECK-NEXT:  entry:
228 ; CHECK-NEXT:    ret i16 1
230 entry:
231   %tmp = load i16, ptr @g6_as1
232   ret i16 %tmp
235 define i64 @test15() nounwind {
236 ; CHECK-LABEL: @test15(
237 ; CHECK-NEXT:  entry:
238 ; CHECK-NEXT:    ret i64 2
240 entry:
241   %tmp = load i64, ptr getelementptr inbounds ([2 x ptr], ptr @g6, i32 0, i64 1)
242   ret i64 %tmp
245 @gv7 = constant [4 x ptr] [ptr null, ptr inttoptr (i64 -14 to ptr), ptr null, ptr null]
246 define i64 @test16.1() {
247 ; CHECK-LABEL: @test16.1(
248 ; CHECK-NEXT:    ret i64 0
250   %v = load i64, ptr @gv7, align 8
251   ret i64 %v
254 define i64 @test16.2() {
255 ; CHECK-LABEL: @test16.2(
256 ; CHECK-NEXT:    ret i64 -14
258   %v = load i64, ptr getelementptr inbounds ([4 x ptr], ptr @gv7, i64 0, i64 1), align 8
259   ret i64 %v
262 define i64 @test16.3() {
263 ; CHECK-LABEL: @test16.3(
264 ; CHECK-NEXT:    ret i64 0
266   %v = load i64, ptr getelementptr inbounds ([4 x ptr], ptr @gv7, i64 0, i64 2), align 8
267   ret i64 %v
270 @g7 = constant {[0 x i32], [0 x i8], ptr} { [0 x i32] poison, [0 x i8] poison, ptr null }
272 define ptr @test_leading_zero_size_elems() {
273 ; CHECK-LABEL: @test_leading_zero_size_elems(
274 ; CHECK-NEXT:    ret ptr null
276   %v = load ptr, ptr @g7
277   ret ptr %v
280 @g8 = constant {[4294967295 x [0 x i32]], i64} { [4294967295 x [0 x i32]] poison, i64 123 }
282 define i64 @test_leading_zero_size_elems_big() {
283 ; CHECK-LABEL: @test_leading_zero_size_elems_big(
284 ; CHECK-NEXT:    ret i64 123
286   %v = load i64, ptr @g8
287   ret i64 %v
290 @g9 = constant [4294967295 x [0 x i32]] zeroinitializer
292 define i64 @test_array_of_zero_size_array() {
293 ; CHECK-LABEL: @test_array_of_zero_size_array(
294 ; CHECK-NEXT:    ret i64 poison
296   %v = load i64, ptr @g9
297   ret i64 %v
300 @g_undef = constant { i128 } undef
302 define ptr @test_undef_aggregate() {
303 ; CHECK-LABEL: @test_undef_aggregate(
304 ; CHECK-NEXT:    ret ptr undef
306   %v = load ptr, ptr @g_undef
307   ret ptr %v
310 @g_poison = constant { i128 } poison
312 define ptr @test_poison_aggregate() {
313 ; CHECK-LABEL: @test_poison_aggregate(
314 ; CHECK-NEXT:    ret ptr poison
316   %v = load ptr, ptr @g_poison
317   ret ptr %v
320 @g11 = constant <{ [8 x i8], [8 x i8] }> <{ [8 x i8] poison, [8 x i8] zeroinitializer }>, align 4
322 define ptr @test_trailing_zero_gep_index() {
323 ; CHECK-LABEL: @test_trailing_zero_gep_index(
324 ; CHECK-NEXT:    ret ptr null
326   %v = load ptr, ptr getelementptr inbounds (<{ [8 x i8], [8 x i8] }>, ptr @g11, i32 0, i32 1, i32 0), align 4
327   ret ptr %v
330 define { i64, i64 } @test_load_struct() {
331 ; CHECK-LABEL: @test_load_struct(
332 ; CHECK-NEXT:    ret { i64, i64 } { i64 123, i64 112312312 }
334   %v = load { i64, i64 }, ptr @g3
335   ret { i64, i64 } %v
338 @m64 = internal constant [2 x i64] zeroinitializer
339 @idx = external global i32
341 ; This should not try to create an x86_mmx null value.
342 define x86_mmx @load_mmx() {
343 ; CHECK-LABEL: @load_mmx(
344 ; CHECK-NEXT:    [[TEMP:%.*]] = load x86_mmx, ptr getelementptr ([2 x i64], ptr @m64, i64 0, i64 ptrtoint (ptr @idx to i64)), align 8
345 ; CHECK-NEXT:    ret x86_mmx [[TEMP]]
347   %temp = load x86_mmx, ptr getelementptr ([2 x i64], ptr @m64, i64 0, i64 ptrtoint (ptr @idx to i64))
348   ret x86_mmx %temp
351 @g_offset = external global i64
353 @g_neg_one_vec = constant <4 x i8> <i8 -1, i8 -1, i8 -1, i8 -1>
355 define i8 @load_neg_one_at_unknown_offset() {
356 ; CHECK-LABEL: @load_neg_one_at_unknown_offset(
357 ; CHECK-NEXT:    ret i8 -1
359   %v = load i8, ptr getelementptr (<4 x i8>, ptr @g_neg_one_vec, i64 0, i64 ptrtoint (ptr @g_offset to i64))
360   ret i8 %v
363 @g_with_padding = constant { i32, [4 x i8] } { i32 0, [4 x i8] poison }
365 define i32 @load_padding() {
366 ; CHECK-LABEL: @load_padding(
367 ; CHECK-NEXT:    ret i32 poison
369   %v = load i32, ptr getelementptr (i32, ptr @g_with_padding, i64 1)
370   ret i32 %v
373 @g_all_poison = constant { i32, [4 x i8] } poison
375 ; Same as the previous case, but with an all-poison initializer.
376 define i32 @load_all_poison() {
377 ; CHECK-LABEL: @load_all_poison(
378 ; CHECK-NEXT:    ret i32 poison
380   %v = load i32, ptr getelementptr (i32, ptr @g_all_poison, i64 1)
381   ret i32 %v
384 @g_i8_data = constant [16 x i8] c"\01\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00"
386 define ptr @load_ptr_from_i8_data() {
387 ; LE-LABEL: @load_ptr_from_i8_data(
388 ; LE-NEXT:    ret ptr inttoptr (i64 1 to ptr)
390 ; BE-LABEL: @load_ptr_from_i8_data(
391 ; BE-NEXT:    ret ptr inttoptr (i64 72057594037927936 to ptr)
393   %v = load ptr, ptr @g_i8_data
394   ret ptr %v
397 define ptr addrspace(2) @load_non_integral_ptr_from_i8_data() {
398 ; CHECK-LABEL: @load_non_integral_ptr_from_i8_data(
399 ; CHECK-NEXT:    [[V:%.*]] = load ptr addrspace(2), ptr @g_i8_data, align 8
400 ; CHECK-NEXT:    ret ptr addrspace(2) [[V]]
402   %v = load ptr addrspace(2), ptr @g_i8_data
403   ret ptr addrspace(2) %v
406 @g_i1 = constant i1 true
408 define i8 @load_i8_from_i1() {
409 ; CHECK-LABEL: @load_i8_from_i1(
410 ; CHECK-NEXT:    ret i8 -1
412   %v = load i8, ptr @g_i1
413   ret i8 %v
416 @global128 = internal constant i128 1125899906842625
417 define i128 @load-128bit(){
418 ; CHECK-LABEL: @load-128bit(
419 ; CHECK-NEXT:    ret i128 1125899906842625
421   %1 = load i128, ptr @global128, align 4
422   ret i128 %1