X86ISelLowering.h revision 368e18d56a87308045d341e85584597bfe7426e9
1dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//===-- X86ISelLowering.h - X86 DAG Lowering Interface ----------*- C++ -*-===//
2dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//
3dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//                     The LLVM Compiler Infrastructure
4dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//
5dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner// This file was developed by Chris Lattner and is distributed under
6dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner// the University of Illinois Open Source License. See LICENSE.TXT for details.
7dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//
8dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//===----------------------------------------------------------------------===//
9dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//
10dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner// This file defines the interfaces that X86 uses to lower LLVM code into a
11dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner// selection DAG.
12dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//
13dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner//===----------------------------------------------------------------------===//
14dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
15dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner#ifndef X86ISELLOWERING_H
16dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner#define X86ISELLOWERING_H
17dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
18559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng#include "X86Subtarget.h"
19dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner#include "llvm/Target/TargetLowering.h"
20dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner#include "llvm/CodeGen/SelectionDAG.h"
21dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
22dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattnernamespace llvm {
23dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  namespace X86ISD {
24d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng    // X86 Specific DAG Nodes
25dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    enum NodeType {
26dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      // Start the numbering where the builtin ops leave off.
277df96d66729d1f33934de7b52553e5f071686041Evan Cheng      FIRST_NUMBER = ISD::BUILTIN_OP_END+X86::INSTRUCTION_LIST_END,
28dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
29e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// ADD_FLAG, SUB_FLAG - Same as ISD::ADD and ISD::SUB except it also
30e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// produces a flag result.
31e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      ADD_FLAG,
32e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      SUB_FLAG,
33e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng
34e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// ADC, SBB - Add with carry and subtraction with borrow. These
35e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// correspond to X86::ADCxx and X86::SBBxx instructions.
36e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      ADC,
37e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      SBB,
38e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng
39e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// SHLD, SHRD - Double shift instructions. These correspond to
40e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// X86::SHLDxx and X86::SHRDxx instructions.
41e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      SHLD,
42e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      SHRD,
43e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng
44ef6ffb17c71232af5962f9926b31508eb942cddcEvan Cheng      /// FAND - Bitwise logical AND of floating point values. This corresponds
45ef6ffb17c71232af5962f9926b31508eb942cddcEvan Cheng      /// to X86::ANDPS or X86::ANDPD.
46ef6ffb17c71232af5962f9926b31508eb942cddcEvan Cheng      FAND,
47ef6ffb17c71232af5962f9926b31508eb942cddcEvan Cheng
48223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng      /// FXOR - Bitwise logical XOR of floating point values. This corresponds
49223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng      /// to X86::XORPS or X86::XORPD.
50223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng      FXOR,
51223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng
52e3de85b447b0a94c82f147159a0c903ea47e0069Evan Cheng      /// FILD, FILD_FLAG - This instruction implements SINT_TO_FP with the
53e3de85b447b0a94c82f147159a0c903ea47e0069Evan Cheng      /// integer source in memory and FP reg result.  This corresponds to the
54e3de85b447b0a94c82f147159a0c903ea47e0069Evan Cheng      /// X86::FILD*m instructions. It has three inputs (token chain, address,
55e3de85b447b0a94c82f147159a0c903ea47e0069Evan Cheng      /// and source type) and two outputs (FP value and token chain). FILD_FLAG
56e3de85b447b0a94c82f147159a0c903ea47e0069Evan Cheng      /// also produces a flag).
57a3195e86439896ecba9b3f2afce40919b20a987aEvan Cheng      FILD,
58e3de85b447b0a94c82f147159a0c903ea47e0069Evan Cheng      FILD_FLAG,
59dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
60dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// FP_TO_INT*_IN_MEM - This instruction implements FP_TO_SINT with the
61dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// integer destination in memory and a FP reg source.  This corresponds
62dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// to the X86::FIST*m instructions and the rounding mode change stuff. It
63a3195e86439896ecba9b3f2afce40919b20a987aEvan Cheng      /// has two inputs (token chain and address) and two outputs (int value and
64dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// token chain).
65dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      FP_TO_INT16_IN_MEM,
66dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      FP_TO_INT32_IN_MEM,
67dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      FP_TO_INT64_IN_MEM,
68dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
69b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      /// FLD - This instruction implements an extending load to FP stack slots.
70b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      /// This corresponds to the X86::FLD32m / X86::FLD64m. It takes a chain
7138bcbaf23e8836c8f64e7fd66ebebc44a2b921a1Evan Cheng      /// operand, ptr to load from, and a ValueType node indicating the type
7238bcbaf23e8836c8f64e7fd66ebebc44a2b921a1Evan Cheng      /// to load to.
73b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      FLD,
74b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng
75d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// FST - This instruction implements a truncating store to FP stack
76d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// slots. This corresponds to the X86::FST32m / X86::FST64m. It takes a
77d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// chain operand, value to store, address, and a ValueType to store it
78d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// as.
79d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      FST,
80d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng
81d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// FP_SET_RESULT - This corresponds to FpGETRESULT pseudo instrcuction
82d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// which copies from ST(0) to the destination. It takes a chain and writes
83d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      /// a RFP result and a chain.
84d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng      FP_GET_RESULT,
85d90eb7fb2435e2abedb4694edc44fa45642edbe9Evan Cheng
86b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      /// FP_SET_RESULT - This corresponds to FpSETRESULT pseudo instrcuction
87b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      /// which copies the source operand to ST(0). It takes a chain and writes
88b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      /// a chain and a flag.
89b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      FP_SET_RESULT,
90b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng
91dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// CALL/TAILCALL - These operations represent an abstract X86 call
92dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// instruction, which includes a bunch of information.  In particular the
93dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// operands of these node are:
94dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///
95dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #0 - The incoming token chain
96dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #1 - The callee
97dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #2 - The number of arg bytes the caller pushes on the stack.
98dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #3 - The number of arg bytes the callee pops off the stack.
99dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #4 - The value to pass in AL/AX/EAX (optional)
100dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #5 - The value to pass in DL/DX/EDX (optional)
101dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///
102dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// The result values of these nodes are:
103dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///
104dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #0 - The outgoing token chain
105dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #1 - The first register result value (optional)
106dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///     #2 - The second register result value (optional)
107dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      ///
108dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// The CALL vs TAILCALL distinction boils down to whether the callee is
109dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// known not to modify the caller's stack frame, as is standard with
110dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      /// LLVM.
111dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      CALL,
112dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner      TAILCALL,
113b873ff322c28ce097762355921100b677c71238dAndrew Lenharth
114b873ff322c28ce097762355921100b677c71238dAndrew Lenharth      /// RDTSC_DAG - This operation implements the lowering for
115b873ff322c28ce097762355921100b677c71238dAndrew Lenharth      /// readcyclecounter
116b873ff322c28ce097762355921100b677c71238dAndrew Lenharth      RDTSC_DAG,
1177df96d66729d1f33934de7b52553e5f071686041Evan Cheng
1187df96d66729d1f33934de7b52553e5f071686041Evan Cheng      /// X86 compare and logical compare instructions.
1197df96d66729d1f33934de7b52553e5f071686041Evan Cheng      CMP, TEST,
1207df96d66729d1f33934de7b52553e5f071686041Evan Cheng
121d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// X86 SetCC. Operand 1 is condition code, and operand 2 is the flag
122d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// operand produced by a CMP instruction.
123d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      SETCC,
124d5781fca4f8f98863560338d4f8d017389428119Evan Cheng
125d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// X86 conditional moves. Operand 1 and operand 2 are the two values
126d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// to select from (operand 1 is a R/W operand). Operand 3 is the condition
127d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// code, and operand 4 is the flag operand produced by a CMP or TEST
128e3413160ca2fb42854b2a23be6b2114c1da2778cEvan Cheng      /// instruction. It also writes a flag result.
1297df96d66729d1f33934de7b52553e5f071686041Evan Cheng      CMOV,
130898101c15fa11a896deb4e2fcb73b4727e1dcc1fEvan Cheng
131d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// X86 conditional branches. Operand 1 is the chain operand, operand 2
132d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// is the block to branch if condition is true, operand 3 is the
133d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// condition code, and operand 4 is the flag operand produced by a CMP
134d5781fca4f8f98863560338d4f8d017389428119Evan Cheng      /// or TEST instruction.
135898101c15fa11a896deb4e2fcb73b4727e1dcc1fEvan Cheng      BRCOND,
136b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng
13767f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng      /// Return with a flag operand. Operand 1 is the chain operand, operand
13867f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng      /// 2 is the number of bytes of stack to pop.
139b077b842b64af39c8e2e9aaad327b3be446790ddEvan Cheng      RET_FLAG,
14067f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng
14167f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng      /// REP_STOS - Repeat fill, corresponds to X86::REP_STOSx.
14267f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng      REP_STOS,
14367f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng
14467f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng      /// REP_MOVS - Repeat move, corresponds to X86::REP_MOVSx.
14567f92a76497d1f50e0dd6279c81b45689bd463f5Evan Cheng      REP_MOVS,
146223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng
147223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng      /// LOAD_PACK Load a 128-bit packed float / double value. It has the same
148223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng      /// operands as a normal load.
149223547ab3101f32252cb704a67bd757e00fdbd16Evan Cheng      LOAD_PACK,
150dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    };
151d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng
152d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng    // X86 specific condition code. These correspond to X86_*_COND in
153d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng    // X86InstrInfo.td. They must be kept in synch.
154d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng    enum CondCode {
155d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_A  = 0,
156d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_AE = 1,
157d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_B  = 2,
158d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_BE = 3,
159d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_E  = 4,
160d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_G  = 5,
161d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_GE = 6,
162d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_L  = 7,
163d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_LE = 8,
164d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_NE = 9,
165d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_NO = 10,
166d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_NP = 11,
167d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_NS = 12,
168d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_O  = 13,
169d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_P  = 14,
170d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_S  = 15,
171d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng      COND_INVALID
172d9558e0ba6ddcf2798cfb88cc56e5f1c8135eb0dEvan Cheng    };
173dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  }
174dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
175dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  //===----------------------------------------------------------------------===//
176dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  //  X86TargetLowering - X86 Implementation of the TargetLowering interface
177dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  class X86TargetLowering : public TargetLowering {
178dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    int VarArgsFrameIndex;            // FrameIndex for start of varargs area.
179dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    int ReturnAddrIndex;              // FrameIndex for return slot.
180dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    int BytesToPopOnReturn;           // Number of arg bytes ret should pop.
181dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    int BytesCallerReserves;          // Number of arg bytes caller makes.
182dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  public:
183dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    X86TargetLowering(TargetMachine &TM);
184dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
185dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    // Return the number of bytes that a function should pop when it returns (in
186dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    // addition to the space used by the return address).
187dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    //
188dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    unsigned getBytesToPopOnReturn() const { return BytesToPopOnReturn; }
189dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
190dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    // Return the number of bytes that the caller reserves for arguments passed
191dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    // to this function.
192dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    unsigned getBytesCallerReserves() const { return BytesCallerReserves; }
193dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
194dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    /// LowerOperation - Provide custom lowering hooks for some operations.
195dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    ///
196dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    virtual SDOperand LowerOperation(SDOperand Op, SelectionDAG &DAG);
197dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
198dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    /// LowerArguments - This hook must be implemented to indicate how we should
199dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    /// lower the arguments for the specified function, into the specified DAG.
200dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    virtual std::vector<SDOperand>
201dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    LowerArguments(Function &F, SelectionDAG &DAG);
202dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
203dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    /// LowerCallTo - This hook lowers an abstract call to a function into an
204dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    /// actual call.
205dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    virtual std::pair<SDOperand, SDOperand>
206dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    LowerCallTo(SDOperand Chain, const Type *RetTy, bool isVarArg, unsigned CC,
207dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner                bool isTailCall, SDOperand Callee, ArgListTy &Args,
208dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner                SelectionDAG &DAG);
209dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
210dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    virtual std::pair<SDOperand, SDOperand>
211dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    LowerFrameReturnAddress(bool isFrameAddr, SDOperand Chain, unsigned Depth,
212dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner                            SelectionDAG &DAG);
213dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
2144a46080fe0133c71b511805c63abfb158dcd56a5Evan Cheng    virtual MachineBasicBlock *InsertAtEndOfBasicBlock(MachineInstr *MI,
2154a46080fe0133c71b511805c63abfb158dcd56a5Evan Cheng                                                       MachineBasicBlock *MBB);
2164a46080fe0133c71b511805c63abfb158dcd56a5Evan Cheng
2177226158d7e3986e55b58214a749aa4eabb3fb6d5Evan Cheng    /// getTargetNodeName - This method returns the name of a target specific
2187226158d7e3986e55b58214a749aa4eabb3fb6d5Evan Cheng    /// DAG node.
2197226158d7e3986e55b58214a749aa4eabb3fb6d5Evan Cheng    virtual const char *getTargetNodeName(unsigned Opcode) const;
2207226158d7e3986e55b58214a749aa4eabb3fb6d5Evan Cheng
221368e18d56a87308045d341e85584597bfe7426e9Nate Begeman    /// computeMaskedBitsForTargetNode - Determine which of the bits specified
222368e18d56a87308045d341e85584597bfe7426e9Nate Begeman    /// in Mask are known to be either zero or one and return them in the
223368e18d56a87308045d341e85584597bfe7426e9Nate Begeman    /// KnownZero/KnownOne bitsets.
224368e18d56a87308045d341e85584597bfe7426e9Nate Begeman    virtual void computeMaskedBitsForTargetNode(const SDOperand Op,
225368e18d56a87308045d341e85584597bfe7426e9Nate Begeman                                                uint64_t Mask,
226368e18d56a87308045d341e85584597bfe7426e9Nate Begeman                                                uint64_t &KnownZero,
227368e18d56a87308045d341e85584597bfe7426e9Nate Begeman                                                uint64_t &KnownOne,
228368e18d56a87308045d341e85584597bfe7426e9Nate Begeman                                                unsigned Depth = 0) const;
229368e18d56a87308045d341e85584597bfe7426e9Nate Begeman
230dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    SDOperand getReturnAddressFrameIndex(SelectionDAG &DAG);
231dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
232259e97cc725011a3c138563d421a4654b082a64cChris Lattner    std::vector<unsigned>
233259e97cc725011a3c138563d421a4654b082a64cChris Lattner      getRegForInlineAsmConstraint(const std::string &Constraint) const;
234dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  private:
235dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    // C Calling Convention implementation.
236dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    std::vector<SDOperand> LowerCCCArguments(Function &F, SelectionDAG &DAG);
237dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    std::pair<SDOperand, SDOperand>
238dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    LowerCCCCallTo(SDOperand Chain, const Type *RetTy, bool isVarArg,
239dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner                   bool isTailCall,
240dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner                   SDOperand Callee, ArgListTy &Args, SelectionDAG &DAG);
241dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
242dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    // Fast Calling Convention implementation.
243dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    std::vector<SDOperand> LowerFastCCArguments(Function &F, SelectionDAG &DAG);
244dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    std::pair<SDOperand, SDOperand>
245dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner    LowerFastCCCallTo(SDOperand Chain, const Type *RetTy, bool isTailCall,
246dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner                      SDOperand Callee, ArgListTy &Args, SelectionDAG &DAG);
247559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng
248559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng    /// Subtarget - Keep a pointer to the X86Subtarget around so that we can
249559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng    /// make the right decision when generating code for different targets.
250559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng    const X86Subtarget *Subtarget;
251559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng
252559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng    /// X86ScalarSSE - Select between SSE2 or x87 floating point ops.
253559806f575297866609c7bef0e5c1084dcdda9a5Evan Cheng    bool X86ScalarSSE;
254dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner  };
255dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner}
256dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner
257dbdbf0ce2eef7b6585397121f56d3845e04866d1Chris Lattner#endif    // X86ISELLOWERING_H
258