Plug some leaks in edis.
authorBenjamin Kramer <benny.kra@googlemail.com>
Thu, 24 Feb 2011 11:03:19 +0000 (11:03 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Thu, 24 Feb 2011 11:03:19 +0000 (11:03 +0000)
- Don't leak parsed operands during tokenization.
- Don't leak printed insts in llvm-mc.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@126381 91177308-0d34-0410-b5e6-96231b3b80d8

lib/MC/MCDisassembler/EDToken.cpp
tools/llvm-mc/Disassembler.cpp

index 400e1649e9709c8f984dd11f1466a0b6dcc28f84..de770b41ef35f6766b454fed53b79169772a9cc5 100644 (file)
@@ -194,6 +194,10 @@ int EDToken::tokenize(std::vector<EDToken*> &tokens,
     tokens.push_back(token);
   }
   
+  // Free any parsed operands.
+  for (unsigned i = 0, e = parsedOperands.size(); i != e; ++i)
+    delete parsedOperands[i];
+
   return 0;
 }
 
index 1f0850ff8b4e91ad4e1048c3a35c058a63dd65b3..d98b57ebc6591e5193c5672b8b2fd05d3f214513 100644 (file)
@@ -227,8 +227,8 @@ int Disassembler::disassembleEnhanced(const std::string &TS,
   }
   
   EDDisassembler::initialize();
-  EDDisassembler *disassembler =
-    EDDisassembler::getDisassembler(TS.c_str(), AS);
+  OwningPtr<EDDisassembler>
+    disassembler(EDDisassembler::getDisassembler(TS.c_str(), AS));
   
   if (disassembler == 0) {
     errs() << "error: couldn't get disassembler for " << TS << '\n';
@@ -236,8 +236,8 @@ int Disassembler::disassembleEnhanced(const std::string &TS,
   }
   
   while (ByteArray.size()) {
-    EDInst *inst =
-      disassembler->createInst(byteArrayReader, 0, &ByteArray);
+    OwningPtr<EDInst>
+      inst(disassembler->createInst(byteArrayReader, 0, &ByteArray));
   
     ByteArray.erase (ByteArray.begin(), ByteArray.begin() + inst->byteSize());
                                
@@ -330,7 +330,7 @@ int Disassembler::disassembleEnhanced(const std::string &TS,
       }
       
       uint64_t evaluatedResult;
-      void *Arg[] = { disassembler, &Out };
+      void *Arg[] = { disassembler.get(), &Out };
       if (operand->evaluate(evaluatedResult, verboseEvaluator, Arg)) {
         errs() << "error: Couldn't evaluate an operand\n";
         return -1;