Update existing tests with dead interleave groups by adding users. This ensures the tests keep testing what they were intended to test with a planned change to skip unused instructions in cost computations.
77 lines
2.9 KiB
LLVM
77 lines
2.9 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
|
|
; RUN: opt -p loop-vectorize -scalable-vectorization=on -force-vector-width=1 -force-target-supports-scalable-vectors=true -S %s | FileCheck %s
|
|
|
|
target datalayout = "e-m:e-p:64:64-i64:64-i128:128-n32:64-S128"
|
|
|
|
|
|
define i64 @pr97452_scalable_vf1_for_live_out(ptr %src) {
|
|
; CHECK-LABEL: define i64 @pr97452_scalable_vf1_for_live_out(
|
|
; CHECK-SAME: ptr [[SRC:%.*]]) {
|
|
; CHECK-NEXT: [[ENTRY:.*]]:
|
|
; CHECK-NEXT: br label %[[LOOP:.*]]
|
|
; CHECK: [[LOOP]]:
|
|
; CHECK-NEXT: [[FOR:%.*]] = phi i64 [ 0, %[[ENTRY]] ], [ [[L:%.*]], %[[LOOP]] ]
|
|
; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, %[[ENTRY]] ], [ [[IV_NEXT:%.*]], %[[LOOP]] ]
|
|
; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1
|
|
; CHECK-NEXT: [[GEP:%.*]] = getelementptr inbounds i64, ptr [[SRC]], i64 [[IV]]
|
|
; CHECK-NEXT: [[L]] = load i64, ptr [[GEP]], align 8
|
|
; CHECK-NEXT: [[EC:%.*]] = icmp eq i64 [[IV]], 22
|
|
; CHECK-NEXT: br i1 [[EC]], label %[[EXIT:.*]], label %[[LOOP]]
|
|
; CHECK: [[EXIT]]:
|
|
; CHECK-NEXT: [[RES:%.*]] = phi i64 [ [[FOR]], %[[LOOP]] ]
|
|
; CHECK-NEXT: ret i64 [[RES]]
|
|
;
|
|
entry:
|
|
br label %loop
|
|
|
|
loop:
|
|
%for = phi i64 [ 0, %entry ], [ %l, %loop ]
|
|
%iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ]
|
|
%iv.next = add i64 %iv, 1
|
|
%gep = getelementptr inbounds i64, ptr %src, i64 %iv
|
|
%l = load i64, ptr %gep, align 8
|
|
%ec = icmp eq i64 %iv, 22
|
|
br i1 %ec, label %exit, label %loop
|
|
|
|
exit:
|
|
%res = phi i64 [ %for, %loop ]
|
|
ret i64 %res
|
|
}
|
|
|
|
|
|
define void @pr97452_scalable_vf1_for_no_live_out(ptr %src, ptr noalias %dst) {
|
|
; CHECK-LABEL: define void @pr97452_scalable_vf1_for_no_live_out(
|
|
; CHECK-SAME: ptr [[SRC:%.*]], ptr noalias [[DST:%.*]]) {
|
|
; CHECK-NEXT: [[ENTRY:.*]]:
|
|
; CHECK-NEXT: br label %[[LOOP:.*]]
|
|
; CHECK: [[LOOP]]:
|
|
; CHECK-NEXT: [[FOR:%.*]] = phi i64 [ 0, %[[ENTRY]] ], [ [[L:%.*]], %[[LOOP]] ]
|
|
; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, %[[ENTRY]] ], [ [[IV_NEXT:%.*]], %[[LOOP]] ]
|
|
; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1
|
|
; CHECK-NEXT: [[GEP:%.*]] = getelementptr inbounds i64, ptr [[SRC]], i64 [[IV]]
|
|
; CHECK-NEXT: [[L]] = load i64, ptr [[GEP]], align 8
|
|
; CHECK-NEXT: [[GEP_DST:%.*]] = getelementptr inbounds i64, ptr [[DST]], i64 [[IV]]
|
|
; CHECK-NEXT: store i64 [[FOR]], ptr [[GEP_DST]], align 8
|
|
; CHECK-NEXT: [[EC:%.*]] = icmp eq i64 [[IV]], 22
|
|
; CHECK-NEXT: br i1 [[EC]], label %[[EXIT:.*]], label %[[LOOP]]
|
|
; CHECK: [[EXIT]]:
|
|
; CHECK-NEXT: ret void
|
|
;
|
|
entry:
|
|
br label %loop
|
|
|
|
loop:
|
|
%for = phi i64 [ 0, %entry ], [ %l, %loop ]
|
|
%iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ]
|
|
%iv.next = add i64 %iv, 1
|
|
%gep = getelementptr inbounds i64, ptr %src, i64 %iv
|
|
%l = load i64, ptr %gep, align 8
|
|
%gep.dst = getelementptr inbounds i64, ptr %dst, i64 %iv
|
|
store i64 %for, ptr %gep.dst
|
|
%ec = icmp eq i64 %iv, 22
|
|
br i1 %ec, label %exit, label %loop
|
|
|
|
exit:
|
|
ret void
|
|
}
|