1*9880d681SAndroid Build Coastguard Worker //===-- SparcTargetMachine.h - Define TargetMachine for Sparc ---*- C++ -*-===// 2*9880d681SAndroid Build Coastguard Worker // 3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure 4*9880d681SAndroid Build Coastguard Worker // 5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source 6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details. 7*9880d681SAndroid Build Coastguard Worker // 8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 9*9880d681SAndroid Build Coastguard Worker // 10*9880d681SAndroid Build Coastguard Worker // This file declares the Sparc specific subclass of TargetMachine. 11*9880d681SAndroid Build Coastguard Worker // 12*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_LIB_TARGET_SPARC_SPARCTARGETMACHINE_H 15*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_SPARC_SPARCTARGETMACHINE_H 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker #include "SparcInstrInfo.h" 18*9880d681SAndroid Build Coastguard Worker #include "SparcSubtarget.h" 19*9880d681SAndroid Build Coastguard Worker #include "llvm/Target/TargetMachine.h" 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker namespace llvm { 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker class SparcTargetMachine : public LLVMTargetMachine { 24*9880d681SAndroid Build Coastguard Worker std::unique_ptr<TargetLoweringObjectFile> TLOF; 25*9880d681SAndroid Build Coastguard Worker SparcSubtarget Subtarget; 26*9880d681SAndroid Build Coastguard Worker bool is64Bit; 27*9880d681SAndroid Build Coastguard Worker mutable StringMap<std::unique_ptr<SparcSubtarget>> SubtargetMap; 28*9880d681SAndroid Build Coastguard Worker public: 29*9880d681SAndroid Build Coastguard Worker SparcTargetMachine(const Target &T, const Triple &TT, StringRef CPU, 30*9880d681SAndroid Build Coastguard Worker StringRef FS, const TargetOptions &Options, 31*9880d681SAndroid Build Coastguard Worker Optional<Reloc::Model> RM, CodeModel::Model CM, 32*9880d681SAndroid Build Coastguard Worker CodeGenOpt::Level OL, bool is64bit); 33*9880d681SAndroid Build Coastguard Worker ~SparcTargetMachine() override; 34*9880d681SAndroid Build Coastguard Worker getSubtargetImpl()35*9880d681SAndroid Build Coastguard Worker const SparcSubtarget *getSubtargetImpl() const { return &Subtarget; } 36*9880d681SAndroid Build Coastguard Worker const SparcSubtarget *getSubtargetImpl(const Function &) const override; 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker // Pass Pipeline Configuration 39*9880d681SAndroid Build Coastguard Worker TargetPassConfig *createPassConfig(PassManagerBase &PM) override; getObjFileLowering()40*9880d681SAndroid Build Coastguard Worker TargetLoweringObjectFile *getObjFileLowering() const override { 41*9880d681SAndroid Build Coastguard Worker return TLOF.get(); 42*9880d681SAndroid Build Coastguard Worker } 43*9880d681SAndroid Build Coastguard Worker }; 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker /// Sparc 32-bit target machine 46*9880d681SAndroid Build Coastguard Worker /// 47*9880d681SAndroid Build Coastguard Worker class SparcV8TargetMachine : public SparcTargetMachine { 48*9880d681SAndroid Build Coastguard Worker virtual void anchor(); 49*9880d681SAndroid Build Coastguard Worker public: 50*9880d681SAndroid Build Coastguard Worker SparcV8TargetMachine(const Target &T, const Triple &TT, StringRef CPU, 51*9880d681SAndroid Build Coastguard Worker StringRef FS, const TargetOptions &Options, 52*9880d681SAndroid Build Coastguard Worker Optional<Reloc::Model> RM, CodeModel::Model CM, 53*9880d681SAndroid Build Coastguard Worker CodeGenOpt::Level OL); 54*9880d681SAndroid Build Coastguard Worker }; 55*9880d681SAndroid Build Coastguard Worker 56*9880d681SAndroid Build Coastguard Worker /// Sparc 64-bit target machine 57*9880d681SAndroid Build Coastguard Worker /// 58*9880d681SAndroid Build Coastguard Worker class SparcV9TargetMachine : public SparcTargetMachine { 59*9880d681SAndroid Build Coastguard Worker virtual void anchor(); 60*9880d681SAndroid Build Coastguard Worker public: 61*9880d681SAndroid Build Coastguard Worker SparcV9TargetMachine(const Target &T, const Triple &TT, StringRef CPU, 62*9880d681SAndroid Build Coastguard Worker StringRef FS, const TargetOptions &Options, 63*9880d681SAndroid Build Coastguard Worker Optional<Reloc::Model> RM, CodeModel::Model CM, 64*9880d681SAndroid Build Coastguard Worker CodeGenOpt::Level OL); 65*9880d681SAndroid Build Coastguard Worker }; 66*9880d681SAndroid Build Coastguard Worker 67*9880d681SAndroid Build Coastguard Worker class SparcelTargetMachine : public SparcTargetMachine { 68*9880d681SAndroid Build Coastguard Worker virtual void anchor(); 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Worker public: 71*9880d681SAndroid Build Coastguard Worker SparcelTargetMachine(const Target &T, const Triple &TT, StringRef CPU, 72*9880d681SAndroid Build Coastguard Worker StringRef FS, const TargetOptions &Options, 73*9880d681SAndroid Build Coastguard Worker Optional<Reloc::Model> RM, CodeModel::Model CM, 74*9880d681SAndroid Build Coastguard Worker CodeGenOpt::Level OL); 75*9880d681SAndroid Build Coastguard Worker }; 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Worker } // end namespace llvm 78*9880d681SAndroid Build Coastguard Worker 79*9880d681SAndroid Build Coastguard Worker #endif 80