mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
make hasAddressTaken() constant time by storing a refcount in BB's subclass data.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85625 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
57f224a5a4
commit
3821176b2e
@ -23,6 +23,7 @@ namespace llvm {
|
||||
|
||||
class TerminatorInst;
|
||||
class LLVMContext;
|
||||
class BlockAddress;
|
||||
|
||||
template<> struct ilist_traits<Instruction>
|
||||
: public SymbolTableListTraits<Instruction, BasicBlock> {
|
||||
@ -66,7 +67,7 @@ private:
|
||||
/// @brief LLVM Basic Block Representation
|
||||
class BasicBlock : public Value, // Basic blocks are data objects also
|
||||
public ilist_node<BasicBlock> {
|
||||
|
||||
friend class BlockAddress;
|
||||
public:
|
||||
typedef iplist<Instruction> InstListType;
|
||||
private:
|
||||
@ -238,7 +239,15 @@ public:
|
||||
|
||||
/// hasAddressTaken - returns true if there are any uses of this basic block
|
||||
/// other than direct branches, switches, etc. to it.
|
||||
bool hasAddressTaken() const;
|
||||
bool hasAddressTaken() const { return SubclassData != 0; }
|
||||
private:
|
||||
/// AdjustBlockAddressRefCount - BasicBlock stores the number of BlockAddress
|
||||
/// objects using it. This is almost always 0, sometimes one, possibly but
|
||||
/// almost never 2, and inconceivably 3 or more.
|
||||
void AdjustBlockAddressRefCount(int Amt) {
|
||||
SubclassData += Amt;
|
||||
assert((int)(char)SubclassData >= 0 && "Refcount wrap-around");
|
||||
}
|
||||
};
|
||||
|
||||
} // End llvm namespace
|
||||
|
@ -278,11 +278,3 @@ BasicBlock *BasicBlock::splitBasicBlock(iterator I, const Twine &BBName) {
|
||||
return New;
|
||||
}
|
||||
|
||||
/// hasAddressTaken - returns true if there are any uses of this basic block
|
||||
/// other than direct branches, switches, etc. to it.
|
||||
bool BasicBlock::hasAddressTaken() const {
|
||||
for (Value::use_const_iterator I = use_begin(), E = use_end(); I != E; ++I)
|
||||
if (isa<BlockAddress>(*I))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
@ -1045,6 +1045,7 @@ BlockAddress::BlockAddress(Function *F, BasicBlock *BB)
|
||||
&Op<0>(), 2) {
|
||||
Op<0>() = F;
|
||||
Op<1>() = BB;
|
||||
BB->AdjustBlockAddressRefCount(1);
|
||||
}
|
||||
|
||||
|
||||
@ -1053,6 +1054,7 @@ BlockAddress::BlockAddress(Function *F, BasicBlock *BB)
|
||||
void BlockAddress::destroyConstant() {
|
||||
getFunction()->getType()->getContext().pImpl
|
||||
->BlockAddresses.erase(std::make_pair(getFunction(), getBasicBlock()));
|
||||
getBasicBlock()->AdjustBlockAddressRefCount(-1);
|
||||
destroyConstantImpl();
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user