1 ;test all the shifted and signextending adds and subs with and without consts
3 ; RUN: llc < %s -march=alpha -o %t.s
4 ; RUN: grep { addl} %t.s | count 2
5 ; RUN: grep { addq} %t.s | count 2
6 ; RUN: grep { subl} %t.s | count 2
7 ; RUN: grep { subq} %t.s | count 2
9 ; RUN: grep {s4addl} %t.s | count 2
10 ; RUN: grep {s8addl} %t.s | count 2
11 ; RUN: grep {s4addq} %t.s | count 2
12 ; RUN: grep {s8addq} %t.s | count 2
14 ; RUN: grep {s4subl} %t.s | count 2
15 ; RUN: grep {s8subl} %t.s | count 2
16 ; RUN: grep {s4subq} %t.s | count 2
17 ; RUN: grep {s8subq} %t.s | count 2
20 define signext i32 @al(i32 signext %x.s, i32 signext %y.s) {
22 %tmp.3.s = add i32 %y.s, %x.s ; <i32> [#uses=1]
26 define signext i32 @ali(i32 signext %x.s) {
28 %tmp.3.s = add i32 100, %x.s ; <i32> [#uses=1]
32 define signext i64 @aq(i64 signext %x.s, i64 signext %y.s) {
34 %tmp.3.s = add i64 %y.s, %x.s ; <i64> [#uses=1]
38 define i64 @aqi(i64 %x.s) {
40 %tmp.3.s = add i64 100, %x.s ; <i64> [#uses=1]
44 define signext i32 @sl(i32 signext %x.s, i32 signext %y.s) {
46 %tmp.3.s = sub i32 %y.s, %x.s ; <i32> [#uses=1]
50 define signext i32 @sli(i32 signext %x.s) {
52 %tmp.3.s = sub i32 %x.s, 100 ; <i32> [#uses=1]
56 define i64 @sq(i64 %x.s, i64 %y.s) {
58 %tmp.3.s = sub i64 %y.s, %x.s ; <i64> [#uses=1]
62 define i64 @sqi(i64 %x.s) {
64 %tmp.3.s = sub i64 %x.s, 100 ; <i64> [#uses=1]
68 define signext i32 @a4l(i32 signext %x.s, i32 signext %y.s) {
70 %tmp.1.s = shl i32 %y.s, 2 ; <i32> [#uses=1]
71 %tmp.3.s = add i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
75 define signext i32 @a8l(i32 signext %x.s, i32 signext %y.s) {
77 %tmp.1.s = shl i32 %y.s, 3 ; <i32> [#uses=1]
78 %tmp.3.s = add i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
82 define i64 @a4q(i64 %x.s, i64 %y.s) {
84 %tmp.1.s = shl i64 %y.s, 2 ; <i64> [#uses=1]
85 %tmp.3.s = add i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
89 define i64 @a8q(i64 %x.s, i64 %y.s) {
91 %tmp.1.s = shl i64 %y.s, 3 ; <i64> [#uses=1]
92 %tmp.3.s = add i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
96 define signext i32 @a4li(i32 signext %y.s) {
98 %tmp.1.s = shl i32 %y.s, 2 ; <i32> [#uses=1]
99 %tmp.3.s = add i32 100, %tmp.1.s ; <i32> [#uses=1]
103 define signext i32 @a8li(i32 signext %y.s) {
105 %tmp.1.s = shl i32 %y.s, 3 ; <i32> [#uses=1]
106 %tmp.3.s = add i32 100, %tmp.1.s ; <i32> [#uses=1]
110 define i64 @a4qi(i64 %y.s) {
112 %tmp.1.s = shl i64 %y.s, 2 ; <i64> [#uses=1]
113 %tmp.3.s = add i64 100, %tmp.1.s ; <i64> [#uses=1]
117 define i64 @a8qi(i64 %y.s) {
119 %tmp.1.s = shl i64 %y.s, 3 ; <i64> [#uses=1]
120 %tmp.3.s = add i64 100, %tmp.1.s ; <i64> [#uses=1]
124 define signext i32 @s4l(i32 signext %x.s, i32 signext %y.s) {
126 %tmp.1.s = shl i32 %y.s, 2 ; <i32> [#uses=1]
127 %tmp.3.s = sub i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
131 define signext i32 @s8l(i32 signext %x.s, i32 signext %y.s) {
133 %tmp.1.s = shl i32 %y.s, 3 ; <i32> [#uses=1]
134 %tmp.3.s = sub i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
138 define i64 @s4q(i64 %x.s, i64 %y.s) {
140 %tmp.1.s = shl i64 %y.s, 2 ; <i64> [#uses=1]
141 %tmp.3.s = sub i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
145 define i64 @s8q(i64 %x.s, i64 %y.s) {
147 %tmp.1.s = shl i64 %y.s, 3 ; <i64> [#uses=1]
148 %tmp.3.s = sub i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
152 define signext i32 @s4li(i32 signext %y.s) {
154 %tmp.1.s = shl i32 %y.s, 2 ; <i32> [#uses=1]
155 %tmp.3.s = sub i32 %tmp.1.s, 100 ; <i32> [#uses=1]
159 define signext i32 @s8li(i32 signext %y.s) {
161 %tmp.1.s = shl i32 %y.s, 3 ; <i32> [#uses=1]
162 %tmp.3.s = sub i32 %tmp.1.s, 100 ; <i32> [#uses=1]
166 define i64 @s4qi(i64 %y.s) {
168 %tmp.1.s = shl i64 %y.s, 2 ; <i64> [#uses=1]
169 %tmp.3.s = sub i64 %tmp.1.s, 100 ; <i64> [#uses=1]
173 define i64 @s8qi(i64 %y.s) {
175 %tmp.1.s = shl i64 %y.s, 3 ; <i64> [#uses=1]
176 %tmp.3.s = sub i64 %tmp.1.s, 100 ; <i64> [#uses=1]