mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-19 16:35:10 +00:00
Update edge weights correctly in replaceSuccessor().
When replacing Old with New, it can happen that New is already a successor. Add the old and new edge weights instead of creating a duplicate edge. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@161653 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
94bc246a8b
commit
15121ca0d1
@ -478,18 +478,42 @@ MachineBasicBlock::removeSuccessor(succ_iterator I) {
|
||||
|
||||
void MachineBasicBlock::replaceSuccessor(MachineBasicBlock *Old,
|
||||
MachineBasicBlock *New) {
|
||||
uint32_t weight = 0;
|
||||
succ_iterator SI = std::find(Successors.begin(), Successors.end(), Old);
|
||||
if (Old == New)
|
||||
return;
|
||||
|
||||
// If Weight list is empty it means we don't use it (disabled optimization).
|
||||
if (!Weights.empty()) {
|
||||
weight_iterator WI = getWeightIterator(SI);
|
||||
weight = *WI;
|
||||
succ_iterator E = succ_end();
|
||||
succ_iterator NewI = E;
|
||||
succ_iterator OldI = E;
|
||||
for (succ_iterator I = succ_begin(); I != E; ++I) {
|
||||
if (*I == Old) {
|
||||
OldI = I;
|
||||
if (NewI != E)
|
||||
break;
|
||||
}
|
||||
if (*I == New) {
|
||||
NewI = I;
|
||||
if (OldI != E)
|
||||
break;
|
||||
}
|
||||
}
|
||||
assert(OldI != E && "Old is not a successor of this block");
|
||||
Old->removePredecessor(this);
|
||||
|
||||
// If New isn't already a successor, let it take Old's place.
|
||||
if (NewI == E) {
|
||||
New->addPredecessor(this);
|
||||
*OldI = New;
|
||||
return;
|
||||
}
|
||||
|
||||
// Update the successor information.
|
||||
removeSuccessor(SI);
|
||||
addSuccessor(New, weight);
|
||||
// New is already a successor.
|
||||
// Update its weight instead of adding a duplicate edge.
|
||||
if (!Weights.empty()) {
|
||||
weight_iterator OldWI = getWeightIterator(OldI);
|
||||
*getWeightIterator(NewI) += *OldWI;
|
||||
Weights.erase(OldWI);
|
||||
}
|
||||
Successors.erase(OldI);
|
||||
}
|
||||
|
||||
void MachineBasicBlock::addPredecessor(MachineBasicBlock *pred) {
|
||||
|
@ -1,7 +1,7 @@
|
||||
; RUN: llc -march=x86-64 < %s | FileCheck %s
|
||||
|
||||
; CHECK: orq
|
||||
; CHECK-NEXT: LBB0_1
|
||||
; CHECK-NEXT: %bb8.i329
|
||||
|
||||
@_ZN11xercesc_2_513SchemaSymbols21fgURI_SCHEMAFORSCHEMAE = external constant [33 x i16], align 32 ; <[33 x i16]*> [#uses=1]
|
||||
@_ZN11xercesc_2_56XMLUni16fgNotationStringE = external constant [9 x i16], align 16 ; <[9 x i16]*> [#uses=1]
|
||||
|
Loading…
x
Reference in New Issue
Block a user