1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
; Test 64-bit addition in which the second operand is constant.
;
; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
; Check additions of 1.
define i64 @f1(i64 %a) {
; CHECK: f1:
; CHECK: {{aghi %r2, 1|la %r[0-5], 1\(%r2\)}}
; CHECK: br %r14
%add = add i64 %a, 1
ret i64 %add
}
; Check the high end of the AGHI range.
define i64 @f2(i64 %a) {
; CHECK: f2:
; CHECK: aghi %r2, 32767
; CHECK: br %r14
%add = add i64 %a, 32767
ret i64 %add
}
; Check the next value up, which must use AGFI instead.
define i64 @f3(i64 %a) {
; CHECK: f3:
; CHECK: {{agfi %r2, 32768|lay %r[0-5], 32768\(%r2\)}}
; CHECK: br %r14
%add = add i64 %a, 32768
ret i64 %add
}
; Check the high end of the AGFI range.
define i64 @f4(i64 %a) {
; CHECK: f4:
; CHECK: agfi %r2, 2147483647
; CHECK: br %r14
%add = add i64 %a, 2147483647
ret i64 %add
}
; Check the next value up, which must use ALGFI instead.
define i64 @f5(i64 %a) {
; CHECK: f5:
; CHECK: algfi %r2, 2147483648
; CHECK: br %r14
%add = add i64 %a, 2147483648
ret i64 %add
}
; Check the high end of the ALGFI range.
define i64 @f6(i64 %a) {
; CHECK: f6:
; CHECK: algfi %r2, 4294967295
; CHECK: br %r14
%add = add i64 %a, 4294967295
ret i64 %add
}
; Check the next value up, which must be loaded into a register first.
define i64 @f7(i64 %a) {
; CHECK: f7:
; CHECK: llihl %r0, 1
; CHECK: agr
; CHECK: br %r14
%add = add i64 %a, 4294967296
ret i64 %add
}
; Check the high end of the negative AGHI range.
define i64 @f8(i64 %a) {
; CHECK: f8:
; CHECK: aghi %r2, -1
; CHECK: br %r14
%add = add i64 %a, -1
ret i64 %add
}
; Check the low end of the AGHI range.
define i64 @f9(i64 %a) {
; CHECK: f9:
; CHECK: aghi %r2, -32768
; CHECK: br %r14
%add = add i64 %a, -32768
ret i64 %add
}
; Check the next value down, which must use AGFI instead.
define i64 @f10(i64 %a) {
; CHECK: f10:
; CHECK: {{agfi %r2, -32769|lay %r[0-5]+, -32769\(%r2\)}}
; CHECK: br %r14
%add = add i64 %a, -32769
ret i64 %add
}
; Check the low end of the AGFI range.
define i64 @f11(i64 %a) {
; CHECK: f11:
; CHECK: agfi %r2, -2147483648
; CHECK: br %r14
%add = add i64 %a, -2147483648
ret i64 %add
}
; Check the next value down, which must use SLGFI instead.
define i64 @f12(i64 %a) {
; CHECK: f12:
; CHECK: slgfi %r2, 2147483649
; CHECK: br %r14
%add = add i64 %a, -2147483649
ret i64 %add
}
; Check the low end of the SLGFI range.
define i64 @f13(i64 %a) {
; CHECK: f13:
; CHECK: slgfi %r2, 4294967295
; CHECK: br %r14
%add = add i64 %a, -4294967295
ret i64 %add
}
; Check the next value down, which must use register addition instead.
define i64 @f14(i64 %a) {
; CHECK: f14:
; CHECK: llihf %r0, 4294967295
; CHECK: agr
; CHECK: br %r14
%add = add i64 %a, -4294967296
ret i64 %add
}
|