diff options
author | Pete Cooper <peter_cooper@apple.com> | 2015-06-10 22:38:30 +0000 |
---|---|---|
committer | Pete Cooper <peter_cooper@apple.com> | 2015-06-10 22:38:30 +0000 |
commit | 87b925b0645e33fc353d8c54ab21b26792262dc8 (patch) | |
tree | 943bbe2c778529bf412d5e451fcfe0e468e64766 | |
parent | 115fe3762108b7aca37274cb31f10a48d9b35b01 (diff) | |
download | bcm5719-llvm-87b925b0645e33fc353d8c54ab21b26792262dc8.tar.gz bcm5719-llvm-87b925b0645e33fc353d8c54ab21b26792262dc8.zip |
Move the special Phi logic for hung off uses in to User::allocHungOffUses. NFC.
PhiNode's need to allocate space for an array of Use[N] and then BasicBlock*[N].
They had their own allocHungOffUses to handle all of this. This moves the logic
in to User::allocHungOffUses and PhiNode passes in a bool to say to allocate
the BB* space too.
Reviewed by Duncan Exon Smith.
llvm-svn: 239489
-rw-r--r-- | llvm/include/llvm/IR/Instructions.h | 4 | ||||
-rw-r--r-- | llvm/include/llvm/IR/User.h | 7 | ||||
-rw-r--r-- | llvm/lib/IR/Instructions.cpp | 12 | ||||
-rw-r--r-- | llvm/lib/IR/User.cpp | 5 |
4 files changed, 13 insertions, 15 deletions
diff --git a/llvm/include/llvm/IR/Instructions.h b/llvm/include/llvm/IR/Instructions.h index 8d8c530d2c6..5c6806c1d0d 100644 --- a/llvm/include/llvm/IR/Instructions.h +++ b/llvm/include/llvm/IR/Instructions.h @@ -2248,7 +2248,9 @@ protected: // allocHungoffUses - this is more complicated than the generic // User::allocHungoffUses, because we have to allocate Uses for the incoming // values and pointers to the incoming blocks, all in one allocation. - Use *allocHungoffUses(unsigned) const; + Use *allocHungoffUses(unsigned N) const { + return User::allocHungoffUses(N, /* IsPhi */ true); + } PHINode *clone_impl() const override; public: diff --git a/llvm/include/llvm/IR/User.h b/llvm/include/llvm/IR/User.h index 455900566af..1dacc3f303e 100644 --- a/llvm/include/llvm/IR/User.h +++ b/llvm/include/llvm/IR/User.h @@ -52,7 +52,12 @@ protected: : Value(ty, vty), OperandList(OpList) { NumOperands = NumOps; } - Use *allocHungoffUses(unsigned) const; + + /// \brief Allocate the array of Uses, followed by a pointer + /// (with bottom bit set) to the User. + /// \param IsPhi identifies callers which are phi nodes and which need + /// N BasicBlock* allocated along with N + Use *allocHungoffUses(unsigned N, bool IsPhi = false) const; void dropHungoffUses() { Use::zap(OperandList, OperandList + NumOperands, true); OperandList = nullptr; diff --git a/llvm/lib/IR/Instructions.cpp b/llvm/lib/IR/Instructions.cpp index 1478bffe7c3..06e2d0913ce 100644 --- a/llvm/lib/IR/Instructions.cpp +++ b/llvm/lib/IR/Instructions.cpp @@ -97,18 +97,6 @@ PHINode::~PHINode() { dropHungoffUses(); } -Use *PHINode::allocHungoffUses(unsigned N) const { - // Allocate the array of Uses of the incoming values, followed by a pointer - // (with bottom bit set) to the User, followed by the array of pointers to - // the incoming basic blocks. - size_t size = N * sizeof(Use) + sizeof(Use::UserRef) - + N * sizeof(BasicBlock*); - Use *Begin = static_cast<Use*>(::operator new(size)); - Use *End = Begin + N; - (void) new(End) Use::UserRef(const_cast<PHINode*>(this), 1); - return Use::initTags(Begin, End); -} - // removeIncomingValue - Remove an incoming value. This is useful if a // predecessor basic block is deleted. Value *PHINode::removeIncomingValue(unsigned Idx, bool DeletePHIIfEmpty) { diff --git a/llvm/lib/IR/User.cpp b/llvm/lib/IR/User.cpp index ee83eacf2b2..4dae071185f 100644 --- a/llvm/lib/IR/User.cpp +++ b/llvm/lib/IR/User.cpp @@ -13,6 +13,7 @@ #include "llvm/IR/Operator.h" namespace llvm { +class BasicBlock; //===----------------------------------------------------------------------===// // User Class @@ -39,10 +40,12 @@ void User::replaceUsesOfWith(Value *From, Value *To) { // User allocHungoffUses Implementation //===----------------------------------------------------------------------===// -Use *User::allocHungoffUses(unsigned N) const { +Use *User::allocHungoffUses(unsigned N, bool IsPhi) const { // Allocate the array of Uses, followed by a pointer (with bottom bit set) to // the User. size_t size = N * sizeof(Use) + sizeof(Use::UserRef); + if (IsPhi) + size += N * sizeof(BasicBlock *); Use *Begin = static_cast<Use*>(::operator new(size)); Use *End = Begin + N; (void) new(End) Use::UserRef(const_cast<User*>(this), 1); |