Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Transforms / InstCombine / loadstore-alignment.ll
blobff3401727b9c1aa3f124617707516fdfbde07ecd
1 ; RUN: opt < %s -instcombine -S | grep {, align 16} | count 14
3 @x = external global <2 x i64>, align 16
4 @xx = external global [13 x <2 x i64>], align 16
6 define <2 x i64> @static_hem() {
7         %t = getelementptr <2 x i64>* @x, i32 7
8         %tmp1 = load <2 x i64>* %t, align 1
9         ret <2 x i64> %tmp1
12 define <2 x i64> @hem(i32 %i) {
13         %t = getelementptr <2 x i64>* @x, i32 %i
14         %tmp1 = load <2 x i64>* %t, align 1
15         ret <2 x i64> %tmp1
18 define <2 x i64> @hem_2d(i32 %i, i32 %j) {
19         %t = getelementptr [13 x <2 x i64>]* @xx, i32 %i, i32 %j
20         %tmp1 = load <2 x i64>* %t, align 1
21         ret <2 x i64> %tmp1
24 define <2 x i64> @foo() {
25         %tmp1 = load <2 x i64>* @x, align 1
26         ret <2 x i64> %tmp1
29 define <2 x i64> @bar() {
30         %t = alloca <2 x i64>
31         call void @kip(<2 x i64>* %t);
32         %tmp1 = load <2 x i64>* %t, align 1
33         ret <2 x i64> %tmp1
36 define void @static_hem_store(<2 x i64> %y) {
37         %t = getelementptr <2 x i64>* @x, i32 7
38         store <2 x i64> %y, <2 x i64>* %t, align 1
39         ret void
42 define void @hem_store(i32 %i, <2 x i64> %y) {
43         %t = getelementptr <2 x i64>* @x, i32 %i
44         store <2 x i64> %y, <2 x i64>* %t, align 1
45         ret void
48 define void @hem_2d_store(i32 %i, i32 %j, <2 x i64> %y) {
49         %t = getelementptr [13 x <2 x i64>]* @xx, i32 %i, i32 %j
50         store <2 x i64> %y, <2 x i64>* %t, align 1
51         ret void
54 define void @foo_store(<2 x i64> %y) {
55         store <2 x i64> %y, <2 x i64>* @x, align 1
56         ret void
59 define void @bar_store(<2 x i64> %y) {
60         %t = alloca <2 x i64>
61         call void @kip(<2 x i64>* %t);
62         store <2 x i64> %y, <2 x i64>* %t, align 1
63         ret void
66 declare void @kip(<2 x i64>* %t)