summaryrefslogtreecommitdiff
path: root/include/llvm/Function.h
diff options
context:
space:
mode:
authorGabor Greif <ggreif@gmail.com>2009-03-01 16:38:10 +0000
committerGabor Greif <ggreif@gmail.com>2009-03-01 16:38:10 +0000
commitabd6f28a74e74303725ec123bdfe9202617115c8 (patch)
treecaa4ebd3eb34a8b9cb748678a375678798e9f0d0 /include/llvm/Function.h
parent358f24943aab6d3a168eb075f9435e31e85f6c38 (diff)
downloadllvm-abd6f28a74e74303725ec123bdfe9202617115c8.tar.gz
llvm-abd6f28a74e74303725ec123bdfe9202617115c8.tar.bz2
llvm-abd6f28a74e74303725ec123bdfe9202617115c8.tar.xz
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
Diffstat (limited to 'include/llvm/Function.h')
-rw-r--r--include/llvm/Function.h11
1 files changed, 8 insertions, 3 deletions
diff --git a/include/llvm/Function.h b/include/llvm/Function.h
index ee53252b95..bdae9cd02f 100644
--- a/include/llvm/Function.h
+++ b/include/llvm/Function.h
@@ -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>