mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
fix an issue where the verifier would reject a function whose entry
block had its address taken even if the blockaddress was dead. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85706 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
da9c281121
commit
660a4f389c
@ -240,6 +240,10 @@ public:
|
||||
/// hasAddressTaken - returns true if there are any uses of this basic block
|
||||
/// other than direct branches, switches, etc. to it.
|
||||
bool hasAddressTaken() const { return SubclassData != 0; }
|
||||
|
||||
/// removeDeadBlockAddress - If there is a blockaddress node for this basic
|
||||
/// block, try to remove it and any dead constant users of it.
|
||||
void removeDeadBlockAddress();
|
||||
private:
|
||||
/// AdjustBlockAddressRefCount - BasicBlock stores the number of BlockAddress
|
||||
/// objects using it. This is almost always 0, sometimes one, possibly but
|
||||
|
@ -75,6 +75,14 @@ void GlobalValue::removeDeadConstantUsers() const {
|
||||
}
|
||||
}
|
||||
|
||||
/// removeDeadBlockAddress - If there is a blockaddress node for this basic
|
||||
/// block, try to remove it and any dead constant users of it.
|
||||
void BasicBlock::removeDeadBlockAddress() {
|
||||
if (!hasAddressTaken()) return;
|
||||
removeDeadUsersOfConstant(BlockAddress::get(this));
|
||||
}
|
||||
|
||||
|
||||
/// Override destroyConstant to make sure it doesn't get called on
|
||||
/// GlobalValue's because they shouldn't be treated like other constants.
|
||||
void GlobalValue::destroyConstant() {
|
||||
|
@ -658,8 +658,13 @@ void Verifier::visitFunction(Function &F) {
|
||||
BasicBlock *Entry = &F.getEntryBlock();
|
||||
Assert1(pred_begin(Entry) == pred_end(Entry),
|
||||
"Entry block to function must not have predecessors!", Entry);
|
||||
Assert1(!Entry->hasAddressTaken(),
|
||||
"blockaddress may not be used with the entry block!", Entry);
|
||||
|
||||
// The address of the entry block cannot be taken, unless it is dead.
|
||||
if (Entry->hasAddressTaken()) {
|
||||
Entry->removeDeadBlockAddress();
|
||||
Assert1(!Entry->hasAddressTaken(),
|
||||
"blockaddress may not be used with the entry block!", Entry);
|
||||
}
|
||||
}
|
||||
|
||||
// If this function is actually an intrinsic, verify that it is only used in
|
||||
|
Loading…
x
Reference in New Issue
Block a user