| //===-- SystemZSubtarget.h - SystemZ subtarget information -----*- 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 SystemZ specific subclass of TargetSubtargetInfo. | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 |  | 
 | #ifndef LLVM_LIB_TARGET_SYSTEMZ_SYSTEMZSUBTARGET_H | 
 | #define LLVM_LIB_TARGET_SYSTEMZ_SYSTEMZSUBTARGET_H | 
 |  | 
 | #include "SystemZFrameLowering.h" | 
 | #include "SystemZISelLowering.h" | 
 | #include "SystemZInstrInfo.h" | 
 | #include "SystemZRegisterInfo.h" | 
 | #include "SystemZSelectionDAGInfo.h" | 
 | #include "llvm/ADT/Triple.h" | 
 | #include "llvm/CodeGen/TargetSubtargetInfo.h" | 
 | #include "llvm/IR/DataLayout.h" | 
 | #include <string> | 
 |  | 
 | #define GET_SUBTARGETINFO_HEADER | 
 | #include "SystemZGenSubtargetInfo.inc" | 
 |  | 
 | namespace llvm { | 
 | class GlobalValue; | 
 | class StringRef; | 
 |  | 
 | class SystemZSubtarget : public SystemZGenSubtargetInfo { | 
 |   virtual void anchor(); | 
 | protected: | 
 |   bool HasDistinctOps; | 
 |   bool HasLoadStoreOnCond; | 
 |   bool HasHighWord; | 
 |   bool HasFPExtension; | 
 |   bool HasPopulationCount; | 
 |   bool HasMessageSecurityAssist3; | 
 |   bool HasMessageSecurityAssist4; | 
 |   bool HasResetReferenceBitsMultiple; | 
 |   bool HasFastSerialization; | 
 |   bool HasInterlockedAccess1; | 
 |   bool HasMiscellaneousExtensions; | 
 |   bool HasExecutionHint; | 
 |   bool HasLoadAndTrap; | 
 |   bool HasTransactionalExecution; | 
 |   bool HasProcessorAssist; | 
 |   bool HasDFPZonedConversion; | 
 |   bool HasEnhancedDAT2; | 
 |   bool HasVector; | 
 |   bool HasLoadStoreOnCond2; | 
 |   bool HasLoadAndZeroRightmostByte; | 
 |   bool HasMessageSecurityAssist5; | 
 |   bool HasDFPPackedConversion; | 
 |   bool HasMiscellaneousExtensions2; | 
 |   bool HasGuardedStorage; | 
 |   bool HasMessageSecurityAssist7; | 
 |   bool HasMessageSecurityAssist8; | 
 |   bool HasVectorEnhancements1; | 
 |   bool HasVectorPackedDecimal; | 
 |   bool HasInsertReferenceBitsMultiple; | 
 |  | 
 | private: | 
 |   Triple TargetTriple; | 
 |   SystemZInstrInfo InstrInfo; | 
 |   SystemZTargetLowering TLInfo; | 
 |   SystemZSelectionDAGInfo TSInfo; | 
 |   SystemZFrameLowering FrameLowering; | 
 |  | 
 |   SystemZSubtarget &initializeSubtargetDependencies(StringRef CPU, | 
 |                                                     StringRef FS); | 
 | public: | 
 |   SystemZSubtarget(const Triple &TT, const std::string &CPU, | 
 |                    const std::string &FS, const TargetMachine &TM); | 
 |  | 
 |   const TargetFrameLowering *getFrameLowering() const override { | 
 |     return &FrameLowering; | 
 |   } | 
 |   const SystemZInstrInfo *getInstrInfo() const override { return &InstrInfo; } | 
 |   const SystemZRegisterInfo *getRegisterInfo() const override { | 
 |     return &InstrInfo.getRegisterInfo(); | 
 |   } | 
 |   const SystemZTargetLowering *getTargetLowering() const override { | 
 |     return &TLInfo; | 
 |   } | 
 |   const SelectionDAGTargetInfo *getSelectionDAGInfo() const override { | 
 |     return &TSInfo; | 
 |   } | 
 |  | 
 |   // True if the subtarget should run MachineScheduler after aggressive | 
 |   // coalescing. This currently replaces the SelectionDAG scheduler with the | 
 |   // "source" order scheduler. | 
 |   bool enableMachineScheduler() const override { return true; } | 
 |  | 
 |   // This is important for reducing register pressure in vector code. | 
 |   bool useAA() const override { return true; } | 
 |  | 
 |   // Always enable the early if-conversion pass. | 
 |   bool enableEarlyIfConversion() const override { return true; } | 
 |  | 
 |   // Automatically generated by tblgen. | 
 |   void ParseSubtargetFeatures(StringRef CPU, StringRef FS); | 
 |  | 
 |   // Return true if the target has the distinct-operands facility. | 
 |   bool hasDistinctOps() const { return HasDistinctOps; } | 
 |  | 
 |   // Return true if the target has the load/store-on-condition facility. | 
 |   bool hasLoadStoreOnCond() const { return HasLoadStoreOnCond; } | 
 |  | 
 |   // Return true if the target has the load/store-on-condition facility 2. | 
 |   bool hasLoadStoreOnCond2() const { return HasLoadStoreOnCond2; } | 
 |  | 
 |   // Return true if the target has the high-word facility. | 
 |   bool hasHighWord() const { return HasHighWord; } | 
 |  | 
 |   // Return true if the target has the floating-point extension facility. | 
 |   bool hasFPExtension() const { return HasFPExtension; } | 
 |  | 
 |   // Return true if the target has the population-count facility. | 
 |   bool hasPopulationCount() const { return HasPopulationCount; } | 
 |  | 
 |   // Return true if the target has the message-security-assist | 
 |   // extension facility 3. | 
 |   bool hasMessageSecurityAssist3() const { return HasMessageSecurityAssist3; } | 
 |  | 
 |   // Return true if the target has the message-security-assist | 
 |   // extension facility 4. | 
 |   bool hasMessageSecurityAssist4() const { return HasMessageSecurityAssist4; } | 
 |  | 
 |   // Return true if the target has the reset-reference-bits-multiple facility. | 
 |   bool hasResetReferenceBitsMultiple() const { | 
 |     return HasResetReferenceBitsMultiple; | 
 |   } | 
 |  | 
 |   // Return true if the target has the fast-serialization facility. | 
 |   bool hasFastSerialization() const { return HasFastSerialization; } | 
 |  | 
 |   // Return true if the target has interlocked-access facility 1. | 
 |   bool hasInterlockedAccess1() const { return HasInterlockedAccess1; } | 
 |  | 
 |   // Return true if the target has the miscellaneous-extensions facility. | 
 |   bool hasMiscellaneousExtensions() const { | 
 |     return HasMiscellaneousExtensions; | 
 |   } | 
 |  | 
 |   // Return true if the target has the execution-hint facility. | 
 |   bool hasExecutionHint() const { return HasExecutionHint; } | 
 |  | 
 |   // Return true if the target has the load-and-trap facility. | 
 |   bool hasLoadAndTrap() const { return HasLoadAndTrap; } | 
 |  | 
 |   // Return true if the target has the transactional-execution facility. | 
 |   bool hasTransactionalExecution() const { return HasTransactionalExecution; } | 
 |  | 
 |   // Return true if the target has the processor-assist facility. | 
 |   bool hasProcessorAssist() const { return HasProcessorAssist; } | 
 |  | 
 |   // Return true if the target has the DFP zoned-conversion facility. | 
 |   bool hasDFPZonedConversion() const { return HasDFPZonedConversion; } | 
 |  | 
 |   // Return true if the target has the enhanced-DAT facility 2. | 
 |   bool hasEnhancedDAT2() const { return HasEnhancedDAT2; } | 
 |  | 
 |   // Return true if the target has the load-and-zero-rightmost-byte facility. | 
 |   bool hasLoadAndZeroRightmostByte() const { | 
 |     return HasLoadAndZeroRightmostByte; | 
 |   } | 
 |  | 
 |   // Return true if the target has the message-security-assist | 
 |   // extension facility 5. | 
 |   bool hasMessageSecurityAssist5() const { return HasMessageSecurityAssist5; } | 
 |  | 
 |   // Return true if the target has the DFP packed-conversion facility. | 
 |   bool hasDFPPackedConversion() const { return HasDFPPackedConversion; } | 
 |  | 
 |   // Return true if the target has the vector facility. | 
 |   bool hasVector() const { return HasVector; } | 
 |  | 
 |   // Return true if the target has the miscellaneous-extensions facility 2. | 
 |   bool hasMiscellaneousExtensions2() const { | 
 |     return HasMiscellaneousExtensions2; | 
 |   } | 
 |  | 
 |   // Return true if the target has the guarded-storage facility. | 
 |   bool hasGuardedStorage() const { return HasGuardedStorage; } | 
 |  | 
 |   // Return true if the target has the message-security-assist | 
 |   // extension facility 7. | 
 |   bool hasMessageSecurityAssist7() const { return HasMessageSecurityAssist7; } | 
 |  | 
 |   // Return true if the target has the message-security-assist | 
 |   // extension facility 8. | 
 |   bool hasMessageSecurityAssist8() const { return HasMessageSecurityAssist8; } | 
 |  | 
 |   // Return true if the target has the vector-enhancements facility 1. | 
 |   bool hasVectorEnhancements1() const { return HasVectorEnhancements1; } | 
 |  | 
 |   // Return true if the target has the vector-packed-decimal facility. | 
 |   bool hasVectorPackedDecimal() const { return HasVectorPackedDecimal; } | 
 |  | 
 |   // Return true if the target has the insert-reference-bits-multiple facility. | 
 |   bool hasInsertReferenceBitsMultiple() const { | 
 |     return HasInsertReferenceBitsMultiple; | 
 |   } | 
 |  | 
 |   // Return true if GV can be accessed using LARL for reloc model RM | 
 |   // and code model CM. | 
 |   bool isPC32DBLSymbol(const GlobalValue *GV, CodeModel::Model CM) const; | 
 |  | 
 |   bool isTargetELF() const { return TargetTriple.isOSBinFormatELF(); } | 
 | }; | 
 | } // end namespace llvm | 
 |  | 
 | #endif |