| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 1 | //===- MipsInstrInfo.h - Mips Instruction Information -----------*- C++ -*-===// | 
|  | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
| Chris Lattner | f3ebc3f | 2007-12-29 20:36:04 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source | 
|  | 6 | // License. See LICENSE.TXT for details. | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file contains the Mips implementation of the TargetInstrInfo class. | 
|  | 11 | // | 
|  | 12 | //===----------------------------------------------------------------------===// | 
|  | 13 |  | 
|  | 14 | #ifndef MIPSINSTRUCTIONINFO_H | 
|  | 15 | #define MIPSINSTRUCTIONINFO_H | 
|  | 16 |  | 
|  | 17 | #include "Mips.h" | 
| Torok Edwin | 56d0659 | 2009-07-11 20:10:48 +0000 | [diff] [blame] | 18 | #include "llvm/Support/ErrorHandling.h" | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 19 | #include "llvm/Target/TargetInstrInfo.h" | 
|  | 20 | #include "MipsRegisterInfo.h" | 
|  | 21 |  | 
|  | 22 | namespace llvm { | 
|  | 23 |  | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 24 | namespace Mips { | 
|  | 25 |  | 
| Bruno Cardoso Lopes | bcaf6e5 | 2008-07-28 19:11:24 +0000 | [diff] [blame] | 26 | // Mips Branch Codes | 
|  | 27 | enum FPBranchCode { | 
|  | 28 | BRANCH_F, | 
|  | 29 | BRANCH_T, | 
|  | 30 | BRANCH_FL, | 
|  | 31 | BRANCH_TL, | 
|  | 32 | BRANCH_INVALID | 
|  | 33 | }; | 
|  | 34 |  | 
| Bruno Cardoso Lopes | cfd1638 | 2007-08-28 05:06:17 +0000 | [diff] [blame] | 35 | // Mips Condition Codes | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 36 | enum CondCode { | 
| Bruno Cardoso Lopes | c9c3f49 | 2008-07-05 19:05:21 +0000 | [diff] [blame] | 37 | // To be used with float branch True | 
|  | 38 | FCOND_F, | 
|  | 39 | FCOND_UN, | 
|  | 40 | FCOND_EQ, | 
|  | 41 | FCOND_UEQ, | 
|  | 42 | FCOND_OLT, | 
|  | 43 | FCOND_ULT, | 
|  | 44 | FCOND_OLE, | 
|  | 45 | FCOND_ULE, | 
|  | 46 | FCOND_SF, | 
|  | 47 | FCOND_NGLE, | 
|  | 48 | FCOND_SEQ, | 
|  | 49 | FCOND_NGL, | 
|  | 50 | FCOND_LT, | 
|  | 51 | FCOND_NGE, | 
|  | 52 | FCOND_LE, | 
|  | 53 | FCOND_NGT, | 
|  | 54 |  | 
|  | 55 | // To be used with float branch False | 
|  | 56 | // This conditions have the same mnemonic as the | 
|  | 57 | // above ones, but are used with a branch False; | 
|  | 58 | FCOND_T, | 
|  | 59 | FCOND_OR, | 
|  | 60 | FCOND_NEQ, | 
|  | 61 | FCOND_OGL, | 
|  | 62 | FCOND_UGE, | 
|  | 63 | FCOND_OGE, | 
|  | 64 | FCOND_UGT, | 
|  | 65 | FCOND_OGT, | 
|  | 66 | FCOND_ST, | 
|  | 67 | FCOND_GLE, | 
|  | 68 | FCOND_SNE, | 
|  | 69 | FCOND_GL, | 
|  | 70 | FCOND_NLT, | 
|  | 71 | FCOND_GE, | 
|  | 72 | FCOND_NLE, | 
|  | 73 | FCOND_GT, | 
|  | 74 |  | 
|  | 75 | // Only integer conditions | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 76 | COND_E, | 
|  | 77 | COND_GZ, | 
|  | 78 | COND_GEZ, | 
|  | 79 | COND_LZ, | 
|  | 80 | COND_LEZ, | 
|  | 81 | COND_NE, | 
|  | 82 | COND_INVALID | 
|  | 83 | }; | 
|  | 84 |  | 
|  | 85 | // Turn condition code into conditional branch opcode. | 
|  | 86 | unsigned GetCondBranchFromCond(CondCode CC); | 
| Bruno Cardoso Lopes | bcaf6e5 | 2008-07-28 19:11:24 +0000 | [diff] [blame] | 87 |  | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 88 | /// GetOppositeBranchCondition - Return the inverse of the specified cond, | 
|  | 89 | /// e.g. turning COND_E to COND_NE. | 
|  | 90 | CondCode GetOppositeBranchCondition(Mips::CondCode CC); | 
|  | 91 |  | 
| Bruno Cardoso Lopes | c9c3f49 | 2008-07-05 19:05:21 +0000 | [diff] [blame] | 92 | /// MipsCCToString - Map each FP condition code to its string | 
|  | 93 | inline static const char *MipsFCCToString(Mips::CondCode CC) | 
|  | 94 | { | 
|  | 95 | switch (CC) { | 
| Torok Edwin | fbcc663 | 2009-07-14 16:55:14 +0000 | [diff] [blame] | 96 | default: llvm_unreachable("Unknown condition code"); | 
| Bruno Cardoso Lopes | c9c3f49 | 2008-07-05 19:05:21 +0000 | [diff] [blame] | 97 | case FCOND_F: | 
|  | 98 | case FCOND_T:   return "f"; | 
|  | 99 | case FCOND_UN: | 
|  | 100 | case FCOND_OR:  return "un"; | 
|  | 101 | case FCOND_EQ: | 
|  | 102 | case FCOND_NEQ: return "eq"; | 
|  | 103 | case FCOND_UEQ: | 
|  | 104 | case FCOND_OGL: return "ueq"; | 
|  | 105 | case FCOND_OLT: | 
|  | 106 | case FCOND_UGE: return "olt"; | 
|  | 107 | case FCOND_ULT: | 
|  | 108 | case FCOND_OGE: return "ult"; | 
|  | 109 | case FCOND_OLE: | 
|  | 110 | case FCOND_UGT: return "ole"; | 
|  | 111 | case FCOND_ULE: | 
|  | 112 | case FCOND_OGT: return "ule"; | 
|  | 113 | case FCOND_SF: | 
|  | 114 | case FCOND_ST:  return "sf"; | 
|  | 115 | case FCOND_NGLE: | 
|  | 116 | case FCOND_GLE: return "ngle"; | 
|  | 117 | case FCOND_SEQ: | 
|  | 118 | case FCOND_SNE: return "seq"; | 
|  | 119 | case FCOND_NGL: | 
|  | 120 | case FCOND_GL:  return "ngl"; | 
|  | 121 | case FCOND_LT: | 
|  | 122 | case FCOND_NLT: return "lt"; | 
|  | 123 | case FCOND_NGE: | 
|  | 124 | case FCOND_GE:  return "ge"; | 
|  | 125 | case FCOND_LE: | 
|  | 126 | case FCOND_NLE: return "nle"; | 
|  | 127 | case FCOND_NGT: | 
|  | 128 | case FCOND_GT:  return "gt"; | 
|  | 129 | } | 
|  | 130 | } | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 131 | } | 
|  | 132 |  | 
| Chris Lattner | 25568e4 | 2008-01-01 01:03:04 +0000 | [diff] [blame] | 133 | class MipsInstrInfo : public TargetInstrInfoImpl { | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 134 | MipsTargetMachine &TM; | 
|  | 135 | const MipsRegisterInfo RI; | 
|  | 136 | public: | 
| Dan Gohman | c60c67f | 2008-03-25 22:06:05 +0000 | [diff] [blame] | 137 | explicit MipsInstrInfo(MipsTargetMachine &TM); | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 138 |  | 
|  | 139 | /// getRegisterInfo - TargetInstrInfo is a superset of MRegister info.  As | 
|  | 140 | /// such, whenever a client has an instance of instruction info, it should | 
|  | 141 | /// always be able to get register info as well (through this method). | 
|  | 142 | /// | 
| Dan Gohman | eabd647 | 2008-05-14 01:58:56 +0000 | [diff] [blame] | 143 | virtual const MipsRegisterInfo &getRegisterInfo() const { return RI; } | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 144 |  | 
| Evan Cheng | c544cb0 | 2009-01-20 19:12:24 +0000 | [diff] [blame] | 145 | /// Return true if the instruction is a register to register move and return | 
|  | 146 | /// the source and dest operands and their sub-register indices by reference. | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 147 | virtual bool isMoveInstr(const MachineInstr &MI, | 
| Evan Cheng | c544cb0 | 2009-01-20 19:12:24 +0000 | [diff] [blame] | 148 | unsigned &SrcReg, unsigned &DstReg, | 
|  | 149 | unsigned &SrcSubIdx, unsigned &DstSubIdx) const; | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 150 |  | 
|  | 151 | /// isLoadFromStackSlot - If the specified machine instruction is a direct | 
|  | 152 | /// load from a stack slot, return the virtual or physical register number of | 
|  | 153 | /// the destination along with the FrameIndex of the loaded stack slot.  If | 
|  | 154 | /// not, return 0.  This predicate must return 0 if the instruction has | 
|  | 155 | /// any side effects other than loading from the stack slot. | 
| Dan Gohman | 0b27325 | 2008-11-18 19:49:32 +0000 | [diff] [blame] | 156 | virtual unsigned isLoadFromStackSlot(const MachineInstr *MI, | 
|  | 157 | int &FrameIndex) const; | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 158 |  | 
|  | 159 | /// isStoreToStackSlot - If the specified machine instruction is a direct | 
|  | 160 | /// store to a stack slot, return the virtual or physical register number of | 
|  | 161 | /// the source reg along with the FrameIndex of the loaded stack slot.  If | 
|  | 162 | /// not, return 0.  This predicate must return 0 if the instruction has | 
|  | 163 | /// any side effects other than storing to the stack slot. | 
| Dan Gohman | 0b27325 | 2008-11-18 19:49:32 +0000 | [diff] [blame] | 164 | virtual unsigned isStoreToStackSlot(const MachineInstr *MI, | 
|  | 165 | int &FrameIndex) const; | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 166 |  | 
|  | 167 | /// Branch Analysis | 
|  | 168 | virtual bool AnalyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, | 
|  | 169 | MachineBasicBlock *&FBB, | 
| Evan Cheng | 64dfcac | 2009-02-09 07:14:22 +0000 | [diff] [blame] | 170 | SmallVectorImpl<MachineOperand> &Cond, | 
|  | 171 | bool AllowModify) const; | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 172 | virtual unsigned RemoveBranch(MachineBasicBlock &MBB) const; | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 173 | virtual unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 174 | MachineBasicBlock *FBB, | 
| Owen Anderson | 4f6bf04 | 2008-08-14 22:49:33 +0000 | [diff] [blame] | 175 | const SmallVectorImpl<MachineOperand> &Cond) const; | 
| Owen Anderson | 27fb3dc | 2008-08-26 18:03:31 +0000 | [diff] [blame] | 176 | virtual bool copyRegToReg(MachineBasicBlock &MBB, | 
| Bruno Cardoso Lopes | 7ceec57 | 2008-07-09 04:45:36 +0000 | [diff] [blame] | 177 | MachineBasicBlock::iterator I, | 
| Owen Anderson | 7a73ae9 | 2007-12-31 06:32:00 +0000 | [diff] [blame] | 178 | unsigned DestReg, unsigned SrcReg, | 
|  | 179 | const TargetRegisterClass *DestRC, | 
|  | 180 | const TargetRegisterClass *SrcRC) const; | 
| Owen Anderson | eee1460 | 2008-01-01 21:11:32 +0000 | [diff] [blame] | 181 | virtual void storeRegToStackSlot(MachineBasicBlock &MBB, | 
|  | 182 | MachineBasicBlock::iterator MBBI, | 
|  | 183 | unsigned SrcReg, bool isKill, int FrameIndex, | 
|  | 184 | const TargetRegisterClass *RC) const; | 
|  | 185 |  | 
| Owen Anderson | eee1460 | 2008-01-01 21:11:32 +0000 | [diff] [blame] | 186 | virtual void loadRegFromStackSlot(MachineBasicBlock &MBB, | 
|  | 187 | MachineBasicBlock::iterator MBBI, | 
|  | 188 | unsigned DestReg, int FrameIndex, | 
|  | 189 | const TargetRegisterClass *RC) const; | 
|  | 190 |  | 
| Dan Gohman | 3f86b51 | 2008-12-03 18:43:12 +0000 | [diff] [blame] | 191 | virtual MachineInstr* foldMemoryOperandImpl(MachineFunction &MF, | 
|  | 192 | MachineInstr* MI, | 
|  | 193 | const SmallVectorImpl<unsigned> &Ops, | 
|  | 194 | int FrameIndex) const; | 
| Owen Anderson | 2a3be7b | 2008-01-07 01:35:02 +0000 | [diff] [blame] | 195 |  | 
| Dan Gohman | 3f86b51 | 2008-12-03 18:43:12 +0000 | [diff] [blame] | 196 | virtual MachineInstr* foldMemoryOperandImpl(MachineFunction &MF, | 
|  | 197 | MachineInstr* MI, | 
|  | 198 | const SmallVectorImpl<unsigned> &Ops, | 
|  | 199 | MachineInstr* LoadMI) const { | 
| Owen Anderson | 2a3be7b | 2008-01-07 01:35:02 +0000 | [diff] [blame] | 200 | return 0; | 
|  | 201 | } | 
|  | 202 |  | 
| Dan Gohman | 33332bc | 2008-10-16 01:49:15 +0000 | [diff] [blame] | 203 | virtual bool BlockHasNoFallThrough(const MachineBasicBlock &MBB) const; | 
| Owen Anderson | 4f6bf04 | 2008-08-14 22:49:33 +0000 | [diff] [blame] | 204 | virtual | 
|  | 205 | bool ReverseBranchCondition(SmallVectorImpl<MachineOperand> &Cond) const; | 
| Bruno Cardoso Lopes | 0c53063 | 2007-08-18 01:59:45 +0000 | [diff] [blame] | 206 |  | 
|  | 207 | /// Insert nop instruction when hazard condition is found | 
|  | 208 | virtual void insertNoop(MachineBasicBlock &MBB, | 
|  | 209 | MachineBasicBlock::iterator MI) const; | 
| Dan Gohman | d5ca7064 | 2009-06-03 20:30:14 +0000 | [diff] [blame] | 210 |  | 
|  | 211 | /// getGlobalBaseReg - Return a virtual register initialized with the | 
|  | 212 | /// the global base register value. Output instructions required to | 
|  | 213 | /// initialize the register in the function entry block, if necessary. | 
|  | 214 | /// | 
|  | 215 | unsigned getGlobalBaseReg(MachineFunction *MF) const; | 
| Bruno Cardoso Lopes | 35e43c4 | 2007-06-06 07:42:06 +0000 | [diff] [blame] | 216 | }; | 
|  | 217 |  | 
|  | 218 | } | 
|  | 219 |  | 
|  | 220 | #endif |