[llvm-commits] [llvm] r124330 - in /llvm/trunk: include/llvm/User.h lib/VMCore/User.cpp

Jay Foad jay.foad at gmail.com
Wed Jan 26 13:56:11 PST 2011


Author: foad
Date: Wed Jan 26 15:56:10 2011
New Revision: 124330

URL: http://llvm.org/viewvc/llvm-project?rev=124330&view=rev
Log:
Simplify User::operator delete().

Modified:
    llvm/trunk/include/llvm/User.h
    llvm/trunk/lib/VMCore/User.cpp

Modified: llvm/trunk/include/llvm/User.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/User.h?rev=124330&r1=124329&r2=124330&view=diff
==============================================================================
--- llvm/trunk/include/llvm/User.h (original)
+++ llvm/trunk/include/llvm/User.h Wed Jan 26 15:56:10 2011
@@ -53,6 +53,7 @@
   void dropHungoffUses() {
     Use::zap(OperandList, OperandList + NumOperands, true);
     OperandList = 0;
+    // Reset NumOperands so User::operator delete() does the right thing.
     NumOperands = 0;
   }
 public:

Modified: llvm/trunk/lib/VMCore/User.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/VMCore/User.cpp?rev=124330&r1=124329&r2=124330&view=diff
==============================================================================
--- llvm/trunk/lib/VMCore/User.cpp (original)
+++ llvm/trunk/lib/VMCore/User.cpp Wed Jan 26 15:56:10 2011
@@ -73,16 +73,9 @@
 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





More information about the llvm-commits mailing list