[PATCH] D67838: [CodeGenPrepare] Mend "avoid crashing from replacing a phi twice" fix.
Jesper Antonsson via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Sep 27 06:05:47 PDT 2019
This revision was automatically updated to reflect the committed changes.
Closed by commit rL373084: [CodeGenPrepare] Mend "avoid crashing from replacing a phi twice" fix. (authored by JesperAntonsson, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D67838?vs=221035&id=222156#toc
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D67838/new/
https://reviews.llvm.org/D67838
Files:
llvm/trunk/lib/CodeGen/CodeGenPrepare.cpp
llvm/trunk/test/CodeGen/X86/codegen-prepare-replacephi2.mir
Index: llvm/trunk/test/CodeGen/X86/codegen-prepare-replacephi2.mir
===================================================================
--- llvm/trunk/test/CodeGen/X86/codegen-prepare-replacephi2.mir
+++ llvm/trunk/test/CodeGen/X86/codegen-prepare-replacephi2.mir
@@ -0,0 +1,68 @@
+# RUN: llc -run-pass=codegenprepare -o - %s | FileCheck %s
+
+# REQUIRES: default_triple
+
+# This testcase without the accompanying fix triggers the assert
+# "Replacement PHI node is already replaced."
+
+--- |
+
+ define void @f1() {
+ entry:
+ %arrayidx = getelementptr inbounds [2 x i16], [2 x i16]* undef, i16 0, i16 2
+ %0 = bitcast i16* %arrayidx to i32*
+ %1 = bitcast [2 x i16]* undef to i32*
+ br label %for.cond
+
+ for.cond.loopexit:
+ br label %for.cond
+
+ for.cond:
+ %2 = phi i32* [ %0, %entry ], [ %12, %for.cond.loopexit ]
+ %3 = phi i32* [ %0, %entry ], [ %14, %for.cond.loopexit ]
+ br label %for.body
+
+ for.body:
+ %4 = phi i32* [ %3, %for.cond ], [ %14, %cleanup ]
+ %5 = phi i32* [ %2, %for.cond ], [ %13, %cleanup ]
+ %6 = phi i32* [ %2, %for.cond ], [ %12, %cleanup ]
+ br i1 undef, label %for.cond2.preheader, label %if.then
+
+ for.cond2.preheader:
+ br label %for.cond2
+
+ if.then:
+ store i32 undef, i32* %4, align 1
+ br label %cleanup
+
+ for.cond2:
+ %7 = phi i32* [ %10, %for.inc ], [ %6, %for.cond2.preheader ]
+ %8 = phi i32* [ %11, %for.inc ], [ %5, %for.cond2.preheader ]
+ %9 = phi i32* [ %11, %for.inc ], [ %4, %for.cond2.preheader ]
+ br i1 undef, label %for.inc, label %if.then5
+
+ if.then5:
+ br i1 icmp ne (i16 2, i16 0), label %cleanup.loopexit, label %if.end
+
+ if.end:
+ br label %for.inc
+
+ for.inc:
+ %10 = phi i32* [ %7, %if.end ], [ %1, %for.cond2 ]
+ %11 = phi i32* [ %8, %if.end ], [ %1, %for.cond2 ]
+ br label %for.cond2
+
+ cleanup.loopexit:
+ br label %cleanup
+
+ cleanup:
+ %12 = phi i32* [ %6, %if.then ], [ %7, %cleanup.loopexit ]
+ %13 = phi i32* [ %5, %if.then ], [ %8, %cleanup.loopexit ]
+ %14 = phi i32* [ %4, %if.then ], [ %9, %cleanup.loopexit ]
+ br i1 true, label %for.cond.loopexit, label %for.body
+ }
+
+...
+
+# Sanity check to verify that something got through.
+# CHECK-LABEL: entry:
Index: llvm/trunk/lib/CodeGen/CodeGenPrepare.cpp
===================================================================
--- llvm/trunk/lib/CodeGen/CodeGenPrepare.cpp
+++ llvm/trunk/lib/CodeGen/CodeGenPrepare.cpp
@@ -3332,7 +3332,7 @@
// So the values are different and does not match. So we need them to
// match. (But we register no more than one match per PHI node, so that
// we won't later try to replace them twice.)
- if (!MatchedPHIs.insert(FirstPhi).second)
+ if (MatchedPHIs.insert(FirstPhi).second)
Matcher.insert({ FirstPhi, SecondPhi });
// But me must check it.
WorkList.push_back({ FirstPhi, SecondPhi });
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D67838.222156.patch
Type: text/x-patch
Size: 2935 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190927/246ab806/attachment.bin>
More information about the llvm-commits
mailing list