forked from OSchip/llvm-project
[BOLT] Fix branch info stats after SCTC
Summary: SCTC was incorrectly swapping BranchInfo when reversing the branch condition. This was wrong because when we remove the successor BB later, it removes the BranchInfo for that BB. In this case the successor would be the BB with the stats we had just swapped. Instead leave BranchInfo as it is and read the branch count from the false or true branch depending on whether we reverse or replace the branch, respectively. The call to removeSuccessor later will remove the unused BranchInfo we no longer care about. (cherry picked from FBD6876799)
This commit is contained in:
parent
1207e1d229
commit
501601259b
|
@ -875,6 +875,7 @@ uint64_t SimplifyConditionalTailCalls::fixTailCalls(BinaryContext &BC,
|
||||||
// Record this block so that we don't try to optimize it twice.
|
// Record this block so that we don't try to optimize it twice.
|
||||||
BeenOptimized.insert(PredBB);
|
BeenOptimized.insert(PredBB);
|
||||||
|
|
||||||
|
bool BranchForStats;
|
||||||
if (CondSucc != BB) {
|
if (CondSucc != BB) {
|
||||||
// Patch the new target address into the conditional branch.
|
// Patch the new target address into the conditional branch.
|
||||||
MIA->reverseBranchCondition(*CondBranch, CalleeSymbol, BC.Ctx.get());
|
MIA->reverseBranchCondition(*CondBranch, CalleeSymbol, BC.Ctx.get());
|
||||||
|
@ -883,17 +884,16 @@ uint64_t SimplifyConditionalTailCalls::fixTailCalls(BinaryContext &BC,
|
||||||
// branch to the old target. This has to be done manually since
|
// branch to the old target. This has to be done manually since
|
||||||
// fixupBranches is not called after SCTC.
|
// fixupBranches is not called after SCTC.
|
||||||
NeedsUncondBranch.emplace_back(std::make_pair(PredBB, CondSucc));
|
NeedsUncondBranch.emplace_back(std::make_pair(PredBB, CondSucc));
|
||||||
// Swap branch statistics after swapping the branch targets.
|
BranchForStats = false;
|
||||||
auto BI = PredBB->branch_info_begin();
|
|
||||||
std::swap(*BI, *(BI + 1));
|
|
||||||
} else {
|
} else {
|
||||||
// Change destination of the conditional branch.
|
// Change destination of the conditional branch.
|
||||||
MIA->replaceBranchTarget(*CondBranch, CalleeSymbol, BC.Ctx.get());
|
MIA->replaceBranchTarget(*CondBranch, CalleeSymbol, BC.Ctx.get());
|
||||||
|
BranchForStats = true;
|
||||||
}
|
}
|
||||||
const uint64_t CTCTakenFreq = PredBB->getBranchInfo(true).Count ==
|
const auto Count = PredBB->getBranchInfo(BranchForStats).Count;
|
||||||
BinaryBasicBlock::COUNT_NO_PROFILE
|
const uint64_t CTCTakenFreq =
|
||||||
? 0
|
Count == BinaryBasicBlock::COUNT_NO_PROFILE ? 0 : Count;
|
||||||
: PredBB->getBranchInfo(true).Count;
|
|
||||||
// Annotate it, so "isCall" returns true for this jcc
|
// Annotate it, so "isCall" returns true for this jcc
|
||||||
MIA->setConditionalTailCall(*CondBranch);
|
MIA->setConditionalTailCall(*CondBranch);
|
||||||
// Add info abount the conditional tail call frequency, otherwise this
|
// Add info abount the conditional tail call frequency, otherwise this
|
||||||
|
|
Loading…
Reference in New Issue