diff options
| author | Vikram S. Adve <vadve@cs.uiuc.edu> | 2001-07-28 04:19:10 +0000 |
|---|---|---|
| committer | Vikram S. Adve <vadve@cs.uiuc.edu> | 2001-07-28 04:19:10 +0000 |
| commit | 50204f5daaad5c031b9dbced6dfa1c38ae305a8b (patch) | |
| tree | 3ea55dda768d43ac38711d832fbf2d16e58422d5 /llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp | |
| parent | 985b6e3d13add3b881e7ac11acdb6714b44e570b (diff) | |
| download | bcm5719-llvm-50204f5daaad5c031b9dbced6dfa1c38ae305a8b.tar.gz bcm5719-llvm-50204f5daaad5c031b9dbced6dfa1c38ae305a8b.zip | |
Added UltraSparcInstrInfo class to specialize class MachineInstrInfo.
Relevant changes elsewhere:
Added MachineInstrInfo class and moved instruction-related members there.
Added several fields to MachineInstrDescriptor (and renamed it from
MachineInstrInfo. Latency fields are to support scheduling.
llvm-svn: 311
Diffstat (limited to 'llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp b/llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp index 68270fae601..a9ea1da02cc 100644 --- a/llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp +++ b/llvm/lib/CodeGen/TargetMachine/Sparc/Sparc.cpp @@ -11,27 +11,23 @@ #include "llvm/CodeGen/Sparc.h" -//************************ Exported Constants ******************************/ - - -// Set external object describing the machine instructions -// -const MachineInstrInfo* TargetMachineInstrInfo = SparcMachineInstrInfo; - - //************************ Class Implementations **************************/ + //--------------------------------------------------------------------------- // class UltraSparcMachine // // Purpose: -// Machine description. +// Primary interface to machine description for the UltraSPARC. +// Primarily just initializes machine-dependent parameters in +// class TargetMachine, and creates machine-dependent subclasses +// for classes such as MachineInstrInfo. // //--------------------------------------------------------------------------- UltraSparc::UltraSparc() - : TargetMachine() + : TargetMachine(new UltraSparcInstrInfo) { optSizeForSubWordData = 4; intSize = 4; @@ -42,8 +38,12 @@ UltraSparc::UltraSparc() pointerSize = 8; minMemOpWordSize = 8; maxAtomicMemOpWordSize = 8; - machineInstrInfo = SparcMachineInstrInfo; zeroRegNum = 0; // %g0 always gives 0 on Sparc } +UltraSparc::~UltraSparc() +{ + delete (UltraSparcInstrInfo*) machineInstrInfo; +} + //**************************************************************************/ |

