Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 1 | //===-- MachineCodeForInstruction.cpp -------------------------------------===// |
John Criswell | b576c94 | 2003-10-20 19:43:21 +0000 | [diff] [blame] | 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file was developed by the LLVM research group and is distributed under |
| 6 | // the University of Illinois Open Source License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 9 | // |
Chris Lattner | 51a8d85 | 2002-10-28 01:21:55 +0000 | [diff] [blame] | 10 | // Representation of the sequence of machine instructions created for a single |
| 11 | // VM instruction. Additionally records information about hidden and implicit |
| 12 | // values used by the machine instructions: about hidden values used by the |
| 13 | // machine instructions: |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 14 | // |
Chris Lattner | 51a8d85 | 2002-10-28 01:21:55 +0000 | [diff] [blame] | 15 | // "Temporary values" are intermediate values used in the machine instruction |
Brian Gaeke | cdd69e6 | 2004-05-30 03:33:48 +0000 | [diff] [blame] | 16 | // sequence, but not in the VM instruction. Note that such values should be |
Chris Lattner | 51a8d85 | 2002-10-28 01:21:55 +0000 | [diff] [blame] | 17 | // treated as pure SSA values with no interpretation of their operands (i.e., as |
| 18 | // a TmpInstruction object which actually represents such a value). |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 19 | // |
Chris Lattner | 51a8d85 | 2002-10-28 01:21:55 +0000 | [diff] [blame] | 20 | // (2) "Implicit uses" are values used in the VM instruction but not in the |
| 21 | // machine instruction sequence |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 22 | // |
| 23 | //===----------------------------------------------------------------------===// |
| 24 | |
| 25 | #include "llvm/CodeGen/MachineCodeForInstruction.h" |
Chris Lattner | 4e7244e | 2004-06-27 18:52:17 +0000 | [diff] [blame] | 26 | #include "llvm/Function.h" |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 27 | #include "llvm/CodeGen/MachineInstr.h" |
Chris Lattner | 4e7244e | 2004-06-27 18:52:17 +0000 | [diff] [blame] | 28 | #include "llvm/CodeGen/MachineFunction.h" |
| 29 | #include "llvm/CodeGen/MachineFunctionInfo.h" |
Chris Lattner | c81295a | 2004-02-29 21:40:53 +0000 | [diff] [blame] | 30 | #include "../Target/SparcV9/MachineInstrAnnot.h" |
Chris Lattner | d5da197 | 2004-01-09 06:30:18 +0000 | [diff] [blame] | 31 | using namespace llvm; |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 32 | |
Chris Lattner | 585911e | 2004-02-29 19:02:39 +0000 | [diff] [blame] | 33 | MachineCodeForInstruction &MachineCodeForInstruction::get(const Instruction *I){ |
Chris Lattner | 4e7244e | 2004-06-27 18:52:17 +0000 | [diff] [blame] | 34 | MachineFunction &MF = MachineFunction::get(I->getParent()->getParent()); |
| 35 | return MF.getInfo()->MCFIEntries[I]; |
Chris Lattner | 585911e | 2004-02-29 19:02:39 +0000 | [diff] [blame] | 36 | } |
| 37 | void MachineCodeForInstruction::destroy(const Instruction *I) { |
Chris Lattner | 4e7244e | 2004-06-27 18:52:17 +0000 | [diff] [blame] | 38 | MachineFunction &MF = MachineFunction::get(I->getParent()->getParent()); |
| 39 | MF.getInfo()->MCFIEntries.erase(I); |
Chris Lattner | 585911e | 2004-02-29 19:02:39 +0000 | [diff] [blame] | 40 | } |
| 41 | |
Vikram S. Adve | ded1bf8 | 2002-03-24 03:40:11 +0000 | [diff] [blame] | 42 | void |
| 43 | MachineCodeForInstruction::dropAllReferences() |
| 44 | { |
| 45 | for (unsigned i=0, N=tempVec.size(); i < N; i++) |
Chris Lattner | ae7fc3a | 2004-01-10 19:16:26 +0000 | [diff] [blame] | 46 | cast<Instruction>(tempVec[i])->dropAllReferences(); |
Vikram S. Adve | ded1bf8 | 2002-03-24 03:40:11 +0000 | [diff] [blame] | 47 | } |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 48 | |
Vikram S. Adve | ded1bf8 | 2002-03-24 03:40:11 +0000 | [diff] [blame] | 49 | |
Chris Lattner | d5da197 | 2004-01-09 06:30:18 +0000 | [diff] [blame] | 50 | MachineCodeForInstruction::~MachineCodeForInstruction() { |
Vikram S. Adve | ded1bf8 | 2002-03-24 03:40:11 +0000 | [diff] [blame] | 51 | // Let go of all uses in temp. instructions |
| 52 | dropAllReferences(); |
| 53 | |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 54 | // Free the Value objects created to hold intermediate values |
| 55 | for (unsigned i=0, N=tempVec.size(); i < N; i++) |
| 56 | delete tempVec[i]; |
| 57 | |
Alkis Evlogimenos | c0b9dc5 | 2004-02-12 02:27:10 +0000 | [diff] [blame] | 58 | // do not free the MachineInstr objects allocated. they are managed |
| 59 | // by the ilist in MachineBasicBlock |
Vikram S. Adve | e68a343 | 2002-10-29 19:38:46 +0000 | [diff] [blame] | 60 | |
| 61 | // Free the CallArgsDescriptor if it exists. |
Chris Lattner | d5da197 | 2004-01-09 06:30:18 +0000 | [diff] [blame] | 62 | delete callArgsDesc; |
Chris Lattner | f2868ce | 2002-02-03 07:54:50 +0000 | [diff] [blame] | 63 | } |