X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=lib%2FTarget%2FHexagon%2FHexagonTargetMachine.h;h=b61f6bc92f7fd56008391c86e6b955ca1103542f;hb=a7f0a0a566a9e7b0e53fa3124381a040db5df743;hp=d917d5b89a1edf4007f7d8fd28adb8a260a5e068;hpb=c21e4e197d05c9c9579d9fa5e23482349502c43c;p=oota-llvm.git diff --git a/lib/Target/Hexagon/HexagonTargetMachine.h b/lib/Target/Hexagon/HexagonTargetMachine.h index d917d5b89a1..b61f6bc92f7 100644 --- a/lib/Target/Hexagon/HexagonTargetMachine.h +++ b/lib/Target/Hexagon/HexagonTargetMachine.h @@ -23,20 +23,25 @@ namespace llvm { class Module; class HexagonTargetMachine : public LLVMTargetMachine { - HexagonSubtarget Subtarget; + std::unique_ptr TLOF; + mutable StringMap> SubtargetMap; public: - HexagonTargetMachine(const Target &T, StringRef TT,StringRef CPU, + HexagonTargetMachine(const Target &T, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, Reloc::Model RM, CodeModel::Model CM, CodeGenOpt::Level OL); + ~HexagonTargetMachine() override; + const HexagonSubtarget *getSubtargetImpl(const Function &F) const override; - const HexagonSubtarget *getSubtargetImpl() const override { - return &Subtarget; - } static unsigned getModuleMatchQuality(const Module &M); TargetPassConfig *createPassConfig(PassManagerBase &PM) override; + TargetIRAnalysis getTargetIRAnalysis() override; + + TargetLoweringObjectFile *getObjFileLowering() const override { + return TLOF.get(); + } }; extern bool flag_aligned_memcpy;