From: Evan Cheng Date: Thu, 14 Jun 2007 23:13:19 +0000 (+0000) Subject: If BB is predicated, invalidate its predecessor(s) which would if-convert it. It... X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=e37e24331c6fb3e83d5fb0c9ce31be619359a52a;p=oota-llvm.git If BB is predicated, invalidate its predecessor(s) which would if-convert it. It needs to be re-analyzed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37580 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/IfConversion.cpp b/lib/CodeGen/IfConversion.cpp index 87340d37005..b1aa31a28e3 100644 --- a/lib/CodeGen/IfConversion.cpp +++ b/lib/CodeGen/IfConversion.cpp @@ -656,15 +656,19 @@ static bool canFallThroughTo(MachineBasicBlock *BB, MachineBasicBlock *ToBB) { } /// ReTryPreds - Invalidate predecessor BB info so it would be re-analyzed -/// to determine if it can be if-converted. +/// to determine if it can be if-converted. If predecessor is already +/// enqueud, dequeue it! void IfConverter::ReTryPreds(MachineBasicBlock *BB) { for (MachineBasicBlock::pred_iterator PI = BB->pred_begin(), E = BB->pred_end(); PI != E; ++PI) { BBInfo &PBBI = BBAnalysis[(*PI)->getNumber()]; - if (!PBBI.IsDone && PBBI.Kind == ICNotClassfied) { + if (PBBI.IsDone) + continue; + if (PBBI.Kind == ICNotClassfied) { assert(!PBBI.IsEnqueued && "Unexpected"); PBBI.IsAnalyzed = false; - } + } else if (PBBI.IsEnqueued && PBBI.BB != BB) + PBBI.IsEnqueued = false; } }