aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/llvm/User.h1
-rw-r--r--lib/VMCore/User.cpp13
2 files changed, 4 insertions, 10 deletions
diff --git a/include/llvm/User.h b/include/llvm/User.h
index 2aca78c41a..1363495f7c 100644
--- a/include/llvm/User.h
+++ b/include/llvm/User.h
@@ -53,6 +53,7 @@ protected:
void dropHungoffUses() {
Use::zap(OperandList, OperandList + NumOperands, true);
OperandList = 0;
+ // Reset NumOperands so User::operator delete() does the right thing.
NumOperands = 0;
}
public:
diff --git a/lib/VMCore/User.cpp b/lib/VMCore/User.cpp
index ba2b2081db..2f4587debb 100644
--- a/lib/VMCore/User.cpp
+++ b/lib/VMCore/User.cpp
@@ -73,16 +73,9 @@ void *User::operator new(size_t s, unsigned Us) {
void User::operator delete(void *Usr) {
User *Start = static_cast<User*>(Usr);
Use *Storage = static_cast<Use*>(Usr) - Start->NumOperands;
- //
- // look for a variadic User
- if (Storage == Start->OperandList) {
- ::operator delete(Storage);
- return;
- }
- //
- // in all other cases just delete the nullary User (covers hung-off
- // uses also
- ::operator delete(Usr);
+ // If there were hung-off uses, they will have been freed already and
+ // NumOperands reset to 0, so here we just free the User itself.
+ ::operator delete(Storage);
}
} // End llvm namespace