[PATCH] D85971: [IndVarSimplify] Fix Modified status for removal of overflow intrinsics
David Stenberg via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Sep 29 04:21:54 PDT 2020
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rGe6f332ef1e41: [IndVarSimplify] Fix Modified status for removal of overflow intrinsics (authored by dstenb).
Changed prior to commit:
https://reviews.llvm.org/D85971?vs=285640&id=294930#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D85971/new/
https://reviews.llvm.org/D85971
Files:
llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
llvm/test/Transforms/IndVarSimplify/eliminate-overflow-modified.ll
Index: llvm/test/Transforms/IndVarSimplify/eliminate-overflow-modified.ll
===================================================================
--- /dev/null
+++ llvm/test/Transforms/IndVarSimplify/eliminate-overflow-modified.ll
@@ -0,0 +1,46 @@
+; RUN: opt < %s -indvars -S -o - | FileCheck %s
+
+; When eliminating the overflow intrinsic the indvars pass would incorrectly
+; return a false Modified status. This was caught by the pass return
+; status check that is hidden under EXPENSIVE_CHECKS.
+
+; CHECK-LABEL: for.body:
+; CHECK-NEXT: %0 = phi i16 [ %1, %for.body ], [ undef, %for.body.preheader ]
+; CHECK-NEXT: %1 = add nsw i16 %0, -1
+; CHECK-NEXT: %cmp = icmp sgt i16 %1, 0
+; CHECK-NEXT: call void @llvm.assume(i1 %cmp)
+
+; Function Attrs: nounwind
+define void @foo() #0 {
+entry:
+ %cmp1 = icmp sgt i16 undef, 0
+ br i1 %cmp1, label %for.body.preheader, label %for.end
+
+for.body.preheader: ; preds = %entry
+ br label %for.body
+
+for.body: ; preds = %for.body.preheader, %for.body
+ %0 = phi i16 [ %2, %for.body ], [ undef, %for.body.preheader ]
+ %1 = call { i16, i1 } @llvm.sadd.with.overflow.i16(i16 %0, i16 -1)
+ %2 = extractvalue { i16, i1 } %1, 0
+ %cmp = icmp sgt i16 %2, 0
+ call void @llvm.assume(i1 %cmp)
+ br label %for.body
+
+for.end: ; preds = %entry
+ ret void
+}
+
+; Function Attrs: nounwind readnone speculatable willreturn
+declare { i16, i1 } @llvm.sadd.with.overflow.i16(i16, i16) #1
+
+; Function Attrs: nounwind willreturn
+declare void @llvm.assume(i1) #2
+
+attributes #0 = { nounwind }
+attributes #1 = { nounwind readnone speculatable willreturn }
+attributes #2 = { nounwind willreturn }
+
+!llvm.ident = !{!0}
+
+!0 = !{!"clang version 12.0.0"}
Index: llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
===================================================================
--- llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
+++ llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
@@ -477,6 +477,7 @@
if (WO->use_empty())
WO->eraseFromParent();
+ Changed = true;
return true;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D85971.294930.patch
Type: text/x-patch
Size: 2145 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200929/263c88ee/attachment.bin>
More information about the llvm-commits
mailing list