xref: /openbsd-src/gnu/llvm/llvm/lib/Target/Lanai/LanaiSubtarget.h (revision 73471bf04ceb096474c7f0fa83b1b65c70a787a1)
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