Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SystemZ / int-move-06.ll
blob46ad2c2ee82051a5dfd01334dde10ea2cbcd21af
1 ; Test 32-bit GPR stores.
3 ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
5 ; Test an i32 store.
6 define void @f1(ptr %dst, i32 %val) {
7 ; CHECK-LABEL: f1:
8 ; CHECK: st %r3, 0(%r2)
9 ; CHECK: br %r14
10   store i32 %val, ptr %dst
11   ret void
14 ; Test a truncating i64 store.
15 define void @f2(ptr %dst, i64 %val) {
16   %word = trunc i64 %val to i32
17   store i32 %word, ptr %dst
18   ret void
21 ; Check the high end of the aligned ST range.
22 define void @f3(ptr %dst, i32 %val) {
23 ; CHECK-LABEL: f3:
24 ; CHECK: st %r3, 4092(%r2)
25 ; CHECK: br %r14
26   %ptr = getelementptr i32, ptr %dst, i64 1023
27   store i32 %val, ptr %ptr
28   ret void
31 ; Check the next word up, which should use STY instead of ST.
32 define void @f4(ptr %dst, i32 %val) {
33 ; CHECK-LABEL: f4:
34 ; CHECK: sty %r3, 4096(%r2)
35 ; CHECK: br %r14
36   %ptr = getelementptr i32, ptr %dst, i64 1024
37   store i32 %val, ptr %ptr
38   ret void
41 ; Check the high end of the aligned STY range.
42 define void @f5(ptr %dst, i32 %val) {
43 ; CHECK-LABEL: f5:
44 ; CHECK: sty %r3, 524284(%r2)
45 ; CHECK: br %r14
46   %ptr = getelementptr i32, ptr %dst, i64 131071
47   store i32 %val, ptr %ptr
48   ret void
51 ; Check the next word up, which needs separate address logic.
52 ; Other sequences besides this one would be OK.
53 define void @f6(ptr %dst, i32 %val) {
54 ; CHECK-LABEL: f6:
55 ; CHECK: agfi %r2, 524288
56 ; CHECK: st %r3, 0(%r2)
57 ; CHECK: br %r14
58   %ptr = getelementptr i32, ptr %dst, i64 131072
59   store i32 %val, ptr %ptr
60   ret void
63 ; Check the high end of the negative aligned STY range.
64 define void @f7(ptr %dst, i32 %val) {
65 ; CHECK-LABEL: f7:
66 ; CHECK: sty %r3, -4(%r2)
67 ; CHECK: br %r14
68   %ptr = getelementptr i32, ptr %dst, i64 -1
69   store i32 %val, ptr %ptr
70   ret void
73 ; Check the low end of the STY range.
74 define void @f8(ptr %dst, i32 %val) {
75 ; CHECK-LABEL: f8:
76 ; CHECK: sty %r3, -524288(%r2)
77 ; CHECK: br %r14
78   %ptr = getelementptr i32, ptr %dst, i64 -131072
79   store i32 %val, ptr %ptr
80   ret void
83 ; Check the next word down, which needs separate address logic.
84 ; Other sequences besides this one would be OK.
85 define void @f9(ptr %dst, i32 %val) {
86 ; CHECK-LABEL: f9:
87 ; CHECK: agfi %r2, -524292
88 ; CHECK: st %r3, 0(%r2)
89 ; CHECK: br %r14
90   %ptr = getelementptr i32, ptr %dst, i64 -131073
91   store i32 %val, ptr %ptr
92   ret void
95 ; Check that ST allows an index.
96 define void @f10(i64 %dst, i64 %index, i32 %val) {
97 ; CHECK-LABEL: f10:
98 ; CHECK: st %r4, 4095(%r3,%r2)
99 ; CHECK: br %r14
100   %add1 = add i64 %dst, %index
101   %add2 = add i64 %add1, 4095
102   %ptr = inttoptr i64 %add2 to ptr
103   store i32 %val, ptr %ptr
104   ret void
107 ; Check that STY allows an index.
108 define void @f11(i64 %dst, i64 %index, i32 %val) {
109 ; CHECK-LABEL: f11:
110 ; CHECK: sty %r4, 4096(%r3,%r2)
111 ; CHECK: br %r14
112   %add1 = add i64 %dst, %index
113   %add2 = add i64 %add1, 4096
114   %ptr = inttoptr i64 %add2 to ptr
115   store i32 %val, ptr %ptr
116   ret void