Follow up to d0858bffa11, add missing REQUIRES x86
[llvm-project.git] / llvm / test / Transforms / InstSimplify / ConstProp / vscale.ll
blob585e736650b78aa8963d70d0da9f0094dc1e53e0
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -passes=instsimplify,verify -S | FileCheck %s
4 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
5 ;; Unary Operations
6 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
8 define <vscale x 2 x double> @fneg(<vscale x 2 x double> %val) {
9 ; CHECK-LABEL: @fneg(
10 ; CHECK-NEXT:    ret <vscale x 2 x double> undef
12   %r = fneg <vscale x 2 x double> undef
13   ret <vscale x 2 x double> %r
16 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
17 ;; Binary Operations
18 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
20 define <vscale x 4 x i32> @add() {
21 ; CHECK-LABEL: @add(
22 ; CHECK-NEXT:    ret <vscale x 4 x i32> undef
24   %r = add <vscale x 4 x i32> undef, undef
25   ret <vscale x 4 x i32> %r
28 define <vscale x 4 x float> @fadd() {
29 ; CHECK-LABEL: @fadd(
30 ; CHECK-NEXT:    ret <vscale x 4 x float> undef
32   %r = fadd <vscale x 4 x float> undef, undef
33   ret <vscale x 4 x float> %r
36 define <vscale x 4 x i32> @sub() {
37 ; CHECK-LABEL: @sub(
38 ; CHECK-NEXT:    ret <vscale x 4 x i32> undef
40   %r = sub <vscale x 4 x i32> undef, undef
41   ret <vscale x 4 x i32> %r
44 define <vscale x 4 x i32> @sub_splat() {
45 ; CHECK-LABEL: @sub_splat(
46 ; CHECK-NEXT:    ret <vscale x 4 x i32> shufflevector (<vscale x 4 x i32> insertelement (<vscale x 4 x i32> poison, i32 -16, i64 0), <vscale x 4 x i32> poison, <vscale x 4 x i32> zeroinitializer)
48   %r = sub <vscale x 4 x i32> zeroinitializer, shufflevector (<vscale x 4 x i32> insertelement (<vscale x 4 x i32> undef, i32 16, i32 0), <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer)
49   ret <vscale x 4 x i32> %r
52 define <vscale x 4 x float> @fsub() {
53 ; CHECK-LABEL: @fsub(
54 ; CHECK-NEXT:    ret <vscale x 4 x float> undef
56   %r = fsub <vscale x 4 x float> undef, undef
57   ret <vscale x 4 x float> %r
60 define <vscale x 4 x i32> @mul() {
61 ; CHECK-LABEL: @mul(
62 ; CHECK-NEXT:    ret <vscale x 4 x i32> undef
64   %r = mul <vscale x 4 x i32> undef, undef
65   ret <vscale x 4 x i32> %r
68 define <vscale x 4 x float> @fmul() {
69 ; CHECK-LABEL: @fmul(
70 ; CHECK-NEXT:    ret <vscale x 4 x float> undef
72   %r = fmul <vscale x 4 x float> undef, undef
73   ret <vscale x 4 x float> %r
76 define <vscale x 4 x i32> @udiv() {
77 ; CHECK-LABEL: @udiv(
78 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
80   %r = udiv <vscale x 4 x i32> undef, undef
81   ret <vscale x 4 x i32> %r
84 define <vscale x 4 x i32> @udiv_splat_zero() {
85 ; CHECK-LABEL: @udiv_splat_zero(
86 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
88   %r = udiv <vscale x 4 x i32> zeroinitializer, zeroinitializer
89   ret <vscale x 4 x i32> %r
92 define <vscale x 4 x i32> @sdiv() {
93 ; CHECK-LABEL: @sdiv(
94 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
96   %r = sdiv <vscale x 4 x i32> undef, undef
97   ret <vscale x 4 x i32> %r
100 define <vscale x 4 x float> @fdiv() {
101 ; CHECK-LABEL: @fdiv(
102 ; CHECK-NEXT:    ret <vscale x 4 x float> undef
104   %r = fdiv <vscale x 4 x float> undef, undef
105   ret <vscale x 4 x float> %r
108 define <vscale x 4 x i32> @urem() {
109 ; CHECK-LABEL: @urem(
110 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
112   %r = urem <vscale x 4 x i32> undef, undef
113   ret <vscale x 4 x i32> %r
116 define <vscale x 4 x i32> @srem() {
117 ; CHECK-LABEL: @srem(
118 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
120   %r = srem <vscale x 4 x i32> undef, undef
121   ret <vscale x 4 x i32> %r
124 define <vscale x 4 x float> @frem() {
125 ; CHECK-LABEL: @frem(
126 ; CHECK-NEXT:    ret <vscale x 4 x float> undef
128   %r = frem <vscale x 4 x float> undef, undef
129   ret <vscale x 4 x float> %r
132 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
133 ;; Bitwise Binary Operations
134 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
136 define <vscale x 4 x i32> @shl() {
137 ; CHECK-LABEL: @shl(
138 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
140   %r = shl <vscale x 4 x i32> undef, undef
141   ret <vscale x 4 x i32> %r
144 define <vscale x 4 x i32> @lshr() {
145 ; CHECK-LABEL: @lshr(
146 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
148   %r = lshr <vscale x 4 x i32> undef, undef
149   ret <vscale x 4 x i32> %r
152 define <vscale x 4 x i32> @ashr() {
153 ; CHECK-LABEL: @ashr(
154 ; CHECK-NEXT:    ret <vscale x 4 x i32> poison
156   %r = ashr <vscale x 4 x i32> undef, undef
157   ret <vscale x 4 x i32> %r
160 define <vscale x 4 x i32> @and() {
161 ; CHECK-LABEL: @and(
162 ; CHECK-NEXT:    ret <vscale x 4 x i32> undef
164   %r = and <vscale x 4 x i32> undef, undef
165   ret <vscale x 4 x i32> %r
168 define <vscale x 4 x i32> @or() {
169 ; CHECK-LABEL: @or(
170 ; CHECK-NEXT:    ret <vscale x 4 x i32> undef
172   %r = or <vscale x 4 x i32> undef, undef
173   ret <vscale x 4 x i32> %r
176 define <vscale x 4 x i32> @xor() {
177 ; CHECK-LABEL: @xor(
178 ; CHECK-NEXT:    ret <vscale x 4 x i32> zeroinitializer
180   %r = xor <vscale x 4 x i32> undef, undef
181   ret <vscale x 4 x i32> %r
184 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
185 ;; Vector Operations
186 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
188 define <vscale x 4 x i32> @insertelement() {
189 ; CHECK-LABEL: @insertelement(
190 ; CHECK-NEXT:    ret <vscale x 4 x i32> insertelement (<vscale x 4 x i32> undef, i32 1, i32 0)
192   %i = insertelement <vscale x 4 x i32> undef, i32 1, i32 0
193   ret <vscale x 4 x i32> %i
196 define <vscale x 4 x i32> @shufflevector() {
197 ; CHECK-LABEL: @shufflevector(
198 ; CHECK-NEXT:    ret <vscale x 4 x i32> shufflevector (<vscale x 4 x i32> insertelement (<vscale x 4 x i32> undef, i32 1, i32 0), <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer)
200   %i = insertelement <vscale x 4 x i32> undef, i32 1, i32 0
201   %i2 = shufflevector <vscale x 4 x i32> %i, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
202   ret <vscale x 4 x i32> %i2
205 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
206 ;; Conversion Operations
207 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
209 define <vscale x 4 x float> @bitcast() {
210 ; CHECK-LABEL: @bitcast(
211 ; CHECK-NEXT:    ret <vscale x 4 x float> bitcast (<vscale x 4 x i32> shufflevector (<vscale x 4 x i32> insertelement (<vscale x 4 x i32> undef, i32 1, i32 0), <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer) to <vscale x 4 x float>)
213   %i1 = insertelement <vscale x 4 x i32> undef, i32 1, i32 0
214   %i2 = shufflevector <vscale x 4 x i32> %i1, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
215   %i3 = bitcast <vscale x 4 x i32> %i2 to <vscale x 4 x float>
216   ret <vscale x 4 x float> %i3
219 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
220 ;; Other Operations
221 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
223 define <vscale x 4 x i32> @select() {
224 ; CHECK-LABEL: @select(
225 ; CHECK-NEXT:    ret <vscale x 4 x i32> undef
227   %r = select <vscale x 4 x i1> undef, <vscale x 4 x i32> zeroinitializer, <vscale x 4 x i32> undef
228   ret <vscale x 4 x i32> %r
231 declare <vscale x 16 x i8> @llvm.something(<vscale x 16 x i8>, <vscale x 16 x i8>)
233 define <vscale x 16 x i8> @call() {
234 ; CHECK-LABEL: @call(
235 ; CHECK-NEXT:    [[R:%.*]] = call <vscale x 16 x i8> @llvm.something(<vscale x 16 x i8> undef, <vscale x 16 x i8> undef)
236 ; CHECK-NEXT:    ret <vscale x 16 x i8> [[R]]
238   %r =  call <vscale x 16 x i8> @llvm.something(<vscale x 16 x i8> undef, <vscale x 16 x i8> undef)
239   ret <vscale x 16 x i8> %r
242 define <vscale x 4 x i1> @icmp_undef() {
243 ; CHECK-LABEL: @icmp_undef(
244 ; CHECK-NEXT:    ret <vscale x 4 x i1> undef
246   %r = icmp eq <vscale x 4 x i32> undef, undef
247   ret <vscale x 4 x i1> %r
250 define <vscale x 4 x i1> @icmp_zero() {
251 ; CHECK-LABEL: @icmp_zero(
252 ; CHECK-NEXT:    ret <vscale x 4 x i1> shufflevector (<vscale x 4 x i1> insertelement (<vscale x 4 x i1> poison, i1 true, i64 0), <vscale x 4 x i1> poison, <vscale x 4 x i32> zeroinitializer)
254   %r = icmp eq <vscale x 4 x i32> zeroinitializer, zeroinitializer
255   ret <vscale x 4 x i1> %r
258 define <vscale x 4 x i1> @fcmp_true() {
259 ; CHECK-LABEL: @fcmp_true(
260 ; CHECK-NEXT:    ret <vscale x 4 x i1> shufflevector (<vscale x 4 x i1> insertelement (<vscale x 4 x i1> poison, i1 true, i64 0), <vscale x 4 x i1> poison, <vscale x 4 x i32> zeroinitializer)
262   %r = fcmp true <vscale x 4 x float> undef, undef
263   ret <vscale x 4 x i1> %r
266 define <vscale x 4 x i1> @fcmp_false() {
267 ; CHECK-LABEL: @fcmp_false(
268 ; CHECK-NEXT:    ret <vscale x 4 x i1> zeroinitializer
270   %r = fcmp false <vscale x 4 x float> undef, undef
271   ret <vscale x 4 x i1> %r
274 define <vscale x 4 x i1> @fcmp_undef() {
275 ; CHECK-LABEL: @fcmp_undef(
276 ; CHECK-NEXT:    ret <vscale x 4 x i1> undef
278   %r = icmp ne <vscale x 4 x i32> undef, undef
279   ret <vscale x 4 x i1> %r
282 define <vscale x 4 x i1> @fcmp_not_equality() {
283 ; CHECK-LABEL: @fcmp_not_equality(
284 ; CHECK-NEXT:    ret <vscale x 4 x i1> shufflevector (<vscale x 4 x i1> insertelement (<vscale x 4 x i1> poison, i1 true, i64 0), <vscale x 4 x i1> poison, <vscale x 4 x i32> zeroinitializer)
286   %r = icmp ule <vscale x 4 x i32> undef, zeroinitializer
287   ret <vscale x 4 x i1> %r