mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
Reuse a technique (pioneered for BasicBlocks) of superposing ilist with
its sentinel. This is quite a win when a function really has a basic block. When the function is just a declaration (and stays so) the old way did not allocate a sentinel. So this change is most beneficial when the ratio of function definition to declaration is high. I.e. linkers etc. Incidentally these are the most resource demanding applications, so I expect that the reduced malloc traffic, locality and space savings outweigh the cost of addition of two pointers to Function. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65776 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
358f24943a
commit
abd6f28a74
@ -32,12 +32,17 @@ class FunctionType;
|
||||
template<> struct ilist_traits<BasicBlock>
|
||||
: public SymbolTableListTraits<BasicBlock, Function> {
|
||||
|
||||
// createSentinel is used to create a node that marks the end of the list...
|
||||
static BasicBlock *createSentinel();
|
||||
static void destroySentinel(BasicBlock *BB) { delete BB; }
|
||||
// createSentinel is used to get hold of the node that marks the end of the
|
||||
// list... (same trick used here as in ilist_traits<Instruction>)
|
||||
BasicBlock *createSentinel() const {
|
||||
return const_cast<BasicBlock*>(static_cast<const BasicBlock*>(&Sentinel));
|
||||
}
|
||||
static void destroySentinel(BasicBlock*) {}
|
||||
static iplist<BasicBlock> &getList(Function *F);
|
||||
static ValueSymbolTable *getSymTab(Function *ItemParent);
|
||||
static int getListOffset();
|
||||
private:
|
||||
ilist_node<BasicBlock> Sentinel;
|
||||
};
|
||||
|
||||
template<> struct ilist_traits<Argument>
|
||||
|
@ -22,13 +22,6 @@
|
||||
#include "llvm/ADT/StringExtras.h"
|
||||
using namespace llvm;
|
||||
|
||||
BasicBlock *ilist_traits<BasicBlock>::createSentinel() {
|
||||
BasicBlock *Ret = BasicBlock::Create();
|
||||
// This should not be garbage monitored.
|
||||
LeakDetector::removeGarbageObject(Ret);
|
||||
return Ret;
|
||||
}
|
||||
|
||||
iplist<BasicBlock> &ilist_traits<BasicBlock>::getList(Function *F) {
|
||||
return F->getBasicBlockList();
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user