@@ -252,12 +252,12 @@ body: |
252
252
RET_ReallyLR implicit $q0
253
253
254
254
---
255
- name : negative_pattern
255
+ name : negative_pattern_missing_lanes
256
256
body : |
257
257
bb.0.entry:
258
258
liveins: $x0, $x1
259
259
260
- ; CHECK-LABEL: name: negative_pattern
260
+ ; CHECK-LABEL: name: negative_pattern_missing_lanes
261
261
; CHECK: [[LD1:%.*]]:fpr128 = LDRQui $x1, 0
262
262
; CHECK-NEXT: [[LD2:%.*]]:fpr128 = LD1i32 [[LD1]]
263
263
@@ -266,3 +266,99 @@ body: |
266
266
%2:fpr128 = LD1i32 %1, 3, %0
267
267
$q0 = COPY %2
268
268
RET_ReallyLR implicit $q0
269
+
270
+ ---
271
+ name : out_of_order_lanes
272
+ body : |
273
+ bb.0.entry:
274
+ liveins: $x0, $x1, $x2, $x3, $x4
275
+
276
+ ; CHECK-LABEL: name: out_of_order_lanes
277
+ ; CHECK: [[COPY:%[0-9]+]]:gpr64common = COPY $x0
278
+ ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr64common = COPY $x1
279
+ ; CHECK-NEXT: [[COPY2:%[0-9]+]]:gpr64common = COPY $x2
280
+ ; CHECK-NEXT: [[COPY3:%[0-9]+]]:gpr64common = COPY $x3
281
+ ; CHECK-NEXT: [[COPY4:%[0-9]+]]:gpr64common = COPY $x4
282
+ ; CHECK-NEXT: [[LD_i32:%[0-9]+]]:fpr32 = LDRSroX [[COPY]], killed [[COPY1]], 0, 1
283
+ ; CHECK-NEXT: [[FIRST_REG:%[0-9]+]]:fpr128 = SUBREG_TO_REG 0, killed [[LD_i32]], %subreg.ssub
284
+ ; CHECK-NEXT: [[LD0_1:%[0-9]+]]:fpr128 = LD1i32 [[FIRST_REG]], 1, killed [[COPY3]]
285
+ ; CHECK-NEXT: [[LD1_0:%[0-9]+]]:fpr32 = LDRSui [[COPY2]], 0
286
+ ; CHECK-NEXT: [[SECOND_REG:%[0-9]+]]:fpr128 = SUBREG_TO_REG 0, killed [[LD1_0]], %subreg.ssub
287
+ ; CHECK-NEXT: [[LD1_1:%[0-9]+]]:fpr128 = LD1i32 [[SECOND_REG]], 1, killed [[COPY4]]
288
+ ; CHECK-NEXT: [[ZIP:%[0-9]+]]:fpr128 = ZIP1v2i64 [[LD0_1]], [[LD1_1]]
289
+ ; CHECK-NEXT: $q0 = COPY [[ZIP]]
290
+ ; CHECK-NEXT: RET_ReallyLR implicit $q0
291
+ %0:gpr64common = COPY $x0
292
+ %1:gpr64common = COPY $x1
293
+ %2:gpr64common = COPY $x2
294
+ %3:gpr64common = COPY $x3
295
+ %4:gpr64common = COPY $x4
296
+ %5:fpr32 = LDRSroX %0, killed %1, 0, 1
297
+ %6:fpr128 = SUBREG_TO_REG 0, killed %5, %subreg.ssub
298
+ %7:fpr128 = LD1i32 %6, 2, killed %2
299
+ %8:fpr128 = LD1i32 %7, 1, killed %3
300
+ %9:fpr128 = LD1i32 %8, 3, killed %4
301
+ $q0 = COPY %9
302
+ RET_ReallyLR implicit $q0
303
+
304
+ ---
305
+ name : negative_pattern_no_subreg_to_reg
306
+ body : |
307
+ bb.0.entry:
308
+ liveins: $x0, $x1, $x2, $x3
309
+
310
+ ; CHECK-LABEL: name: negative_pattern_no_subreg_to_reg
311
+ ; CHECK: [[COPY:%[0-9]+]]:gpr64common = COPY $x0
312
+ ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr64common = COPY $x1
313
+ ; CHECK-NEXT: [[COPY2:%[0-9]+]]:gpr64common = COPY $x2
314
+ ; CHECK-NEXT: [[COPY3:%[0-9]+]]:gpr64common = COPY $x3
315
+ ; CHECK-NEXT: [[INITIAL_VEC:%[0-9]+]]:fpr128 = LDRQui [[COPY]], 0
316
+ ; CHECK-NEXT: [[LD_LANE_1:%[0-9]+]]:fpr128 = LD1i32 [[INITIAL_VEC]], 1, killed [[COPY1]]
317
+ ; CHECK-NEXT: [[LD_LANE_2:%[0-9]+]]:fpr128 = LD1i32 [[LD_LANE_1]], 2, killed [[COPY2]]
318
+ ; CHECK-NEXT: [[LD_LANE_3:%[0-9]+]]:fpr128 = LD1i32 [[LD_LANE_2]], 3, killed [[COPY3]]
319
+ ; CHECK-NEXT: $q0 = COPY [[LD_LANE_3]]
320
+ ; CHECK-NEXT: RET_ReallyLR implicit $q0
321
+ %0:gpr64common = COPY $x0
322
+ %1:gpr64common = COPY $x1
323
+ %2:gpr64common = COPY $x2
324
+ %3:gpr64common = COPY $x3
325
+ %4:fpr128 = LDRQui %0, 0
326
+ %5:fpr128 = LD1i32 %4, 1, killed %1
327
+ %6:fpr128 = LD1i32 %5, 2, killed %2
328
+ %7:fpr128 = LD1i32 %6, 3, killed %3
329
+ $q0 = COPY %7
330
+ RET_ReallyLR implicit $q0
331
+
332
+ ---
333
+ name : negative_pattern_multiple_users
334
+ body : |
335
+ bb.0.entry:
336
+ liveins: $x0, $x1, $x2, $x3, $x4
337
+
338
+ ; CHECK-LABEL: name: negative_pattern_multiple_users
339
+ ; CHECK: [[COPY:%[0-9]+]]:gpr64common = COPY $x0
340
+ ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr64common = COPY $x1
341
+ ; CHECK-NEXT: [[COPY2:%[0-9]+]]:gpr64common = COPY $x2
342
+ ; CHECK-NEXT: [[COPY3:%[0-9]+]]:gpr64common = COPY $x3
343
+ ; CHECK-NEXT: [[COPY4:%[0-9]+]]:gpr64common = COPY $x4
344
+ ; CHECK-NEXT: [[LD_i32:%[0-9]+]]:fpr32 = LDRSroX [[COPY]], killed [[COPY1]], 0, 1
345
+ ; CHECK-NEXT: [[FIRST_REG:%[0-9]+]]:fpr128 = SUBREG_TO_REG 0, killed [[LD_i32]], %subreg.ssub
346
+ ; CHECK-NEXT: [[LD_LANE_1:%[0-9]+]]:fpr128 = LD1i32 [[FIRST_REG]], 1, killed [[COPY2]]
347
+ ; CHECK-NEXT: [[LD_LANE_2:%[0-9]+]]:fpr128 = LD1i32 [[LD_LANE_1]], 2, killed [[COPY3]]
348
+ ; CHECK-NEXT: [[LD_LANE_3:%[0-9]+]]:fpr128 = LD1i32 [[LD_LANE_2]], 3, killed [[COPY4]]
349
+ ; CHECK-NEXT: $q0 = COPY [[LD_LANE_3]]
350
+ ; CHECK-NEXT: $q1 = COPY [[LD_LANE_2]]
351
+ ; CHECK-NEXT: RET_ReallyLR implicit $q0, implicit $q1
352
+ %0:gpr64common = COPY $x0
353
+ %1:gpr64common = COPY $x1
354
+ %2:gpr64common = COPY $x2
355
+ %3:gpr64common = COPY $x3
356
+ %4:gpr64common = COPY $x4
357
+ %5:fpr32 = LDRSroX %0, killed %1, 0, 1
358
+ %6:fpr128 = SUBREG_TO_REG 0, killed %5, %subreg.ssub
359
+ %7:fpr128 = LD1i32 %6, 1, killed %2
360
+ %8:fpr128 = LD1i32 %7, 2, killed %3
361
+ %9:fpr128 = LD1i32 %8, 3, killed %4
362
+ $q0 = COPY %9
363
+ $q1 = COPY %8
364
+ RET_ReallyLR implicit $q0, implicit $q1
0 commit comments