summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/MachineCodeForInstruction.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-02-03 07:54:50 +0000
committerChris Lattner <sabre@nondot.org>2002-02-03 07:54:50 +0000
commiteda6bd71a02adb82dff8acafb6cd6976095cc9fd (patch)
tree7551386835fb59a21ed5d6b55674c0e0713ab734 /llvm/lib/CodeGen/MachineCodeForInstruction.cpp
parent74f0a5b35ef5130316082bbf12f70c7083a17df0 (diff)
downloadbcm5719-llvm-eda6bd71a02adb82dff8acafb6cd6976095cc9fd.tar.gz
bcm5719-llvm-eda6bd71a02adb82dff8acafb6cd6976095cc9fd.zip
Code pulled out of MAchineInstr.(h|cpp)
llvm-svn: 1660
Diffstat (limited to 'llvm/lib/CodeGen/MachineCodeForInstruction.cpp')
-rw-r--r--llvm/lib/CodeGen/MachineCodeForInstruction.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/MachineCodeForInstruction.cpp b/llvm/lib/CodeGen/MachineCodeForInstruction.cpp
new file mode 100644
index 00000000000..97a53752e13
--- /dev/null
+++ b/llvm/lib/CodeGen/MachineCodeForInstruction.cpp
@@ -0,0 +1,57 @@
+//===-- MachineCodeForInstruction.cpp -------------------------------------===//
+//
+// Representation of the sequence of machine instructions created
+// for a single VM instruction. Additionally records information
+// about hidden and implicit values used by the machine instructions:
+// about hidden values used by the machine instructions:
+//
+// "Temporary values" are intermediate values used in the machine
+// instruction sequence, but not in the VM instruction
+// Note that such values should be treated as pure SSA values with
+// no interpretation of their operands (i.e., as a TmpInstruction
+// object which actually represents such a value).
+//
+// (2) "Implicit uses" are values used in the VM instruction but not in
+// the machine instruction sequence
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/CodeGen/MachineCodeForInstruction.h"
+#include "llvm/CodeGen/MachineInstr.h"
+#include "llvm/Instruction.h"
+
+static AnnotationID MCFI_AID(
+ AnnotationManager::getID("CodeGen::MachineCodeForInstruction"));
+
+static Annotation *CreateMCFI(AnnotationID AID, const Annotable *, void *) {
+ assert(AID == MCFI_AID);
+ return new MachineCodeForInstruction(); // Invoke constructor!
+}
+
+// Register the annotation with the annotation factory
+static struct Initializer {
+ Initializer() {
+ AnnotationManager::registerAnnotationFactory(MCFI_AID, &CreateMCFI);
+ }
+} RegisterAID;
+
+MachineCodeForInstruction &MachineCodeForInstruction::get(const Instruction *I){
+ return *(MachineCodeForInstruction*)I->getOrCreateAnnotation(MCFI_AID);
+}
+
+void MachineCodeForInstruction::destroy(const Instruction *I) {
+ I->deleteAnnotation(MCFI_AID);
+}
+
+
+MachineCodeForInstruction::MachineCodeForInstruction() : Annotation(MCFI_AID) {}
+
+MachineCodeForInstruction::~MachineCodeForInstruction() {
+ // Free the Value objects created to hold intermediate values
+ for (unsigned i=0, N=tempVec.size(); i < N; i++)
+ delete tempVec[i];
+
+ // Free the MachineInstr objects allocated, if any.
+ for (unsigned i=0, N = size(); i < N; i++)
+ delete (*this)[i];
+}
OpenPOWER on IntegriCloud