| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 1 | //===-- ARMISelLowering.h - ARM DAG Lowering Interface ----------*- 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. | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file defines the interfaces that ARM uses to lower LLVM code into a | 
|  | 11 | // selection DAG. | 
|  | 12 | // | 
|  | 13 | //===----------------------------------------------------------------------===// | 
|  | 14 |  | 
|  | 15 | #ifndef ARMISELLOWERING_H | 
|  | 16 | #define ARMISELLOWERING_H | 
|  | 17 |  | 
| Rafael Espindola | fa0df55 | 2007-11-05 23:12:20 +0000 | [diff] [blame] | 18 | #include "ARMSubtarget.h" | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 19 | #include "llvm/Target/TargetLowering.h" | 
|  | 20 | #include "llvm/CodeGen/SelectionDAG.h" | 
|  | 21 | #include <vector> | 
|  | 22 |  | 
|  | 23 | namespace llvm { | 
|  | 24 | class ARMConstantPoolValue; | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 25 |  | 
|  | 26 | namespace ARMISD { | 
|  | 27 | // ARM Specific DAG Nodes | 
|  | 28 | enum NodeType { | 
|  | 29 | // Start the numbering where the builting ops and target ops leave off. | 
|  | 30 | FIRST_NUMBER = ISD::BUILTIN_OP_END+ARM::INSTRUCTION_LIST_END, | 
|  | 31 |  | 
|  | 32 | Wrapper,      // Wrapper - A wrapper node for TargetConstantPool, | 
|  | 33 | // TargetExternalSymbol, and TargetGlobalAddress. | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 34 | WrapperJT,    // WrapperJT - A wrapper node for TargetJumpTable | 
|  | 35 |  | 
|  | 36 | CALL,         // Function call. | 
| Evan Cheng | c3c949b4 | 2007-06-19 21:05:09 +0000 | [diff] [blame] | 37 | CALL_PRED,    // Function call that's predicable. | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 38 | CALL_NOLINK,  // Function call with branch not branch-and-link. | 
|  | 39 | tCALL,        // Thumb function call. | 
|  | 40 | BRCOND,       // Conditional branch. | 
|  | 41 | BR_JT,        // Jumptable branch. | 
|  | 42 | RET_FLAG,     // Return with a flag operand. | 
|  | 43 |  | 
|  | 44 | PIC_ADD,      // Add with a PC operand and a PIC label. | 
|  | 45 |  | 
|  | 46 | CMP,          // ARM compare instructions. | 
| Lauro Ramos Venancio | 6be8533 | 2007-04-02 01:30:03 +0000 | [diff] [blame] | 47 | CMPNZ,        // ARM compare that uses only N or Z flags. | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 48 | CMPFP,        // ARM VFP compare instruction, sets FPSCR. | 
|  | 49 | CMPFPw0,      // ARM VFP compare against zero instruction, sets FPSCR. | 
|  | 50 | FMSTAT,       // ARM fmstat instruction. | 
|  | 51 | CMOV,         // ARM conditional move instructions. | 
|  | 52 | CNEG,         // ARM conditional negate instructions. | 
|  | 53 |  | 
|  | 54 | FTOSI,        // FP to sint within a FP register. | 
|  | 55 | FTOUI,        // FP to uint within a FP register. | 
|  | 56 | SITOF,        // sint to FP within a FP register. | 
|  | 57 | UITOF,        // uint to FP within a FP register. | 
|  | 58 |  | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 59 | SRL_FLAG,     // V,Flag = srl_flag X -> srl X, 1 + save carry out. | 
|  | 60 | SRA_FLAG,     // V,Flag = sra_flag X -> sra X, 1 + save carry out. | 
|  | 61 | RRX,          // V = RRX X, Flag     -> srl X, 1 + shift in carry flag. | 
|  | 62 |  | 
|  | 63 | FMRRD,        // double to two gprs. | 
| Lauro Ramos Venancio | c39c12a | 2007-04-27 13:54:47 +0000 | [diff] [blame] | 64 | FMDRR,         // Two gprs to double. | 
|  | 65 |  | 
|  | 66 | THREAD_POINTER | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 67 | }; | 
|  | 68 | } | 
|  | 69 |  | 
|  | 70 | //===----------------------------------------------------------------------===// | 
| Dale Johannesen | 8447d34 | 2007-03-20 00:30:56 +0000 | [diff] [blame] | 71 | //  ARMTargetLowering - ARM Implementation of the TargetLowering interface | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 72 |  | 
|  | 73 | class ARMTargetLowering : public TargetLowering { | 
|  | 74 | int VarArgsFrameIndex;            // FrameIndex for start of varargs area. | 
|  | 75 | public: | 
| Dan Gohman | 5f6a9da5 | 2007-08-02 21:21:54 +0000 | [diff] [blame] | 76 | explicit ARMTargetLowering(TargetMachine &TM); | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 77 |  | 
|  | 78 | virtual SDOperand LowerOperation(SDOperand Op, SelectionDAG &DAG); | 
| Chris Lattner | f81d588 | 2007-11-24 07:07:01 +0000 | [diff] [blame] | 79 | virtual SDNode *ExpandOperationResult(SDNode *N, SelectionDAG &DAG); | 
|  | 80 |  | 
| Nate Begeman | 5420516 | 2008-02-04 23:04:24 +0000 | [diff] [blame] | 81 | virtual SDOperand PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const; | 
| Chris Lattner | f3f4ad9 | 2007-11-27 22:36:16 +0000 | [diff] [blame] | 82 |  | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 83 | virtual const char *getTargetNodeName(unsigned Opcode) const; | 
|  | 84 |  | 
| Evan Cheng | 29cfb67 | 2008-01-30 18:18:23 +0000 | [diff] [blame] | 85 | virtual MachineBasicBlock *EmitInstrWithCustomInserter(MachineInstr *MI, | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 86 | MachineBasicBlock *MBB); | 
|  | 87 |  | 
| Chris Lattner | 1eb94d9 | 2007-03-30 23:15:24 +0000 | [diff] [blame] | 88 | /// isLegalAddressingMode - Return true if the addressing mode represented | 
|  | 89 | /// by AM is legal for this target, for a load/store of the specified type. | 
|  | 90 | virtual bool isLegalAddressingMode(const AddrMode &AM, const Type *Ty)const; | 
|  | 91 |  | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 92 | /// getPreIndexedAddressParts - returns true by value, base pointer and | 
|  | 93 | /// offset pointer and addressing mode by reference if the node's address | 
|  | 94 | /// can be legally represented as pre-indexed load / store address. | 
|  | 95 | virtual bool getPreIndexedAddressParts(SDNode *N, SDOperand &Base, | 
|  | 96 | SDOperand &Offset, | 
|  | 97 | ISD::MemIndexedMode &AM, | 
|  | 98 | SelectionDAG &DAG); | 
|  | 99 |  | 
|  | 100 | /// getPostIndexedAddressParts - returns true by value, base pointer and | 
|  | 101 | /// offset pointer and addressing mode by reference if this node can be | 
|  | 102 | /// combined with a load / store to form a post-indexed load / store. | 
|  | 103 | virtual bool getPostIndexedAddressParts(SDNode *N, SDNode *Op, | 
|  | 104 | SDOperand &Base, SDOperand &Offset, | 
|  | 105 | ISD::MemIndexedMode &AM, | 
|  | 106 | SelectionDAG &DAG); | 
|  | 107 |  | 
|  | 108 | virtual void computeMaskedBitsForTargetNode(const SDOperand Op, | 
| Dan Gohman | e1d9ee6 | 2008-02-13 22:28:48 +0000 | [diff] [blame] | 109 | const APInt &Mask, | 
| Dan Gohman | f990faf | 2008-02-13 00:35:47 +0000 | [diff] [blame] | 110 | APInt &KnownZero, | 
|  | 111 | APInt &KnownOne, | 
| Dan Gohman | 309d3d5 | 2007-06-22 14:59:07 +0000 | [diff] [blame] | 112 | const SelectionDAG &DAG, | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 113 | unsigned Depth) const; | 
| Chris Lattner | d685514 | 2007-03-25 02:14:49 +0000 | [diff] [blame] | 114 | ConstraintType getConstraintType(const std::string &Constraint) const; | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 115 | std::pair<unsigned, const TargetRegisterClass*> | 
|  | 116 | getRegForInlineAsmConstraint(const std::string &Constraint, | 
|  | 117 | MVT::ValueType VT) const; | 
|  | 118 | std::vector<unsigned> | 
|  | 119 | getRegClassForInlineAsmConstraint(const std::string &Constraint, | 
|  | 120 | MVT::ValueType VT) const; | 
| Rafael Espindola | fa0df55 | 2007-11-05 23:12:20 +0000 | [diff] [blame] | 121 |  | 
|  | 122 | virtual const TargetSubtarget* getSubtarget() { | 
|  | 123 | return static_cast<const TargetSubtarget*>(Subtarget); | 
|  | 124 | } | 
|  | 125 |  | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 126 | private: | 
|  | 127 | /// Subtarget - Keep a pointer to the ARMSubtarget around so that we can | 
|  | 128 | /// make the right decision when generating code for different targets. | 
|  | 129 | const ARMSubtarget *Subtarget; | 
|  | 130 |  | 
|  | 131 | /// ARMPCLabelIndex - Keep track the number of ARM PC labels created. | 
|  | 132 | /// | 
|  | 133 | unsigned ARMPCLabelIndex; | 
|  | 134 |  | 
|  | 135 | SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG); | 
| Lauro Ramos Venancio | ee2d164 | 2007-04-22 00:04:12 +0000 | [diff] [blame] | 136 | SDOperand LowerGlobalAddressDarwin(SDOperand Op, SelectionDAG &DAG); | 
|  | 137 | SDOperand LowerGlobalAddressELF(SDOperand Op, SelectionDAG &DAG); | 
| Lauro Ramos Venancio | c39c12a | 2007-04-27 13:54:47 +0000 | [diff] [blame] | 138 | SDOperand LowerGlobalTLSAddress(SDOperand Op, SelectionDAG &DAG); | 
|  | 139 | SDOperand LowerToTLSGeneralDynamicModel(GlobalAddressSDNode *GA, | 
|  | 140 | SelectionDAG &DAG); | 
|  | 141 | SDOperand LowerToTLSExecModels(GlobalAddressSDNode *GA, | 
| Evan Cheng | 1f2dd35 | 2007-10-22 22:11:27 +0000 | [diff] [blame] | 142 | SelectionDAG &DAG); | 
| Lauro Ramos Venancio | ee2d164 | 2007-04-22 00:04:12 +0000 | [diff] [blame] | 143 | SDOperand LowerGLOBAL_OFFSET_TABLE(SDOperand Op, SelectionDAG &DAG); | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 144 | SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG); | 
|  | 145 | SDOperand LowerBR_JT(SDOperand Op, SelectionDAG &DAG); | 
| Rafael Espindola | 18a831d | 2007-10-19 14:35:17 +0000 | [diff] [blame] | 146 | SDOperand LowerMEMCPYInline(SDOperand Chain, SDOperand Dest, | 
|  | 147 | SDOperand Source, unsigned Size, | 
|  | 148 | unsigned Align, SelectionDAG &DAG); | 
|  | 149 |  | 
|  | 150 |  | 
| Evan Cheng | 10043e2 | 2007-01-19 07:51:42 +0000 | [diff] [blame] | 151 | }; | 
|  | 152 | } | 
|  | 153 |  | 
|  | 154 | #endif  // ARMISELLOWERING_H |