diff --git a/include/llvm/BasicBlock.h b/include/llvm/BasicBlock.h index 3ef83e8a816..54f3690096e 100644 --- a/include/llvm/BasicBlock.h +++ b/include/llvm/BasicBlock.h @@ -38,14 +38,14 @@ template<> struct ilist_traits // NodeTy, which becomes the sentinel. Dereferencing the sentinel is // forbidden (save the ilist_node) so no one will ever notice // the superposition. - return const_cast(static_cast(&Sentinel)); + return static_cast(&Sentinel); } static void destroySentinel(Instruction*) {} static iplist &getList(BasicBlock *BB); static ValueSymbolTable *getSymTab(BasicBlock *ItemParent); static int getListOffset(); private: - ilist_node Sentinel; + mutable ilist_node Sentinel; }; /// This represents a single basic block in LLVM. A basic block is simply a diff --git a/include/llvm/Function.h b/include/llvm/Function.h index 9f4f23be088..37e8f19f625 100644 --- a/include/llvm/Function.h +++ b/include/llvm/Function.h @@ -35,28 +35,28 @@ template<> struct ilist_traits // createSentinel is used to get hold of the node that marks the end of the // list... (same trick used here as in ilist_traits) BasicBlock *createSentinel() const { - return const_cast(static_cast(&Sentinel)); + return static_cast(&Sentinel); } static void destroySentinel(BasicBlock*) {} static iplist &getList(Function *F); static ValueSymbolTable *getSymTab(Function *ItemParent); static int getListOffset(); private: - ilist_node Sentinel; + mutable ilist_node Sentinel; }; template<> struct ilist_traits : public SymbolTableListTraits { Argument *createSentinel() const { - return const_cast(static_cast(&Sentinel)); + return static_cast(&Sentinel); } static void destroySentinel(Argument*) {} static iplist &getList(Function *F); static ValueSymbolTable *getSymTab(Function *ItemParent); static int getListOffset(); private: - ilist_node Sentinel; + mutable ilist_node Sentinel; }; class Function : public GlobalValue, public Annotable,