109467b48Spatrick //=====-- LanaiSubtarget.h - Define Subtarget for the Lanai -----*- C++ -*--==// 209467b48Spatrick // 309467b48Spatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 409467b48Spatrick // See https://llvm.org/LICENSE.txt for license information. 509467b48Spatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 609467b48Spatrick // 709467b48Spatrick //===----------------------------------------------------------------------===// 809467b48Spatrick // 909467b48Spatrick // This file declares the Lanai specific subclass of TargetSubtarget. 1009467b48Spatrick // 1109467b48Spatrick //===----------------------------------------------------------------------===// 1209467b48Spatrick 1309467b48Spatrick #ifndef LLVM_LIB_TARGET_LANAI_LANAISUBTARGET_H 1409467b48Spatrick #define LLVM_LIB_TARGET_LANAI_LANAISUBTARGET_H 1509467b48Spatrick 1609467b48Spatrick #include "LanaiFrameLowering.h" 1709467b48Spatrick #include "LanaiISelLowering.h" 1809467b48Spatrick #include "LanaiInstrInfo.h" 1909467b48Spatrick #include "LanaiSelectionDAGInfo.h" 2009467b48Spatrick #include "llvm/CodeGen/TargetSubtargetInfo.h" 2109467b48Spatrick #include "llvm/IR/DataLayout.h" 2209467b48Spatrick #include "llvm/Target/TargetMachine.h" 2309467b48Spatrick 2409467b48Spatrick #define GET_SUBTARGETINFO_HEADER 2509467b48Spatrick #include "LanaiGenSubtargetInfo.inc" 2609467b48Spatrick 2709467b48Spatrick namespace llvm { 2809467b48Spatrick 2909467b48Spatrick class LanaiSubtarget : public LanaiGenSubtargetInfo { 3009467b48Spatrick public: 3109467b48Spatrick // This constructor initializes the data members to match that 3209467b48Spatrick // of the specified triple. 3309467b48Spatrick LanaiSubtarget(const Triple &TargetTriple, StringRef Cpu, 3409467b48Spatrick StringRef FeatureString, const TargetMachine &TM, 3509467b48Spatrick const TargetOptions &Options, CodeModel::Model CodeModel, 3609467b48Spatrick CodeGenOpt::Level OptLevel); 3709467b48Spatrick 3809467b48Spatrick // ParseSubtargetFeatures - Parses features string setting specified 3909467b48Spatrick // subtarget options. Definition of function is auto generated by tblgen. 40*73471bf0Spatrick void ParseSubtargetFeatures(StringRef CPU, StringRef TuneCPU, StringRef FS); 4109467b48Spatrick 4209467b48Spatrick LanaiSubtarget &initializeSubtargetDependencies(StringRef CPU, StringRef FS); 4309467b48Spatrick 4409467b48Spatrick void initSubtargetFeatures(StringRef CPU, StringRef FS); 4509467b48Spatrick enableMachineScheduler()4609467b48Spatrick bool enableMachineScheduler() const override { return true; } 4709467b48Spatrick getInstrInfo()4809467b48Spatrick const LanaiInstrInfo *getInstrInfo() const override { return &InstrInfo; } 4909467b48Spatrick getFrameLowering()5009467b48Spatrick const TargetFrameLowering *getFrameLowering() const override { 5109467b48Spatrick return &FrameLowering; 5209467b48Spatrick } 5309467b48Spatrick getRegisterInfo()5409467b48Spatrick const LanaiRegisterInfo *getRegisterInfo() const override { 5509467b48Spatrick return &InstrInfo.getRegisterInfo(); 5609467b48Spatrick } 5709467b48Spatrick getTargetLowering()5809467b48Spatrick const LanaiTargetLowering *getTargetLowering() const override { 5909467b48Spatrick return &TLInfo; 6009467b48Spatrick } 6109467b48Spatrick getSelectionDAGInfo()6209467b48Spatrick const LanaiSelectionDAGInfo *getSelectionDAGInfo() const override { 6309467b48Spatrick return &TSInfo; 6409467b48Spatrick } 6509467b48Spatrick 6609467b48Spatrick private: 6709467b48Spatrick LanaiFrameLowering FrameLowering; 6809467b48Spatrick LanaiInstrInfo InstrInfo; 6909467b48Spatrick LanaiTargetLowering TLInfo; 7009467b48Spatrick LanaiSelectionDAGInfo TSInfo; 7109467b48Spatrick }; 7209467b48Spatrick } // namespace llvm 7309467b48Spatrick 7409467b48Spatrick #endif // LLVM_LIB_TARGET_LANAI_LANAISUBTARGET_H 75