1 ; Test vector insertion of constants. 2 ; 3 ; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 | FileCheck %s 4 5 ; Test v16i8 insertion into the first element. 6 define <16 x i8> @f1(<16 x i8> %val) { 7 ; CHECK-LABEL: f1: 8 ; CHECK: vleib %v24, 0, 0 9 ; CHECK: br %r14 10 %ret = insertelement <16 x i8> %val, i8 0, i32 0 11 ret <16 x i8> %ret 12 } 13 14 ; Test v16i8 insertion into the last element. 15 define <16 x i8> @f2(<16 x i8> %val) { 16 ; CHECK-LABEL: f2: 17 ; CHECK: vleib %v24, 100, 15 18 ; CHECK: br %r14 19 %ret = insertelement <16 x i8> %val, i8 100, i32 15 20 ret <16 x i8> %ret 21 } 22 23 ; Test v16i8 insertion with the maximum signed value. 24 define <16 x i8> @f3(<16 x i8> %val) { 25 ; CHECK-LABEL: f3: 26 ; CHECK: vleib %v24, 127, 10 27 ; CHECK: br %r14 28 %ret = insertelement <16 x i8> %val, i8 127, i32 10 29 ret <16 x i8> %ret 30 } 31 32 ; Test v16i8 insertion with the minimum signed value. 33 define <16 x i8> @f4(<16 x i8> %val) { 34 ; CHECK-LABEL: f4: 35 ; CHECK: vleib %v24, -128, 11 36 ; CHECK: br %r14 37 %ret = insertelement <16 x i8> %val, i8 128, i32 11 38 ret <16 x i8> %ret 39 } 40 41 ; Test v16i8 insertion with the maximum unsigned value. 42 define <16 x i8> @f5(<16 x i8> %val) { 43 ; CHECK-LABEL: f5: 44 ; CHECK: vleib %v24, -1, 12 45 ; CHECK: br %r14 46 %ret = insertelement <16 x i8> %val, i8 255, i32 12 47 ret <16 x i8> %ret 48 } 49 50 ; Test v16i8 insertion into a variable element. 51 define <16 x i8> @f6(<16 x i8> %val, i32 %index) { 52 ; CHECK-LABEL: f6: 53 ; CHECK-NOT: vleib 54 ; CHECK: br %r14 55 %ret = insertelement <16 x i8> %val, i8 0, i32 %index 56 ret <16 x i8> %ret 57 } 58 59 ; Test v8i16 insertion into the first element. 60 define <8 x i16> @f7(<8 x i16> %val) { 61 ; CHECK-LABEL: f7: 62 ; CHECK: vleih %v24, 0, 0 63 ; CHECK: br %r14 64 %ret = insertelement <8 x i16> %val, i16 0, i32 0 65 ret <8 x i16> %ret 66 } 67 68 ; Test v8i16 insertion into the last element. 69 define <8 x i16> @f8(<8 x i16> %val) { 70 ; CHECK-LABEL: f8: 71 ; CHECK: vleih %v24, 0, 7 72 ; CHECK: br %r14 73 %ret = insertelement <8 x i16> %val, i16 0, i32 7 74 ret <8 x i16> %ret 75 } 76 77 ; Test v8i16 insertion with the maximum signed value. 78 define <8 x i16> @f9(<8 x i16> %val) { 79 ; CHECK-LABEL: f9: 80 ; CHECK: vleih %v24, 32767, 4 81 ; CHECK: br %r14 82 %ret = insertelement <8 x i16> %val, i16 32767, i32 4 83 ret <8 x i16> %ret 84 } 85 86 ; Test v8i16 insertion with the minimum signed value. 87 define <8 x i16> @f10(<8 x i16> %val) { 88 ; CHECK-LABEL: f10: 89 ; CHECK: vleih %v24, -32768, 5 90 ; CHECK: br %r14 91 %ret = insertelement <8 x i16> %val, i16 32768, i32 5 92 ret <8 x i16> %ret 93 } 94 95 ; Test v8i16 insertion with the maximum unsigned value. 96 define <8 x i16> @f11(<8 x i16> %val) { 97 ; CHECK-LABEL: f11: 98 ; CHECK: vleih %v24, -1, 6 99 ; CHECK: br %r14 100 %ret = insertelement <8 x i16> %val, i16 65535, i32 6 101 ret <8 x i16> %ret 102 } 103 104 ; Test v8i16 insertion into a variable element. 105 define <8 x i16> @f12(<8 x i16> %val, i32 %index) { 106 ; CHECK-LABEL: f12: 107 ; CHECK-NOT: vleih 108 ; CHECK: br %r14 109 %ret = insertelement <8 x i16> %val, i16 0, i32 %index 110 ret <8 x i16> %ret 111 } 112 113 ; Test v4i32 insertion into the first element. 114 define <4 x i32> @f13(<4 x i32> %val) { 115 ; CHECK-LABEL: f13: 116 ; CHECK: vleif %v24, 0, 0 117 ; CHECK: br %r14 118 %ret = insertelement <4 x i32> %val, i32 0, i32 0 119 ret <4 x i32> %ret 120 } 121 122 ; Test v4i32 insertion into the last element. 123 define <4 x i32> @f14(<4 x i32> %val) { 124 ; CHECK-LABEL: f14: 125 ; CHECK: vleif %v24, 0, 3 126 ; CHECK: br %r14 127 %ret = insertelement <4 x i32> %val, i32 0, i32 3 128 ret <4 x i32> %ret 129 } 130 131 ; Test v4i32 insertion with the maximum value allowed by VLEIF. 132 define <4 x i32> @f15(<4 x i32> %val) { 133 ; CHECK-LABEL: f15: 134 ; CHECK: vleif %v24, 32767, 1 135 ; CHECK: br %r14 136 %ret = insertelement <4 x i32> %val, i32 32767, i32 1 137 ret <4 x i32> %ret 138 } 139 140 ; Test v4i32 insertion with the next value up. 141 define <4 x i32> @f16(<4 x i32> %val) { 142 ; CHECK-LABEL: f16: 143 ; CHECK-NOT: vleif 144 ; CHECK: br %r14 145 %ret = insertelement <4 x i32> %val, i32 32768, i32 1 146 ret <4 x i32> %ret 147 } 148 149 ; Test v4i32 insertion with the minimum value allowed by VLEIF. 150 define <4 x i32> @f17(<4 x i32> %val) { 151 ; CHECK-LABEL: f17: 152 ; CHECK: vleif %v24, -32768, 2 153 ; CHECK: br %r14 154 %ret = insertelement <4 x i32> %val, i32 -32768, i32 2 155 ret <4 x i32> %ret 156 } 157 158 ; Test v4i32 insertion with the next value down. 159 define <4 x i32> @f18(<4 x i32> %val) { 160 ; CHECK-LABEL: f18: 161 ; CHECK-NOT: vleif 162 ; CHECK: br %r14 163 %ret = insertelement <4 x i32> %val, i32 -32769, i32 2 164 ret <4 x i32> %ret 165 } 166 167 ; Test v4i32 insertion into a variable element. 168 define <4 x i32> @f19(<4 x i32> %val, i32 %index) { 169 ; CHECK-LABEL: f19: 170 ; CHECK-NOT: vleif 171 ; CHECK: br %r14 172 %ret = insertelement <4 x i32> %val, i32 0, i32 %index 173 ret <4 x i32> %ret 174 } 175 176 ; Test v2i64 insertion into the first element. 177 define <2 x i64> @f20(<2 x i64> %val) { 178 ; CHECK-LABEL: f20: 179 ; CHECK: vleig %v24, 0, 0 180 ; CHECK: br %r14 181 %ret = insertelement <2 x i64> %val, i64 0, i32 0 182 ret <2 x i64> %ret 183 } 184 185 ; Test v2i64 insertion into the last element. 186 define <2 x i64> @f21(<2 x i64> %val) { 187 ; CHECK-LABEL: f21: 188 ; CHECK: vleig %v24, 0, 1 189 ; CHECK: br %r14 190 %ret = insertelement <2 x i64> %val, i64 0, i32 1 191 ret <2 x i64> %ret 192 } 193 194 ; Test v2i64 insertion with the maximum value allowed by VLEIG. 195 define <2 x i64> @f22(<2 x i64> %val) { 196 ; CHECK-LABEL: f22: 197 ; CHECK: vleig %v24, 32767, 1 198 ; CHECK: br %r14 199 %ret = insertelement <2 x i64> %val, i64 32767, i32 1 200 ret <2 x i64> %ret 201 } 202 203 ; Test v2i64 insertion with the next value up. 204 define <2 x i64> @f23(<2 x i64> %val) { 205 ; CHECK-LABEL: f23: 206 ; CHECK-NOT: vleig 207 ; CHECK: br %r14 208 %ret = insertelement <2 x i64> %val, i64 32768, i32 1 209 ret <2 x i64> %ret 210 } 211 212 ; Test v2i64 insertion with the minimum value allowed by VLEIG. 213 define <2 x i64> @f24(<2 x i64> %val) { 214 ; CHECK-LABEL: f24: 215 ; CHECK: vleig %v24, -32768, 0 216 ; CHECK: br %r14 217 %ret = insertelement <2 x i64> %val, i64 -32768, i32 0 218 ret <2 x i64> %ret 219 } 220 221 ; Test v2i64 insertion with the next value down. 222 define <2 x i64> @f25(<2 x i64> %val) { 223 ; CHECK-LABEL: f25: 224 ; CHECK-NOT: vleig 225 ; CHECK: br %r14 226 %ret = insertelement <2 x i64> %val, i64 -32769, i32 0 227 ret <2 x i64> %ret 228 } 229 230 ; Test v2i64 insertion into a variable element. 231 define <2 x i64> @f26(<2 x i64> %val, i32 %index) { 232 ; CHECK-LABEL: f26: 233 ; CHECK-NOT: vleig 234 ; CHECK: br %r14 235 %ret = insertelement <2 x i64> %val, i64 0, i32 %index 236 ret <2 x i64> %ret 237 } 238 239 ; Test v4f32 insertion of 0 into the first element. 240 define <4 x float> @f27(<4 x float> %val) { 241 ; CHECK-LABEL: f27: 242 ; CHECK: vleif %v24, 0, 0 243 ; CHECK: br %r14 244 %ret = insertelement <4 x float> %val, float 0.0, i32 0 245 ret <4 x float> %ret 246 } 247 248 ; Test v4f32 insertion of 0 into the last element. 249 define <4 x float> @f28(<4 x float> %val) { 250 ; CHECK-LABEL: f28: 251 ; CHECK: vleif %v24, 0, 3 252 ; CHECK: br %r14 253 %ret = insertelement <4 x float> %val, float 0.0, i32 3 254 ret <4 x float> %ret 255 } 256 257 ; Test v4f32 insertion of a nonzero value. 258 define <4 x float> @f29(<4 x float> %val) { 259 ; CHECK-LABEL: f29: 260 ; CHECK-NOT: vleif 261 ; CHECK: br %r14 262 %ret = insertelement <4 x float> %val, float 1.0, i32 1 263 ret <4 x float> %ret 264 } 265 266 ; Test v2f64 insertion of 0 into the first element. 267 define <2 x double> @f30(<2 x double> %val) { 268 ; CHECK-LABEL: f30: 269 ; CHECK: vleig %v24, 0, 0 270 ; CHECK: br %r14 271 %ret = insertelement <2 x double> %val, double 0.0, i32 0 272 ret <2 x double> %ret 273 } 274 275 ; Test v2f64 insertion of 0 into the last element. 276 define <2 x double> @f31(<2 x double> %val) { 277 ; CHECK-LABEL: f31: 278 ; CHECK: vleig %v24, 0, 1 279 ; CHECK: br %r14 280 %ret = insertelement <2 x double> %val, double 0.0, i32 1 281 ret <2 x double> %ret 282 } 283 284 ; Test v2f64 insertion of a nonzero value. 285 define <2 x double> @f32(<2 x double> %val) { 286 ; CHECK-LABEL: f32: 287 ; CHECK-NOT: vleig 288 ; CHECK: br %r14 289 %ret = insertelement <2 x double> %val, double 1.0, i32 1 290 ret <2 x double> %ret 291 } 292