[llvm] r255867 - Fix PR25838.
Cong Hou via llvm-commits
llvm-commits at lists.llvm.org
Wed Dec 16 17:29:09 PST 2015
Author: conghou
Date: Wed Dec 16 19:29:08 2015
New Revision: 255867
URL: http://llvm.org/viewvc/llvm-project?rev=255867&view=rev
Log:
Fix PR25838.
This is a quick fix to PR25838. The issue comes from the restriction that we
cannot normalize probabilities containing both known and unknown ones. A patch
that removes this restriction is under the review now:
http://reviews.llvm.org/D15548
Added:
llvm/trunk/test/CodeGen/ARM/pr25838.ll
Modified:
llvm/trunk/lib/CodeGen/IfConversion.cpp
Modified: llvm/trunk/lib/CodeGen/IfConversion.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/IfConversion.cpp?rev=255867&r1=255866&r2=255867&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/IfConversion.cpp (original)
+++ llvm/trunk/lib/CodeGen/IfConversion.cpp Wed Dec 16 19:29:08 2015
@@ -1662,6 +1662,12 @@ void IfConverter::MergeBlocks(BBInfo &To
ToBBI.BB->splice(ToBBI.BB->end(),
FromBBI.BB, FromBBI.BB->begin(), FromBBI.BB->end());
+ // Force normalizing the successors' probabilities of ToBBI.BB to convert all
+ // unknown probabilities into known ones.
+ // FIXME: This usage is too tricky and in the future we would like to
+ // eliminate all unknown probabilities in MBB.
+ ToBBI.BB->normalizeSuccProbs();
+
SmallVector<MachineBasicBlock *, 4> FromSuccs(FromBBI.BB->succ_begin(),
FromBBI.BB->succ_end());
MachineBasicBlock *NBB = getNextBlock(FromBBI.BB);
Added: llvm/trunk/test/CodeGen/ARM/pr25838.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/ARM/pr25838.ll?rev=255867&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/ARM/pr25838.ll (added)
+++ llvm/trunk/test/CodeGen/ARM/pr25838.ll Wed Dec 16 19:29:08 2015
@@ -0,0 +1,34 @@
+; RUN: llc < %s
+; PR25838
+
+target triple = "armv7--linux-android"
+
+%0 = type { i32, i32 }
+
+define i32 @foo(%0* readonly) {
+ br i1 undef, label %12, label %2
+
+; <label>:2
+ %3 = trunc i64 undef to i32
+ %4 = icmp eq i32 undef, 0
+ br i1 %4, label %5, label %9
+
+; <label>:5
+ %6 = icmp slt i32 %3, 0
+ %7 = sub nsw i32 0, %3
+ %8 = select i1 %6, i32 %7, i32 %3
+ br label %12
+
+; <label>:9
+ br i1 undef, label %12, label %10
+
+; <label>:10
+ %11 = tail call i32 @bar(i32 undef)
+ unreachable
+
+; <label>:12
+ %13 = phi i32 [ %8, %5 ], [ 0, %1 ], [ undef, %9 ]
+ ret i32 %13
+}
+
+declare i32 @bar(i32)
More information about the llvm-commits
mailing list