| Chris Lattner | 158e1f5 | 2006-02-05 05:50:24 +0000 | [diff] [blame] | 1 | //===- SparcInstrInfo.h - Sparc Instruction Information ---------*- C++ -*-===// | 
|  | 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 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file contains the Sparc implementation of the TargetInstrInfo class. | 
|  | 11 | // | 
|  | 12 | //===----------------------------------------------------------------------===// | 
|  | 13 |  | 
|  | 14 | #ifndef SPARCINSTRUCTIONINFO_H | 
|  | 15 | #define SPARCINSTRUCTIONINFO_H | 
|  | 16 |  | 
|  | 17 | #include "llvm/Target/TargetInstrInfo.h" | 
|  | 18 | #include "SparcRegisterInfo.h" | 
|  | 19 |  | 
|  | 20 | namespace llvm { | 
|  | 21 |  | 
|  | 22 | /// SPII - This namespace holds all of the target specific flags that | 
|  | 23 | /// instruction info tracks. | 
|  | 24 | /// | 
|  | 25 | namespace SPII { | 
|  | 26 | enum { | 
|  | 27 | Pseudo = (1<<0), | 
|  | 28 | Load = (1<<1), | 
|  | 29 | Store = (1<<2), | 
|  | 30 | DelaySlot = (1<<3) | 
|  | 31 | }; | 
| Chris Lattner | aa237256 | 2006-05-24 17:04:05 +0000 | [diff] [blame] | 32 | } | 
| Chris Lattner | 158e1f5 | 2006-02-05 05:50:24 +0000 | [diff] [blame] | 33 |  | 
|  | 34 | class SparcInstrInfo : public TargetInstrInfo { | 
|  | 35 | const SparcRegisterInfo RI; | 
|  | 36 | public: | 
|  | 37 | SparcInstrInfo(SparcSubtarget &ST); | 
|  | 38 |  | 
|  | 39 | /// getRegisterInfo - TargetInstrInfo is a superset of MRegister info.  As | 
|  | 40 | /// such, whenever a client has an instance of instruction info, it should | 
|  | 41 | /// always be able to get register info as well (through this method). | 
|  | 42 | /// | 
|  | 43 | virtual const MRegisterInfo &getRegisterInfo() const { return RI; } | 
|  | 44 |  | 
|  | 45 | /// Return true if the instruction is a register to register move and | 
|  | 46 | /// leave the source and dest operands in the passed parameters. | 
|  | 47 | /// | 
|  | 48 | virtual bool isMoveInstr(const MachineInstr &MI, | 
|  | 49 | unsigned &SrcReg, unsigned &DstReg) const; | 
|  | 50 |  | 
|  | 51 | /// isLoadFromStackSlot - If the specified machine instruction is a direct | 
|  | 52 | /// load from a stack slot, return the virtual or physical register number of | 
|  | 53 | /// the destination along with the FrameIndex of the loaded stack slot.  If | 
|  | 54 | /// not, return 0.  This predicate must return 0 if the instruction has | 
|  | 55 | /// any side effects other than loading from the stack slot. | 
|  | 56 | virtual unsigned isLoadFromStackSlot(MachineInstr *MI, int &FrameIndex) const; | 
|  | 57 |  | 
|  | 58 | /// isStoreToStackSlot - If the specified machine instruction is a direct | 
|  | 59 | /// store to a stack slot, return the virtual or physical register number of | 
|  | 60 | /// the source reg along with the FrameIndex of the loaded stack slot.  If | 
|  | 61 | /// not, return 0.  This predicate must return 0 if the instruction has | 
|  | 62 | /// any side effects other than storing to the stack slot. | 
|  | 63 | virtual unsigned isStoreToStackSlot(MachineInstr *MI, int &FrameIndex) const; | 
| Chris Lattner | b7267bd | 2006-10-24 16:39:19 +0000 | [diff] [blame] | 64 |  | 
|  | 65 |  | 
| Evan Cheng | e20dd92 | 2007-05-18 00:18:17 +0000 | [diff] [blame] | 66 | virtual unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, | 
|  | 67 | MachineBasicBlock *FBB, | 
|  | 68 | const std::vector<MachineOperand> &Cond) const; | 
| Chris Lattner | 158e1f5 | 2006-02-05 05:50:24 +0000 | [diff] [blame] | 69 | }; | 
|  | 70 |  | 
|  | 71 | } | 
|  | 72 |  | 
|  | 73 | #endif |