[llvm] ed72dc8 - [IndVarSimplify] Add test for PR63763 (NFC)

Nikita Popov via llvm-commits llvm-commits at lists.llvm.org
Fri Aug 11 07:54:03 PDT 2023


Author: Nikita Popov
Date: 2023-08-11T16:53:55+02:00
New Revision: ed72dc8c1fdae691f5d57bb2254e3922db46b7e2

URL: https://github.com/llvm/llvm-project/commit/ed72dc8c1fdae691f5d57bb2254e3922db46b7e2
DIFF: https://github.com/llvm/llvm-project/commit/ed72dc8c1fdae691f5d57bb2254e3922db46b7e2.diff

LOG: [IndVarSimplify] Add test for PR63763 (NFC)

Added: 
    llvm/test/Transforms/IndVarSimplify/pr63763.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/IndVarSimplify/pr63763.ll b/llvm/test/Transforms/IndVarSimplify/pr63763.ll
new file mode 100644
index 00000000000000..709c454e8c66db
--- /dev/null
+++ b/llvm/test/Transforms/IndVarSimplify/pr63763.ll
@@ -0,0 +1,50 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2
+; RUN: opt -S -passes='print<scalar-evolution>,indvars' < %s 2>/dev/null | FileCheck %s
+
+; FIXME: This is a miscompile.
+; We should use %invariant.op.us rather than %invariant.op for the exit
+; value expansion. They have the same SCEV, but %invariant.op is more
+; poisonous.
+define i32 @test(i1 %c) {
+; CHECK-LABEL: define i32 @test
+; CHECK-SAME: (i1 [[C:%.*]]) {
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    [[SEL:%.*]] = select i1 [[C]], i32 33, i32 0
+; CHECK-NEXT:    [[SUB_I:%.*]] = add nsw i32 [[SEL]], -68
+; CHECK-NEXT:    [[SHL_I:%.*]] = shl nuw nsw i32 1, [[SUB_I]]
+; CHECK-NEXT:    [[ADD:%.*]] = add nsw i32 [[SHL_I]], [[SEL]]
+; CHECK-NEXT:    [[SEXT:%.*]] = shl i32 [[ADD]], 24
+; CHECK-NEXT:    [[CONV2:%.*]] = ashr exact i32 [[SEXT]], 24
+; CHECK-NEXT:    [[INVARIANT_OP:%.*]] = sub i32 7, [[CONV2]]
+; CHECK-NEXT:    call void @use(i32 [[INVARIANT_OP]])
+; CHECK-NEXT:    br label [[LOOP:%.*]]
+; CHECK:       loop:
+; CHECK-NEXT:    br i1 true, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK:       exit:
+; CHECK-NEXT:    ret i32 [[INVARIANT_OP]]
+;
+entry:
+  %sel = select i1 %c, i32 33, i32 0
+  %sub.i = add nsw i32 %sel, -68
+  %shl.i = shl nuw nsw i32 1, %sub.i
+  %add = add nsw i32 %shl.i, %sel
+  %sext = shl i32 %add, 24
+  %conv2 = ashr exact i32 %sext, 24
+  %invariant.op = sub nsw i32 7, %conv2
+  call void @use(i32 %invariant.op)
+  %sext.us = shl i32 %sel, 24
+  %conv2.us = ashr exact i32 %sext.us, 24
+  %invariant.op.us = sub nsw i32 7, %conv2.us
+  br label %loop
+
+loop:
+  %iv = phi i32 [ %iv.next , %loop ], [ 0, %entry ]
+  %iv.next = add i32 %iv, 1
+  %cmp = icmp eq i32 %iv.next, %invariant.op.us
+  br i1 %cmp, label %exit, label %loop
+
+exit:
+  ret i32 %iv.next
+}
+
+declare void @use(i32)


        


More information about the llvm-commits mailing list