diff options
| author | Florian Hahn <flo@fhahn.com> | 2026-02-08 11:55:11 +0000 |
|---|---|---|
| committer | Florian Hahn <flo@fhahn.com> | 2026-02-08 11:55:12 +0000 |
| commit | 3192fe2c7b08912cc72c86471a593165b615dc28 (patch) | |
| tree | 88346bf642fa5d8a1d647e79c708b1cd0606d312 /llvm/test/Transforms/LoopVectorize | |
| parent | b2f8a0f60134120586865bfb059b52929e6e8a04 (diff) | |
| download | llvm-3192fe2c7b08912cc72c86471a593165b615dc28.tar.gz llvm-3192fe2c7b08912cc72c86471a593165b615dc28.tar.bz2 llvm-3192fe2c7b08912cc72c86471a593165b615dc28.zip | |
[VPlan] Fall back to legacy cost model if PtrSCEV is nullptr.
There are some cases when PtrSCEV can be nullptr. Fall back to legacy
cost model, to not call isLoopInvariant with nullptr.
Fixes a crash after 0c4f8094939d2.
Diffstat (limited to 'llvm/test/Transforms/LoopVectorize')
| -rw-r--r-- | llvm/test/Transforms/LoopVectorize/X86/predicated-instruction-cost.ll | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopVectorize/X86/predicated-instruction-cost.ll b/llvm/test/Transforms/LoopVectorize/X86/predicated-instruction-cost.ll index 7ae20a07290c..41fb58c50ae0 100644 --- a/llvm/test/Transforms/LoopVectorize/X86/predicated-instruction-cost.ll +++ b/llvm/test/Transforms/LoopVectorize/X86/predicated-instruction-cost.ll @@ -101,3 +101,57 @@ loop.latch: exit: ret void } + +define i32 @predicated_load_non_affine_address(i32 %x, ptr %src) { +; CHECK-LABEL: define i32 @predicated_load_non_affine_address( +; CHECK-SAME: i32 [[X:%.*]], ptr [[SRC:%.*]]) { +; CHECK-NEXT: [[ENTRY:.*]]: +; CHECK-NEXT: br label %[[LOOP:.*]] +; CHECK: [[LOOP]]: +; CHECK-NEXT: [[IV:%.*]] = phi i32 [ 0, %[[ENTRY]] ], [ [[IV_NEXT:%.*]], %[[LOOP_LATCH:.*]] ] +; CHECK-NEXT: [[REM:%.*]] = mul i32 [[IV]], [[X]] +; CHECK-NEXT: [[C:%.*]] = icmp eq i32 [[REM]], 0 +; CHECK-NEXT: br i1 [[C]], label %[[IF_THEN:.*]], label %[[LOOP_LATCH]] +; CHECK: [[IF_THEN]]: +; CHECK-NEXT: [[DIV:%.*]] = udiv i32 [[IV]], [[X]] +; CHECK-NEXT: [[DIV_EXT:%.*]] = zext nneg i32 [[DIV]] to i64 +; CHECK-NEXT: [[GEP_SRC:%.*]] = getelementptr i8, ptr [[SRC]], i64 [[DIV_EXT]] +; CHECK-NEXT: [[L:%.*]] = load i8, ptr [[GEP_SRC]], align 1 +; CHECK-NEXT: [[L_EXT:%.*]] = zext i8 [[L]] to i32 +; CHECK-NEXT: br label %[[LOOP_LATCH]] +; CHECK: [[LOOP_LATCH]]: +; CHECK-NEXT: [[T_0:%.*]] = phi i32 [ 0, %[[LOOP]] ], [ [[L_EXT]], %[[IF_THEN]] ] +; CHECK-NEXT: [[IV_NEXT]] = add nuw nsw i32 [[IV]], 1 +; CHECK-NEXT: [[EC:%.*]] = icmp eq i32 [[IV_NEXT]], 28 +; CHECK-NEXT: br i1 [[EC]], label %[[EXIT:.*]], label %[[LOOP]] +; CHECK: [[EXIT]]: +; CHECK-NEXT: [[T_0_LCSSA:%.*]] = phi i32 [ [[T_0]], %[[LOOP_LATCH]] ] +; CHECK-NEXT: ret i32 [[T_0_LCSSA]] +; +entry: + br label %loop + +loop: + %iv = phi i32 [ 0, %entry ], [ %iv.next, %loop.latch ] + %rem = mul i32 %iv, %x + %c = icmp eq i32 %rem, 0 + br i1 %c, label %if.then, label %loop.latch + +if.then: + %div = udiv i32 %iv, %x + %div.ext = zext nneg i32 %div to i64 + %gep.src = getelementptr i8, ptr %src, i64 %div.ext + %l = load i8, ptr %gep.src, align 1 + %l.ext = zext i8 %l to i32 + br label %loop.latch + +loop.latch: + %t.0 = phi i32 [ 0, %loop ], [ %l.ext, %if.then ] + %iv.next = add nuw nsw i32 %iv, 1 + %ec = icmp eq i32 %iv.next, 28 + br i1 %ec, label %exit, label %loop + +exit: + %t.0.lcssa = phi i32 [ %t.0, %loop.latch ] + ret i32 %t.0.lcssa +} |
