|  | //=====-- MipsSubtarget.h - Define Subtarget for the Mips -----*- C++ -*--====// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // This file declares the Mips specific subclass of TargetSubtarget. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef MIPSSUBTARGET_H | 
|  | #define MIPSSUBTARGET_H | 
|  |  | 
|  | #include "llvm/Target/TargetSubtarget.h" | 
|  | #include "llvm/Target/TargetMachine.h" | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | namespace llvm { | 
|  | class Module; | 
|  |  | 
|  | class MipsSubtarget : public TargetSubtarget { | 
|  |  | 
|  | public: | 
|  | enum MipsABIEnum { | 
|  | O32, O64, N32, N64, EABI | 
|  | }; | 
|  |  | 
|  | protected: | 
|  |  | 
|  | enum MipsArchEnum { | 
|  | Mips1, Mips2, Mips3, Mips4, Mips32, Mips32r2, Mips64, Mips64r2 | 
|  | }; | 
|  |  | 
|  | // Mips architecture version | 
|  | MipsArchEnum MipsArchVersion; | 
|  |  | 
|  | // Mips supported ABIs | 
|  | MipsABIEnum MipsABI; | 
|  |  | 
|  | // IsLittle - The target is Little Endian | 
|  | bool IsLittle; | 
|  |  | 
|  | // IsSingleFloat - The target only supports single precision float | 
|  | // point operations. This enable the target to use all 32 32-bit | 
|  | // floating point registers instead of only using even ones. | 
|  | bool IsSingleFloat; | 
|  |  | 
|  | // IsFP64bit - The target processor has 64-bit floating point registers. | 
|  | bool IsFP64bit; | 
|  |  | 
|  | // IsFP64bit - General-purpose registers are 64 bits wide | 
|  | bool IsGP64bit; | 
|  |  | 
|  | // HasVFPU - Processor has a vector floating point unit. | 
|  | bool HasVFPU; | 
|  |  | 
|  | // IsABICall - Enable SRV4 code for SVR4-style dynamic objects | 
|  | bool HasABICall; | 
|  |  | 
|  | // HasAbsoluteCall - Enable code that is not fully position-independent. | 
|  | // Only works with HasABICall enabled. | 
|  | bool HasAbsoluteCall; | 
|  |  | 
|  | // isLinux - Target system is Linux. Is false we consider ELFOS for now. | 
|  | bool IsLinux; | 
|  |  | 
|  | // Put global and static items less than or equal to SSectionThreshold | 
|  | // bytes into the small data or bss section. The default is 8. | 
|  | unsigned SSectionThreshold; | 
|  |  | 
|  | /// Features related to the presence of specific instructions. | 
|  |  | 
|  | // HasSEInReg - SEB and SEH (signext in register) instructions. | 
|  | bool HasSEInReg; | 
|  |  | 
|  | // HasCondMov - Conditional mov (MOVZ, MOVN) instructions. | 
|  | bool HasCondMov; | 
|  |  | 
|  | // HasMulDivAdd - Multiply add and sub (MADD, MADDu, MSUB, MSUBu) | 
|  | // instructions. | 
|  | bool HasMulDivAdd; | 
|  |  | 
|  | // HasMinMax - MIN and MAX instructions. | 
|  | bool HasMinMax; | 
|  |  | 
|  | // HasSwap - Byte and half swap instructions. | 
|  | bool HasSwap; | 
|  |  | 
|  | // HasBitCount - Count leading '1' and '0' bits. | 
|  | bool HasBitCount; | 
|  |  | 
|  | InstrItineraryData InstrItins; | 
|  |  | 
|  | public: | 
|  |  | 
|  | /// Only O32 and EABI supported right now. | 
|  | bool isABI_EABI() const { return MipsABI == EABI; } | 
|  | bool isABI_O32() const { return MipsABI == O32; } | 
|  | unsigned getTargetABI() const { return MipsABI; } | 
|  |  | 
|  | /// This constructor initializes the data members to match that | 
|  | /// of the specified module. | 
|  | MipsSubtarget(const TargetMachine &TM, const Module &M, | 
|  | const std::string &FS, bool little); | 
|  |  | 
|  | /// ParseSubtargetFeatures - Parses features string setting specified | 
|  | /// subtarget options.  Definition of function is auto generated by tblgen. | 
|  | std::string ParseSubtargetFeatures(const std::string &FS, | 
|  | const std::string &CPU); | 
|  |  | 
|  | bool isMips1() const { return MipsArchVersion == Mips1; } | 
|  |  | 
|  | bool isLittle() const { return IsLittle; } | 
|  | bool isFP64bit() const { return IsFP64bit; }; | 
|  | bool isGP64bit() const { return IsGP64bit; }; | 
|  | bool isGP32bit() const { return !IsGP64bit; }; | 
|  | bool isSingleFloat() const { return IsSingleFloat; }; | 
|  | bool isNotSingleFloat() const { return !IsSingleFloat; }; | 
|  | bool hasVFPU() const { return HasVFPU; }; | 
|  | bool hasABICall() const { return HasABICall; }; | 
|  | bool hasAbsoluteCall() const { return HasAbsoluteCall; }; | 
|  | bool isLinux() const { return IsLinux; }; | 
|  | unsigned getSSectionThreshold() const { return SSectionThreshold; } | 
|  |  | 
|  | /// Features related to the presence of specific instructions. | 
|  | bool hasSEInReg()   const { return HasSEInReg; }; | 
|  | bool hasCondMov()   const { return HasCondMov; }; | 
|  | bool hasMulDivAdd() const { return HasMulDivAdd; }; | 
|  | bool hasMinMax()    const { return HasMinMax; }; | 
|  | bool hasSwap()      const { return HasSwap; }; | 
|  | bool hasBitCount()  const { return HasBitCount; }; | 
|  | }; | 
|  | } // End llvm namespace | 
|  |  | 
|  | #endif |