Add back machine code deleter pass until we get a MachineCode pass
authorAlkis Evlogimenos <alkis@evlogimenos.com>
Sun, 15 Feb 2004 00:03:15 +0000 (00:03 +0000)
committerAlkis Evlogimenos <alkis@evlogimenos.com>
Sun, 15 Feb 2004 00:03:15 +0000 (00:03 +0000)
that will be responsible for the creation of MachineFunctions and will
be required by all MachineFunctionPass passes.

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

lib/CodeGen/MachineFunction.cpp
lib/Target/PowerPC/PowerPCTargetMachine.cpp
lib/Target/X86/X86CodeEmitter.cpp
lib/Target/X86/X86TargetMachine.cpp

index 645e7cfedfe784042d1ab2d1991156b2f6eddd4d..719d28a0a85766ecd376941c81fe73087dc9cab2 100644 (file)
@@ -62,6 +62,27 @@ FunctionPass *llvm::createMachineFunctionPrinterPass(std::ostream *OS,
   return new Printer(OS, Banner);
 }
 
+namespace {
+  struct Deleter : public MachineFunctionPass {
+    const char *getPassName() const { return "Machine Code Deleter"; }
+
+    bool runOnMachineFunction(MachineFunction &MF) {
+      // Delete the annotation from the function now.
+      MachineFunction::destruct(MF.getFunction());
+      return true;
+    }
+  };
+}
+
+/// MachineCodeDeletion Pass - This pass deletes all of the machine code for
+/// the current function, which should happen after the function has been
+/// emitted to a .s file or to memory.
+FunctionPass *llvm::createMachineCodeDeleter() {
+  return new Deleter();
+}
+
+
+
 //===---------------------------------------------------------------------===//
 // MachineFunction implementation
 //===---------------------------------------------------------------------===//
index 54d0734fb97596341bbbc5b14176dcc304885230..88b33f098ee071d45835cb4230d8f9bbb8041c52 100644 (file)
@@ -45,6 +45,7 @@ bool PowerPCTargetMachine::addPassesToEmitAssembly(PassManager &PM,
   PM.add(createRegisterAllocator());
   PM.add(createPrologEpilogCodeInserter());
   // <insert assembly code output passes here>
+  PM.add(createMachineCodeDeleter());
   return true; // change to `return false' when this actually works.
 }
 
index 83e5e102d59751a443f96ea24379866a4ed9e0b9..4a66230c5f6d85eda0c8532303d099019714c4ae 100644 (file)
@@ -212,6 +212,8 @@ namespace {
 bool X86TargetMachine::addPassesToEmitMachineCode(FunctionPassManager &PM,
                                                   MachineCodeEmitter &MCE) {
   PM.add(new Emitter(MCE));
+  // Delete machine code for this function
+  PM.add(createMachineCodeDeleter());
   return false;
 }
 
index c411f86123e98c9066a9b4acb2774fd94e135c03..83a390edaf8f137e40922189f628dcbcf639021e 100644 (file)
@@ -104,6 +104,9 @@ bool X86TargetMachine::addPassesToEmitAssembly(PassManager &PM,
   if (!DisableOutput)
     PM.add(createX86CodePrinterPass(Out, *this));
 
+  // Delete machine code for this function
+  PM.add(createMachineCodeDeleter());
+
   return false; // success!
 }