From: Chris Lattner Date: Sun, 8 Sep 2002 21:08:43 +0000 (+0000) Subject: Inform the memory leak detector that TmpInstruction objects should not be X-Git-Url: http://plrg.eecs.uci.edu/git/?p=oota-llvm.git;a=commitdiff_plain;h=a175ed419459f9d2e3cee67d43de3ced28b2341d Inform the memory leak detector that TmpInstruction objects should not be subject to memory leak checking. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3623 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/InstrSelection/InstrSelection.cpp b/lib/CodeGen/InstrSelection/InstrSelection.cpp index d8f89813622..a6e5a77d0ea 100644 --- a/lib/CodeGen/InstrSelection/InstrSelection.cpp +++ b/lib/CodeGen/InstrSelection/InstrSelection.cpp @@ -19,6 +19,7 @@ #include "llvm/iPHINode.h" #include "llvm/Pass.h" #include "Support/CommandLine.h" +#include "Support/LeakDetector.h" using std::cerr; using std::vector; @@ -71,6 +72,29 @@ namespace { static RegisterLLC X("instselect", "Instruction Selection", createInstructionSelectionPass); +TmpInstruction::TmpInstruction(Value *s1, Value *s2, const std::string &name) + : Instruction(s1->getType(), Instruction::UserOp1, name) { + Operands.push_back(Use(s1, this)); // s1 must be nonnull + if (s2) { + Operands.push_back(Use(s2, this)); + } + + // TmpInstructions should not be garbage checked. + LeakDetector::removeGarbageObject(this); +} + +// Constructor that requires the type of the temporary to be specified. +// Both S1 and S2 may be NULL.( +TmpInstruction::TmpInstruction(const Type *Ty, Value *s1, Value* s2, + const std::string &name) + : Instruction(Ty, Instruction::UserOp1, name) { + if (s1) { Operands.push_back(Use(s1, this)); } + if (s2) { Operands.push_back(Use(s2, this)); } + + // TmpInstructions should not be garbage checked. + LeakDetector::removeGarbageObject(this); +} + bool InstructionSelection::runOnFunction(Function &F) { diff --git a/lib/Target/SparcV9/InstrSelection/InstrSelection.cpp b/lib/Target/SparcV9/InstrSelection/InstrSelection.cpp index d8f89813622..a6e5a77d0ea 100644 --- a/lib/Target/SparcV9/InstrSelection/InstrSelection.cpp +++ b/lib/Target/SparcV9/InstrSelection/InstrSelection.cpp @@ -19,6 +19,7 @@ #include "llvm/iPHINode.h" #include "llvm/Pass.h" #include "Support/CommandLine.h" +#include "Support/LeakDetector.h" using std::cerr; using std::vector; @@ -71,6 +72,29 @@ namespace { static RegisterLLC X("instselect", "Instruction Selection", createInstructionSelectionPass); +TmpInstruction::TmpInstruction(Value *s1, Value *s2, const std::string &name) + : Instruction(s1->getType(), Instruction::UserOp1, name) { + Operands.push_back(Use(s1, this)); // s1 must be nonnull + if (s2) { + Operands.push_back(Use(s2, this)); + } + + // TmpInstructions should not be garbage checked. + LeakDetector::removeGarbageObject(this); +} + +// Constructor that requires the type of the temporary to be specified. +// Both S1 and S2 may be NULL.( +TmpInstruction::TmpInstruction(const Type *Ty, Value *s1, Value* s2, + const std::string &name) + : Instruction(Ty, Instruction::UserOp1, name) { + if (s1) { Operands.push_back(Use(s1, this)); } + if (s2) { Operands.push_back(Use(s2, this)); } + + // TmpInstructions should not be garbage checked. + LeakDetector::removeGarbageObject(this); +} + bool InstructionSelection::runOnFunction(Function &F) {