diff options
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/ARM/ARMSubtarget.cpp | 64 | ||||
| -rw-r--r-- | llvm/lib/Target/ARM/ARMTargetMachine.cpp | 53 | 
2 files changed, 63 insertions, 54 deletions
| diff --git a/llvm/lib/Target/ARM/ARMSubtarget.cpp b/llvm/lib/Target/ARM/ARMSubtarget.cpp index d9d0c27c630..dd38f8a82e2 100644 --- a/llvm/lib/Target/ARM/ARMSubtarget.cpp +++ b/llvm/lib/Target/ARM/ARMSubtarget.cpp @@ -11,6 +11,13 @@  //  //===----------------------------------------------------------------------===// +#include "ARM.h" + +#ifdef LLVM_BUILD_GLOBAL_ISEL +#include "ARMCallLowering.h" +#include "ARMLegalizerInfo.h" +#include "ARMRegisterBankInfo.h" +#endif  #include "ARMSubtarget.h"  #include "ARMFrameLowering.h"  #include "ARMInstrInfo.h" @@ -23,6 +30,13 @@  #include "llvm/ADT/StringRef.h"  #include "llvm/ADT/Triple.h"  #include "llvm/ADT/Twine.h" +#ifdef LLVM_BUILD_GLOBAL_ISEL +#include "llvm/CodeGen/GlobalISel/GISelAccessor.h" +#include "llvm/CodeGen/GlobalISel/IRTranslator.h" +#include "llvm/CodeGen/GlobalISel/InstructionSelect.h" +#include "llvm/CodeGen/GlobalISel/Legalizer.h" +#include "llvm/CodeGen/GlobalISel/RegBankSelect.h" +#endif  #include "llvm/CodeGen/MachineFunction.h"  #include "llvm/IR/Function.h"  #include "llvm/IR/GlobalValue.h" @@ -92,6 +106,35 @@ ARMFrameLowering *ARMSubtarget::initializeFrameLowering(StringRef CPU,    return new ARMFrameLowering(STI);  } +#ifdef LLVM_BUILD_GLOBAL_ISEL +namespace { + +struct ARMGISelActualAccessor : public GISelAccessor { +  std::unique_ptr<CallLowering> CallLoweringInfo; +  std::unique_ptr<InstructionSelector> InstSelector; +  std::unique_ptr<LegalizerInfo> Legalizer; +  std::unique_ptr<RegisterBankInfo> RegBankInfo; + +  const CallLowering *getCallLowering() const override { +    return CallLoweringInfo.get(); +  } + +  const InstructionSelector *getInstructionSelector() const override { +    return InstSelector.get(); +  } + +  const LegalizerInfo *getLegalizerInfo() const override { +    return Legalizer.get(); +  } + +  const RegisterBankInfo *getRegBankInfo() const override { +    return RegBankInfo.get(); +  } +}; + +} // end anonymous namespace +#endif +  ARMSubtarget::ARMSubtarget(const Triple &TT, const std::string &CPU,                             const std::string &FS,                             const ARMBaseTargetMachine &TM, bool IsLittle) @@ -106,7 +149,26 @@ ARMSubtarget::ARMSubtarget(const Triple &TT, const std::string &CPU,                      : !isThumb()                            ? (ARMBaseInstrInfo *)new ARMInstrInfo(*this)                            : (ARMBaseInstrInfo *)new Thumb2InstrInfo(*this)), -      TLInfo(TM, *this) {} +      TLInfo(TM, *this) { +#ifndef LLVM_BUILD_GLOBAL_ISEL +  GISelAccessor *GISel = new GISelAccessor(); +#else +  ARMGISelActualAccessor *GISel = new ARMGISelActualAccessor(); +  GISel->CallLoweringInfo.reset(new ARMCallLowering(*getTargetLowering())); +  GISel->Legalizer.reset(new ARMLegalizerInfo(*this)); + +  auto *RBI = new ARMRegisterBankInfo(*getRegisterInfo()); + +  // FIXME: At this point, we can't rely on Subtarget having RBI. +  // It's awkward to mix passing RBI and the Subtarget; should we pass +  // TII/TRI as well? +  GISel->InstSelector.reset(createARMInstructionSelector( +      *static_cast<const ARMBaseTargetMachine *>(&TM), *this, *RBI)); + +  GISel->RegBankInfo.reset(RBI); +#endif +  setGISelAccessor(*GISel); +}  const CallLowering *ARMSubtarget::getCallLowering() const {    assert(GISel && "Access to GlobalISel APIs not set"); diff --git a/llvm/lib/Target/ARM/ARMTargetMachine.cpp b/llvm/lib/Target/ARM/ARMTargetMachine.cpp index 4eb244a13c1..46ca6d5da1b 100644 --- a/llvm/lib/Target/ARM/ARMTargetMachine.cpp +++ b/llvm/lib/Target/ARM/ARMTargetMachine.cpp @@ -11,11 +11,6 @@  //===----------------------------------------------------------------------===//  #include "ARM.h" -#include "ARMCallLowering.h" -#include "ARMLegalizerInfo.h" -#ifdef LLVM_BUILD_GLOBAL_ISEL -#include "ARMRegisterBankInfo.h" -#endif  #include "ARMSubtarget.h"  #include "ARMMacroFusion.h"  #include "ARMTargetMachine.h" @@ -29,7 +24,6 @@  #include "llvm/Analysis/TargetTransformInfo.h"  #include "llvm/CodeGen/ExecutionDepsFix.h"  #include "llvm/CodeGen/GlobalISel/CallLowering.h" -#include "llvm/CodeGen/GlobalISel/GISelAccessor.h"  #include "llvm/CodeGen/GlobalISel/IRTranslator.h"  #include "llvm/CodeGen/GlobalISel/InstructionSelect.h"  #include "llvm/CodeGen/GlobalISel/InstructionSelector.h" @@ -234,35 +228,6 @@ ARMBaseTargetMachine::ARMBaseTargetMachine(const Target &T, const Triple &TT,  ARMBaseTargetMachine::~ARMBaseTargetMachine() = default; -#ifdef LLVM_BUILD_GLOBAL_ISEL -namespace { - -struct ARMGISelActualAccessor : public GISelAccessor { -  std::unique_ptr<CallLowering> CallLoweringInfo; -  std::unique_ptr<InstructionSelector> InstSelector; -  std::unique_ptr<LegalizerInfo> Legalizer; -  std::unique_ptr<RegisterBankInfo> RegBankInfo; - -  const CallLowering *getCallLowering() const override { -    return CallLoweringInfo.get(); -  } - -  const InstructionSelector *getInstructionSelector() const override { -    return InstSelector.get(); -  } - -  const LegalizerInfo *getLegalizerInfo() const override { -    return Legalizer.get(); -  } - -  const RegisterBankInfo *getRegBankInfo() const override { -    return RegBankInfo.get(); -  } -}; - -} // end anonymous namespace -#endif -  const ARMSubtarget *  ARMBaseTargetMachine::getSubtargetImpl(const Function &F) const {    Attribute CPUAttr = F.getFnAttribute("target-cpu"); @@ -294,24 +259,6 @@ ARMBaseTargetMachine::getSubtargetImpl(const Function &F) const {      // function that reside in TargetOptions.      resetTargetOptions(F);      I = llvm::make_unique<ARMSubtarget>(TargetTriple, CPU, FS, *this, isLittle); - -#ifndef LLVM_BUILD_GLOBAL_ISEL -    GISelAccessor *GISel = new GISelAccessor(); -#else -    ARMGISelActualAccessor *GISel = new ARMGISelActualAccessor(); -    GISel->CallLoweringInfo.reset(new ARMCallLowering(*I->getTargetLowering())); -    GISel->Legalizer.reset(new ARMLegalizerInfo(*I)); - -    auto *RBI = new ARMRegisterBankInfo(*I->getRegisterInfo()); - -    // FIXME: At this point, we can't rely on Subtarget having RBI. -    // It's awkward to mix passing RBI and the Subtarget; should we pass -    // TII/TRI as well? -    GISel->InstSelector.reset(createARMInstructionSelector(*this, *I, *RBI)); - -    GISel->RegBankInfo.reset(RBI); -#endif -    I->setGISelAccessor(*GISel);    }    return I.get();  } | 

