1*81ad6265SDimitry Andric //===-- SPIRVSubtarget.h - SPIR-V Subtarget Information --------*- C++ -*--===// 2*81ad6265SDimitry Andric // 3*81ad6265SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*81ad6265SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 5*81ad6265SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*81ad6265SDimitry Andric // 7*81ad6265SDimitry Andric //===----------------------------------------------------------------------===// 8*81ad6265SDimitry Andric // 9*81ad6265SDimitry Andric // This file declares the SPIR-V specific subclass of TargetSubtargetInfo. 10*81ad6265SDimitry Andric // 11*81ad6265SDimitry Andric //===----------------------------------------------------------------------===// 12*81ad6265SDimitry Andric 13*81ad6265SDimitry Andric #ifndef LLVM_LIB_TARGET_SPIRV_SPIRVSUBTARGET_H 14*81ad6265SDimitry Andric #define LLVM_LIB_TARGET_SPIRV_SPIRVSUBTARGET_H 15*81ad6265SDimitry Andric 16*81ad6265SDimitry Andric #include "SPIRVCallLowering.h" 17*81ad6265SDimitry Andric #include "SPIRVFrameLowering.h" 18*81ad6265SDimitry Andric #include "SPIRVISelLowering.h" 19*81ad6265SDimitry Andric #include "SPIRVInstrInfo.h" 20*81ad6265SDimitry Andric #include "llvm/CodeGen/GlobalISel/CallLowering.h" 21*81ad6265SDimitry Andric #include "llvm/CodeGen/GlobalISel/InstructionSelector.h" 22*81ad6265SDimitry Andric #include "llvm/CodeGen/GlobalISel/LegalizerInfo.h" 23*81ad6265SDimitry Andric #include "llvm/CodeGen/SelectionDAGTargetInfo.h" 24*81ad6265SDimitry Andric #include "llvm/CodeGen/TargetSubtargetInfo.h" 25*81ad6265SDimitry Andric #include "llvm/IR/DataLayout.h" 26*81ad6265SDimitry Andric #include "llvm/Target/TargetMachine.h" 27*81ad6265SDimitry Andric 28*81ad6265SDimitry Andric #define GET_SUBTARGETINFO_HEADER 29*81ad6265SDimitry Andric #include "SPIRVGenSubtargetInfo.inc" 30*81ad6265SDimitry Andric 31*81ad6265SDimitry Andric namespace llvm { 32*81ad6265SDimitry Andric class StringRef; 33*81ad6265SDimitry Andric class SPIRVGlobalRegistry; 34*81ad6265SDimitry Andric class SPIRVTargetMachine; 35*81ad6265SDimitry Andric 36*81ad6265SDimitry Andric class SPIRVSubtarget : public SPIRVGenSubtargetInfo { 37*81ad6265SDimitry Andric private: 38*81ad6265SDimitry Andric const unsigned PointerSize; 39*81ad6265SDimitry Andric uint32_t SPIRVVersion; 40*81ad6265SDimitry Andric 41*81ad6265SDimitry Andric std::unique_ptr<SPIRVGlobalRegistry> GR; 42*81ad6265SDimitry Andric 43*81ad6265SDimitry Andric SPIRVInstrInfo InstrInfo; 44*81ad6265SDimitry Andric SPIRVFrameLowering FrameLowering; 45*81ad6265SDimitry Andric SPIRVTargetLowering TLInfo; 46*81ad6265SDimitry Andric 47*81ad6265SDimitry Andric // GlobalISel related APIs. 48*81ad6265SDimitry Andric std::unique_ptr<CallLowering> CallLoweringInfo; 49*81ad6265SDimitry Andric std::unique_ptr<RegisterBankInfo> RegBankInfo; 50*81ad6265SDimitry Andric std::unique_ptr<LegalizerInfo> Legalizer; 51*81ad6265SDimitry Andric std::unique_ptr<InstructionSelector> InstSelector; 52*81ad6265SDimitry Andric 53*81ad6265SDimitry Andric public: 54*81ad6265SDimitry Andric // This constructor initializes the data members to match that 55*81ad6265SDimitry Andric // of the specified triple. 56*81ad6265SDimitry Andric SPIRVSubtarget(const Triple &TT, const std::string &CPU, 57*81ad6265SDimitry Andric const std::string &FS, const SPIRVTargetMachine &TM); 58*81ad6265SDimitry Andric SPIRVSubtarget &initSubtargetDependencies(StringRef CPU, StringRef FS); 59*81ad6265SDimitry Andric 60*81ad6265SDimitry Andric // Parses features string setting specified subtarget options. 61*81ad6265SDimitry Andric // The definition of this function is auto generated by tblgen. 62*81ad6265SDimitry Andric void ParseSubtargetFeatures(StringRef CPU, StringRef TuneCPU, StringRef FS); 63*81ad6265SDimitry Andric unsigned getPointerSize() const { return PointerSize; } 64*81ad6265SDimitry Andric bool canDirectlyComparePointers() const; 65*81ad6265SDimitry Andric uint32_t getSPIRVVersion() const { return SPIRVVersion; }; 66*81ad6265SDimitry Andric SPIRVGlobalRegistry *getSPIRVGlobalRegistry() const { return GR.get(); } 67*81ad6265SDimitry Andric 68*81ad6265SDimitry Andric const CallLowering *getCallLowering() const override { 69*81ad6265SDimitry Andric return CallLoweringInfo.get(); 70*81ad6265SDimitry Andric } 71*81ad6265SDimitry Andric const RegisterBankInfo *getRegBankInfo() const override { 72*81ad6265SDimitry Andric return RegBankInfo.get(); 73*81ad6265SDimitry Andric } 74*81ad6265SDimitry Andric const LegalizerInfo *getLegalizerInfo() const override { 75*81ad6265SDimitry Andric return Legalizer.get(); 76*81ad6265SDimitry Andric } 77*81ad6265SDimitry Andric InstructionSelector *getInstructionSelector() const override { 78*81ad6265SDimitry Andric return InstSelector.get(); 79*81ad6265SDimitry Andric } 80*81ad6265SDimitry Andric const SPIRVInstrInfo *getInstrInfo() const override { return &InstrInfo; } 81*81ad6265SDimitry Andric const SPIRVFrameLowering *getFrameLowering() const override { 82*81ad6265SDimitry Andric return &FrameLowering; 83*81ad6265SDimitry Andric } 84*81ad6265SDimitry Andric const SPIRVTargetLowering *getTargetLowering() const override { 85*81ad6265SDimitry Andric return &TLInfo; 86*81ad6265SDimitry Andric } 87*81ad6265SDimitry Andric const SPIRVRegisterInfo *getRegisterInfo() const override { 88*81ad6265SDimitry Andric return &InstrInfo.getRegisterInfo(); 89*81ad6265SDimitry Andric } 90*81ad6265SDimitry Andric }; 91*81ad6265SDimitry Andric } // namespace llvm 92*81ad6265SDimitry Andric 93*81ad6265SDimitry Andric #endif // LLVM_LIB_TARGET_SPIRV_SPIRVSUBTARGET_H 94