[llvm] 4b6bd1c - [LoopSimplifyCFG] Clear SCEV dispositions when removing dead blocks.

Florian Hahn via llvm-commits llvm-commits at lists.llvm.org
Mon Oct 10 10:08:55 PDT 2022


Author: Florian Hahn
Date: 2022-10-10T18:08:35+01:00
New Revision: 4b6bd1c9d56909b3f25b8dc3ea5b49e0b32d107a

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

LOG: [LoopSimplifyCFG] Clear SCEV dispositions when removing dead blocks.

When removing loops & blocks we also need to clear the SCEV dispositions
as they may now contain incorrect values.

Fixes #58262.

Added: 
    llvm/test/Transforms/LoopSimplifyCFG/invalidate-scev-dispositions-2.ll

Modified: 
    llvm/lib/Transforms/Scalar/LoopSimplifyCFG.cpp

Removed: 
    


################################################################################
diff  --git a/llvm/lib/Transforms/Scalar/LoopSimplifyCFG.cpp b/llvm/lib/Transforms/Scalar/LoopSimplifyCFG.cpp
index 686d122ca51a..4348067c9073 100644
--- a/llvm/lib/Transforms/Scalar/LoopSimplifyCFG.cpp
+++ b/llvm/lib/Transforms/Scalar/LoopSimplifyCFG.cpp
@@ -417,6 +417,7 @@ class ConstantTerminatorFoldingImpl {
           DTU.applyUpdates(DTUpdates);
         DTUpdates.clear();
         formLCSSARecursively(*FixLCSSALoop, DT, &LI, &SE);
+        SE.forgetBlockAndLoopDispositions();
       }
     }
 

diff  --git a/llvm/test/Transforms/LoopSimplifyCFG/invalidate-scev-dispositions-2.ll b/llvm/test/Transforms/LoopSimplifyCFG/invalidate-scev-dispositions-2.ll
new file mode 100644
index 000000000000..3d5de47ad001
--- /dev/null
+++ b/llvm/test/Transforms/LoopSimplifyCFG/invalidate-scev-dispositions-2.ll
@@ -0,0 +1,51 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -verify-scev -passes="print<scalar-evolution>,loop-simplifycfg" -S %s 2>&1 | FileCheck %s
+
+; print<scalar-evolution> is used to compute SCEVs for all values & loops in
+; the function
+
+define void @test_pr58262(ptr %src) {
+; CHECK-LABEL: @test_pr58262(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br label [[LOOP_1_HEADER:%.*]]
+; CHECK:       loop.1.header.loopexit:
+; CHECK-NEXT:    br label [[LOOP_1_HEADER]]
+; CHECK:       loop.1.header:
+; CHECK-NEXT:    switch i32 0, label [[LOOP_1_HEADER_SPLIT:%.*]] [
+; CHECK-NEXT:    i32 1, label [[LOOP_1_HEADER_LOOPEXIT:%.*]]
+; CHECK-NEXT:    ]
+; CHECK:       loop.1.header.split:
+; CHECK-NEXT:    br label [[LOOP_2_HEADER:%.*]]
+; CHECK:       loop.2.header:
+; CHECK-NEXT:    call void @clobber()
+; CHECK-NEXT:    [[L:%.*]] = load i16, ptr [[SRC:%.*]], align 1
+; CHECK-NEXT:    [[C:%.*]] = icmp ult i16 0, [[L]]
+; CHECK-NEXT:    br i1 [[C]], label [[TRAP:%.*]], label [[LOOP_2_LATCH:%.*]]
+; CHECK:       loop.2.latch:
+; CHECK-NEXT:    br label [[LOOP_2_HEADER]]
+; CHECK:       trap:
+; CHECK-NEXT:    ret void
+;
+entry:
+  br label %loop.1.header
+
+loop.1.header:
+  br label %loop.2.header
+
+loop.2.header:
+  br i1 true, label %then, label %loop.1.header
+
+then:
+  call void @clobber()
+  %l = load i16, ptr %src, align 1
+  %c = icmp ult i16 0, %l
+  br i1 %c, label %trap, label %loop.2.latch
+
+loop.2.latch:
+  br label %loop.2.header
+
+trap:                                             ; preds = %for.body
+  ret void
+}
+
+declare void @clobber()


        


More information about the llvm-commits mailing list