| //===-- SPIRVSubtarget.h - SPIR-V Subtarget Information --------*- C++ -*--===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file declares the SPIR-V specific subclass of TargetSubtargetInfo. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_LIB_TARGET_SPIRV_SPIRVSUBTARGET_H |
| #define LLVM_LIB_TARGET_SPIRV_SPIRVSUBTARGET_H |
| |
| #include "SPIRVCallLowering.h" |
| #include "SPIRVFrameLowering.h" |
| #include "SPIRVISelLowering.h" |
| #include "SPIRVInstrInfo.h" |
| #include "llvm/CodeGen/GlobalISel/CallLowering.h" |
| #include "llvm/CodeGen/GlobalISel/InstructionSelector.h" |
| #include "llvm/CodeGen/GlobalISel/LegalizerInfo.h" |
| #include "llvm/CodeGen/SelectionDAGTargetInfo.h" |
| #include "llvm/CodeGen/TargetSubtargetInfo.h" |
| #include "llvm/IR/DataLayout.h" |
| #include "llvm/Target/TargetMachine.h" |
| |
| #define GET_SUBTARGETINFO_HEADER |
| #include "SPIRVGenSubtargetInfo.inc" |
| |
| namespace llvm { |
| class StringRef; |
| class SPIRVTargetMachine; |
| |
| class SPIRVSubtarget : public SPIRVGenSubtargetInfo { |
| private: |
| const unsigned PointerSize; |
| uint32_t SPIRVVersion; |
| uint32_t OpenCLVersion; |
| |
| SmallSet<SPIRV::Extension::Extension, 4> AvailableExtensions; |
| SmallSet<SPIRV::InstructionSet::InstructionSet, 4> AvailableExtInstSets; |
| std::unique_ptr<SPIRVGlobalRegistry> GR; |
| |
| SPIRVInstrInfo InstrInfo; |
| SPIRVFrameLowering FrameLowering; |
| SPIRVTargetLowering TLInfo; |
| |
| // GlobalISel related APIs. |
| std::unique_ptr<CallLowering> CallLoweringInfo; |
| std::unique_ptr<RegisterBankInfo> RegBankInfo; |
| std::unique_ptr<LegalizerInfo> Legalizer; |
| std::unique_ptr<InstructionSelector> InstSelector; |
| |
| // TODO: Initialise the available extensions, extended instruction sets |
| // based on the environment settings. |
| void initAvailableExtensions(); |
| void initAvailableExtInstSets(); |
| |
| public: |
| // This constructor initializes the data members to match that |
| // of the specified triple. |
| SPIRVSubtarget(const Triple &TT, const std::string &CPU, |
| const std::string &FS, const SPIRVTargetMachine &TM); |
| SPIRVSubtarget &initSubtargetDependencies(StringRef CPU, StringRef FS); |
| |
| // Parses features string setting specified subtarget options. |
| // The definition of this function is auto generated by tblgen. |
| void ParseSubtargetFeatures(StringRef CPU, StringRef TuneCPU, StringRef FS); |
| unsigned getPointerSize() const { return PointerSize; } |
| bool canDirectlyComparePointers() const; |
| // TODO: this environment is not implemented in Triple, we need to decide |
| // how to standartize its support. For now, let's assume that we always |
| // operate with OpenCL. |
| bool isOpenCLEnv() const { return true; } |
| uint32_t getSPIRVVersion() const { return SPIRVVersion; }; |
| bool isAtLeastSPIRVVer(uint32_t VerToCompareTo) const; |
| bool isAtLeastOpenCLVer(uint32_t VerToCompareTo) const; |
| // TODO: implement command line args or other ways to determine this. |
| bool hasOpenCLFullProfile() const { return true; } |
| bool hasOpenCLImageSupport() const { return true; } |
| bool canUseExtension(SPIRV::Extension::Extension E) const; |
| bool canUseExtInstSet(SPIRV::InstructionSet::InstructionSet E) const; |
| |
| SPIRVGlobalRegistry *getSPIRVGlobalRegistry() const { return GR.get(); } |
| |
| const CallLowering *getCallLowering() const override { |
| return CallLoweringInfo.get(); |
| } |
| const RegisterBankInfo *getRegBankInfo() const override { |
| return RegBankInfo.get(); |
| } |
| const LegalizerInfo *getLegalizerInfo() const override { |
| return Legalizer.get(); |
| } |
| InstructionSelector *getInstructionSelector() const override { |
| return InstSelector.get(); |
| } |
| const SPIRVInstrInfo *getInstrInfo() const override { return &InstrInfo; } |
| const SPIRVFrameLowering *getFrameLowering() const override { |
| return &FrameLowering; |
| } |
| const SPIRVTargetLowering *getTargetLowering() const override { |
| return &TLInfo; |
| } |
| const SPIRVRegisterInfo *getRegisterInfo() const override { |
| return &InstrInfo.getRegisterInfo(); |
| } |
| }; |
| } // namespace llvm |
| |
| #endif // LLVM_LIB_TARGET_SPIRV_SPIRVSUBTARGET_H |