mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 04:30:23 +00:00
RegionInfo: Add helpers to replace entry/exit recursively
Contributed by: Star Tan <tanmx_star@yeah.net> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@179157 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
90dd7fd167
commit
d03fdfb97c
@ -266,6 +266,24 @@ public:
|
|||||||
/// @param BB The new exit basic block of the region.
|
/// @param BB The new exit basic block of the region.
|
||||||
void replaceExit(BasicBlock *BB);
|
void replaceExit(BasicBlock *BB);
|
||||||
|
|
||||||
|
/// @brief Recursively replace the entry basic block of the region.
|
||||||
|
///
|
||||||
|
/// This function replaces the entry basic block with a new basic block. It
|
||||||
|
/// also updates all child regions that have the same entry basic block as
|
||||||
|
/// this region.
|
||||||
|
///
|
||||||
|
/// @param NewEntry The new entry basic block.
|
||||||
|
void replaceEntryRecursive(BasicBlock *NewEntry);
|
||||||
|
|
||||||
|
/// @brief Recursively replace the exit basic block of the region.
|
||||||
|
///
|
||||||
|
/// This function replaces the exit basic block with a new basic block. It
|
||||||
|
/// also updates all child regions that have the same exit basic block as
|
||||||
|
/// this region.
|
||||||
|
///
|
||||||
|
/// @param NewExit The new exit basic block.
|
||||||
|
void replaceExitRecursive(BasicBlock *NewExit);
|
||||||
|
|
||||||
/// @brief Get the exit BasicBlock of the Region.
|
/// @brief Get the exit BasicBlock of the Region.
|
||||||
/// @return The exit BasicBlock of the Region, NULL if this is the TopLevel
|
/// @return The exit BasicBlock of the Region, NULL if this is the TopLevel
|
||||||
/// Region.
|
/// Region.
|
||||||
|
@ -79,6 +79,38 @@ void Region::replaceExit(BasicBlock *BB) {
|
|||||||
exit = BB;
|
exit = BB;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Region::replaceEntryRecursive(BasicBlock *NewEntry) {
|
||||||
|
std::vector<Region *> RegionQueue;
|
||||||
|
BasicBlock *OldEntry = getEntry();
|
||||||
|
|
||||||
|
RegionQueue.push_back(this);
|
||||||
|
while (!RegionQueue.empty()) {
|
||||||
|
Region *R = RegionQueue.back();
|
||||||
|
RegionQueue.pop_back();
|
||||||
|
|
||||||
|
R->replaceEntry(NewEntry);
|
||||||
|
for (Region::const_iterator RI = R->begin(), RE = R->end(); RI != RE; ++RI)
|
||||||
|
if ((*RI)->getEntry() == OldEntry)
|
||||||
|
RegionQueue.push_back(*RI);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Region::replaceExitRecursive(BasicBlock *NewExit) {
|
||||||
|
std::vector<Region *> RegionQueue;
|
||||||
|
BasicBlock *OldExit = getExit();
|
||||||
|
|
||||||
|
RegionQueue.push_back(this);
|
||||||
|
while (!RegionQueue.empty()) {
|
||||||
|
Region *R = RegionQueue.back();
|
||||||
|
RegionQueue.pop_back();
|
||||||
|
|
||||||
|
R->replaceExit(NewExit);
|
||||||
|
for (Region::const_iterator RI = R->begin(), RE = R->end(); RI != RE; ++RI)
|
||||||
|
if ((*RI)->getExit() == OldExit)
|
||||||
|
RegionQueue.push_back(*RI);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool Region::contains(const BasicBlock *B) const {
|
bool Region::contains(const BasicBlock *B) const {
|
||||||
BasicBlock *BB = const_cast<BasicBlock*>(B);
|
BasicBlock *BB = const_cast<BasicBlock*>(B);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user