forked from OSchip/llvm-project
Add function to replace a destination MBB in a single jump table
llvm-svn: 88804
This commit is contained in:
parent
69865cc1db
commit
9c8609ea1c
|
@ -69,6 +69,11 @@ public:
|
|||
/// the jump tables to branch to New instead.
|
||||
bool ReplaceMBBInJumpTables(MachineBasicBlock *Old, MachineBasicBlock *New);
|
||||
|
||||
/// ReplaceMBBInJumpTable - If Old is a target of the jump tables, update
|
||||
/// the jump table to branch to New instead.
|
||||
bool ReplaceMBBInJumpTable(unsigned Idx, MachineBasicBlock *Old,
|
||||
MachineBasicBlock *New);
|
||||
|
||||
/// getEntrySize - Returns the size of an individual field in a jump table.
|
||||
///
|
||||
unsigned getEntrySize() const { return EntrySize; }
|
||||
|
|
|
@ -545,14 +545,25 @@ MachineJumpTableInfo::ReplaceMBBInJumpTables(MachineBasicBlock *Old,
|
|||
MachineBasicBlock *New) {
|
||||
assert(Old != New && "Not making a change?");
|
||||
bool MadeChange = false;
|
||||
for (size_t i = 0, e = JumpTables.size(); i != e; ++i) {
|
||||
MachineJumpTableEntry &JTE = JumpTables[i];
|
||||
for (size_t j = 0, e = JTE.MBBs.size(); j != e; ++j)
|
||||
if (JTE.MBBs[j] == Old) {
|
||||
JTE.MBBs[j] = New;
|
||||
MadeChange = true;
|
||||
}
|
||||
}
|
||||
for (size_t i = 0, e = JumpTables.size(); i != e; ++i)
|
||||
ReplaceMBBInJumpTable(i, Old, New);
|
||||
return MadeChange;
|
||||
}
|
||||
|
||||
/// ReplaceMBBInJumpTable - If Old is a target of the jump tables, update
|
||||
/// the jump table to branch to New instead.
|
||||
bool
|
||||
MachineJumpTableInfo::ReplaceMBBInJumpTable(unsigned Idx,
|
||||
MachineBasicBlock *Old,
|
||||
MachineBasicBlock *New) {
|
||||
assert(Old != New && "Not making a change?");
|
||||
bool MadeChange = false;
|
||||
MachineJumpTableEntry &JTE = JumpTables[Idx];
|
||||
for (size_t j = 0, e = JTE.MBBs.size(); j != e; ++j)
|
||||
if (JTE.MBBs[j] == Old) {
|
||||
JTE.MBBs[j] = New;
|
||||
MadeChange = true;
|
||||
}
|
||||
return MadeChange;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue