|  | //===-- Nios2ISelLowering.h - Nios2 DAG Lowering Interface ------*- C++ -*-===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // This file defines the interfaces that Nios2 uses to lower LLVM code into a | 
|  | // selection DAG. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef LLVM_LIB_TARGET_NIOS2_NIOS2ISELLOWERING_H | 
|  | #define LLVM_LIB_TARGET_NIOS2_NIOS2ISELLOWERING_H | 
|  |  | 
|  | #include "Nios2.h" | 
|  | #include "llvm/CodeGen/TargetLowering.h" | 
|  |  | 
|  | namespace llvm { | 
|  | class Nios2Subtarget; | 
|  |  | 
|  | namespace Nios2ISD { | 
|  | enum NodeType { | 
|  | // Start the numbering from where ISD NodeType finishes. | 
|  | FIRST_NUMBER = ISD::BUILTIN_OP_END, | 
|  |  | 
|  | // Get the Higher 16 bits from a 32-bit immediate | 
|  | // No relation with Nios2 Hi register | 
|  | Hi, | 
|  | // Get the Lower 16 bits from a 32-bit immediate | 
|  | // No relation with Nios2 Lo register | 
|  | Lo, | 
|  | // Return | 
|  | Ret | 
|  | }; | 
|  | } | 
|  |  | 
|  | class Nios2TargetLowering : public TargetLowering { | 
|  | const Nios2Subtarget *Subtarget; | 
|  |  | 
|  | public: | 
|  | Nios2TargetLowering(const TargetMachine &TM, const Nios2Subtarget &STI); | 
|  |  | 
|  | /// getTargetNodeName - This method returns the name of a target specific | 
|  | //  DAG node. | 
|  | const char *getTargetNodeName(unsigned Opcode) const override; | 
|  |  | 
|  | SDValue LowerFormalArguments(SDValue Chain, CallingConv::ID CallConv, | 
|  | bool IsVarArg, | 
|  | const SmallVectorImpl<ISD::InputArg> &Ins, | 
|  | const SDLoc &dl, SelectionDAG &DAG, | 
|  | SmallVectorImpl<SDValue> &InVals) const override; | 
|  |  | 
|  | SDValue LowerReturn(SDValue Chain, CallingConv::ID CallConv, bool isVarArg, | 
|  | const SmallVectorImpl<ISD::OutputArg> &Outs, | 
|  | const SmallVectorImpl<SDValue> &OutVals, const SDLoc &dl, | 
|  | SelectionDAG &DAG) const override; | 
|  | }; | 
|  | } // end namespace llvm | 
|  |  | 
|  | #endif // NIOS2_ISELLOWERING_H |