forked from OSchip/llvm-project
[CodeExtractor] Add a few debug lines to understand why a region is not extracted
The CodeExtractor is not smart enough to compute which basic block is the entry of a region. Instead it relies on the order of the list of basic blocks that is handed to it and assumes that the entry is the first block in the list. Without the additional debug information, it is hard to understand why a valid region does not get extracted, because we would miss that the order of in the list just doesn't match what the CodeExtractor wants. NFC llvm-svn: 358471
This commit is contained in:
parent
4ed54ee3db
commit
474a9679bd
|
@ -209,6 +209,9 @@ buildExtractionBlockSet(ArrayRef<BasicBlock *> BBs, DominatorTree *DT,
|
||||||
llvm_unreachable("Repeated basic blocks in extraction input");
|
llvm_unreachable("Repeated basic blocks in extraction input");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVM_DEBUG(dbgs() << "Region front block: " << Result.front()->getName()
|
||||||
|
<< '\n');
|
||||||
|
|
||||||
for (auto *BB : Result) {
|
for (auto *BB : Result) {
|
||||||
if (!isBlockValidForExtraction(*BB, Result, AllowVarArgs, AllowAlloca))
|
if (!isBlockValidForExtraction(*BB, Result, AllowVarArgs, AllowAlloca))
|
||||||
return {};
|
return {};
|
||||||
|
@ -226,9 +229,11 @@ buildExtractionBlockSet(ArrayRef<BasicBlock *> BBs, DominatorTree *DT,
|
||||||
// the subgraph which is being extracted.
|
// the subgraph which is being extracted.
|
||||||
for (auto *PBB : predecessors(BB))
|
for (auto *PBB : predecessors(BB))
|
||||||
if (!Result.count(PBB)) {
|
if (!Result.count(PBB)) {
|
||||||
LLVM_DEBUG(
|
LLVM_DEBUG(dbgs() << "No blocks in this region may have entries from "
|
||||||
dbgs() << "No blocks in this region may have entries from "
|
"outside the region except for the first block!\n"
|
||||||
"outside the region except for the first block!\n");
|
<< "Problematic source BB: " << BB->getName() << "\n"
|
||||||
|
<< "Problematic destination BB: " << PBB->getName()
|
||||||
|
<< "\n");
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue