mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-03 17:31:50 +00:00
if basic blocks are destroyed while there are *just* BlockAddress' hanging
around, then zap them. This is analogous to dangling constantexprs hanging off functions. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85627 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2c63566e40
commit
dac8bde235
@ -58,6 +58,24 @@ BasicBlock::BasicBlock(LLVMContext &C, const Twine &Name, Function *NewParent,
|
||||
|
||||
|
||||
BasicBlock::~BasicBlock() {
|
||||
// If the address of the block is taken and it is being deleted (e.g. because
|
||||
// it is dead), this means that there is either a dangling constant expr
|
||||
// hanging off the block, or an undefined use of the block (source code
|
||||
// expecting the address of a label to keep the block alive even though there
|
||||
// is no indirect branch). Handle these cases by zapping the BlockAddress
|
||||
// nodes. There are no other possible uses at this point.
|
||||
if (hasAddressTaken()) {
|
||||
assert(!use_empty() && "There should be at least one blockaddress!");
|
||||
Constant *Replacement =
|
||||
ConstantInt::get(llvm::Type::getInt32Ty(getContext()), 1);
|
||||
while (!use_empty()) {
|
||||
BlockAddress *BA = cast<BlockAddress>(use_back());
|
||||
BA->replaceAllUsesWith(ConstantExpr::getIntToPtr(Replacement,
|
||||
BA->getType()));
|
||||
BA->destroyConstant();
|
||||
}
|
||||
}
|
||||
|
||||
assert(getParent() == 0 && "BasicBlock still linked into the program!");
|
||||
dropAllReferences();
|
||||
InstList.clear();
|
||||
|
@ -21,5 +21,10 @@ BB1: ; preds = %0, %0
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
define void @test4() {
|
||||
entry:
|
||||
br label %return
|
||||
return:
|
||||
ret void
|
||||
}
|
||||
@test4g = global i8* blockaddress(@test4, %return)
|
||||
|
Loading…
Reference in New Issue
Block a user