diff options
Diffstat (limited to 'llvm/lib/Target/AMDGPU')
9 files changed, 196 insertions, 3 deletions
| diff --git a/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp b/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp index 84c71e0cc9c..1c438b24e6a 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp @@ -123,11 +123,46 @@ void AMDGPUAsmPrinter::EmitFunctionEntryLabel() {    AsmPrinter::EmitFunctionEntryLabel();  } +static bool isModuleLinkage(const GlobalValue *GV) { +  switch (GV->getLinkage()) { +  case GlobalValue::InternalLinkage: +  case GlobalValue::CommonLinkage: +   return true; +  case GlobalValue::ExternalLinkage: +   return false; +  default: llvm_unreachable("unknown linkage type"); +  } +} +  void AMDGPUAsmPrinter::EmitGlobalVariable(const GlobalVariable *GV) {    if (TM.getTargetTriple().getOS() != Triple::AMDHSA || -      !AMDGPU::isGroupSegment(GV)) -    return AsmPrinter::EmitGlobalVariable(GV); +      GV->isDeclaration() || AMDGPU::isReadOnlySegment(GV)) { +    AsmPrinter::EmitGlobalVariable(GV); +    return; +  } + +  // Group segment variables aren't emitted in HSA. +  if (AMDGPU::isGroupSegment(GV)) +    return; + +  AMDGPUTargetStreamer *TS = +      static_cast<AMDGPUTargetStreamer *>(OutStreamer->getTargetStreamer()); +  if (isModuleLinkage(GV)) { +    TS->EmitAMDGPUHsaModuleScopeGlobal(GV->getName()); +  } else { +    TS->EmitAMDGPUHsaProgramScopeGlobal(GV->getName()); +  } + +  const DataLayout &DL = getDataLayout(); +  OutStreamer->PushSection(); +  OutStreamer->SwitchSection( +      getObjFileLowering().SectionForGlobal(GV, *Mang, TM)); +  MCSymbol *GVSym = getSymbol(GV); +  const Constant *C = GV->getInitializer(); +  OutStreamer->EmitLabel(GVSym); +  EmitGlobalConstant(DL, C); +  OutStreamer->PopSection();  }  bool AMDGPUAsmPrinter::runOnMachineFunction(MachineFunction &MF) { diff --git a/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.cpp b/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.cpp index fa54f4a017c..ee42eaacf54 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.cpp @@ -8,6 +8,7 @@  //===----------------------------------------------------------------------===//  #include "AMDGPUHSATargetObjectFile.h" +#include "AMDGPU.h"  #include "Utils/AMDGPUBaseInfo.h"  #include "llvm/MC/MCContext.h"  #include "llvm/MC/MCSectionELF.h" @@ -22,6 +23,29 @@ void AMDGPUHSATargetObjectFile::Initialize(MCContext &Ctx,    TextSection = AMDGPU::getHSATextSection(Ctx); +  DataGlobalAgentSection = AMDGPU::getHSADataGlobalAgentSection(Ctx); +  DataGlobalProgramSection = AMDGPU::getHSADataGlobalProgramSection(Ctx); + +} + +bool AMDGPUHSATargetObjectFile::isAgentAllocationSection( +    const char *SectionName) const { +  return cast<MCSectionELF>(DataGlobalAgentSection) +      ->getSectionName() +      .equals(SectionName); +} + +bool AMDGPUHSATargetObjectFile::isAgentAllocation(const GlobalValue *GV) const { +  // Read-only segments can only have agent allocation. +  return AMDGPU::isReadOnlySegment(GV) || +         (AMDGPU::isGlobalSegment(GV) && GV->hasSection() && +          isAgentAllocationSection(GV->getSection())); +} + +bool AMDGPUHSATargetObjectFile::isProgramAllocation( +    const GlobalValue *GV) const { +  // The default for global segments is program allocation. +  return AMDGPU::isGlobalSegment(GV) && !isAgentAllocation(GV);  }  MCSection *AMDGPUHSATargetObjectFile::SelectSectionForGlobal( @@ -31,5 +55,13 @@ MCSection *AMDGPUHSATargetObjectFile::SelectSectionForGlobal(    if (Kind.isText() && !GV->hasComdat())      return getTextSection(); +  if (AMDGPU::isGlobalSegment(GV)) { +    if (isAgentAllocation(GV)) +      return DataGlobalAgentSection; + +    if (isProgramAllocation(GV)) +      return DataGlobalProgramSection; +  } +    return TargetLoweringObjectFileELF::SelectSectionForGlobal(GV, Kind, Mang, TM);  } diff --git a/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.h b/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.h index e1aca67b97c..3697a96ffaf 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.h +++ b/llvm/lib/Target/AMDGPU/AMDGPUHSATargetObjectFile.h @@ -22,6 +22,14 @@  namespace llvm {  class AMDGPUHSATargetObjectFile final : public TargetLoweringObjectFileELF { +private: +  MCSection *DataGlobalAgentSection; +  MCSection *DataGlobalProgramSection; + +  bool isAgentAllocationSection(const char *SectionName) const; +  bool isAgentAllocation(const GlobalValue *GV) const; +  bool isProgramAllocation(const GlobalValue *GV) const; +  public:    void Initialize(MCContext &Ctx, const TargetMachine &TM) override; diff --git a/llvm/lib/Target/AMDGPU/AsmParser/AMDGPUAsmParser.cpp b/llvm/lib/Target/AMDGPU/AsmParser/AMDGPUAsmParser.cpp index 184cf0f6581..b360f2de0cb 100644 --- a/llvm/lib/Target/AMDGPU/AsmParser/AMDGPUAsmParser.cpp +++ b/llvm/lib/Target/AMDGPU/AsmParser/AMDGPUAsmParser.cpp @@ -365,6 +365,10 @@ private:    bool ParseSectionDirectiveHSAText();    bool subtargetHasRegister(const MCRegisterInfo &MRI, unsigned RegNo) const;    bool ParseDirectiveAMDGPUHsaKernel(); +  bool ParseDirectiveAMDGPUHsaModuleGlobal(); +  bool ParseDirectiveAMDGPUHsaProgramGlobal(); +  bool ParseSectionDirectiveHSADataGlobalAgent(); +  bool ParseSectionDirectiveHSADataGlobalProgram();  public:  public: @@ -966,6 +970,40 @@ bool AMDGPUAsmParser::ParseDirectiveAMDGPUHsaKernel() {    return false;  } +bool AMDGPUAsmParser::ParseDirectiveAMDGPUHsaModuleGlobal() { +  if (getLexer().isNot(AsmToken::Identifier)) +    return TokError("expected symbol name"); + +  StringRef GlobalName = Parser.getTok().getIdentifier(); + +  getTargetStreamer().EmitAMDGPUHsaModuleScopeGlobal(GlobalName); +  Lex(); +  return false; +} + +bool AMDGPUAsmParser::ParseDirectiveAMDGPUHsaProgramGlobal() { +  if (getLexer().isNot(AsmToken::Identifier)) +    return TokError("expected symbol name"); + +  StringRef GlobalName = Parser.getTok().getIdentifier(); + +  getTargetStreamer().EmitAMDGPUHsaProgramScopeGlobal(GlobalName); +  Lex(); +  return false; +} + +bool AMDGPUAsmParser::ParseSectionDirectiveHSADataGlobalAgent() { +  getParser().getStreamer().SwitchSection( +      AMDGPU::getHSADataGlobalAgentSection(getContext())); +  return false; +} + +bool AMDGPUAsmParser::ParseSectionDirectiveHSADataGlobalProgram() { +  getParser().getStreamer().SwitchSection( +      AMDGPU::getHSADataGlobalProgramSection(getContext())); +  return false; +} +  bool AMDGPUAsmParser::ParseDirective(AsmToken DirectiveID) {    StringRef IDVal = DirectiveID.getString(); @@ -984,6 +1022,18 @@ bool AMDGPUAsmParser::ParseDirective(AsmToken DirectiveID) {    if (IDVal == ".amdgpu_hsa_kernel")      return ParseDirectiveAMDGPUHsaKernel(); +  if (IDVal == ".amdgpu_hsa_module_global") +    return ParseDirectiveAMDGPUHsaModuleGlobal(); + +  if (IDVal == ".amdgpu_hsa_program_global") +    return ParseDirectiveAMDGPUHsaProgramGlobal(); + +  if (IDVal == ".hsadata_global_agent") +    return ParseSectionDirectiveHSADataGlobalAgent(); + +  if (IDVal == ".hsadata_global_program") +    return ParseSectionDirectiveHSADataGlobalProgram(); +    return true;  } diff --git a/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUMCAsmInfo.cpp b/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUMCAsmInfo.cpp index 01548e50f7c..89fa212de95 100644 --- a/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUMCAsmInfo.cpp +++ b/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUMCAsmInfo.cpp @@ -36,6 +36,7 @@ AMDGPUMCAsmInfo::AMDGPUMCAsmInfo(const Triple &TT) : MCAsmInfoELF() {  }  bool AMDGPUMCAsmInfo::shouldOmitSectionDirective(StringRef SectionName) const { -  return SectionName == ".hsatext" || +  return SectionName == ".hsatext" || SectionName == ".hsadata_global_agent" || +         SectionName == ".hsadata_global_program" ||           MCAsmInfo::shouldOmitSectionDirective(SectionName);  } diff --git a/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.cpp b/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.cpp index c876fa906a9..b91134d2ee9 100644 --- a/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.cpp +++ b/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.cpp @@ -231,6 +231,16 @@ void AMDGPUTargetAsmStreamer::EmitAMDGPUSymbolType(StringRef SymbolName,    }  } +void AMDGPUTargetAsmStreamer::EmitAMDGPUHsaModuleScopeGlobal( +    StringRef GlobalName) { +  OS << "\t.amdgpu_hsa_module_global " << GlobalName << '\n'; +} + +void AMDGPUTargetAsmStreamer::EmitAMDGPUHsaProgramScopeGlobal( +    StringRef GlobalName) { +  OS << "\t.amdgpu_hsa_program_global " << GlobalName << '\n'; +} +  //===----------------------------------------------------------------------===//  // AMDGPUTargetELFStreamer  //===----------------------------------------------------------------------===// @@ -316,3 +326,21 @@ void AMDGPUTargetELFStreamer::EmitAMDGPUSymbolType(StringRef SymbolName,        getStreamer().getContext().getOrCreateSymbol(SymbolName));    Symbol->setType(ELF::STT_AMDGPU_HSA_KERNEL);  } + +void AMDGPUTargetELFStreamer::EmitAMDGPUHsaModuleScopeGlobal( +    StringRef GlobalName) { + +  MCSymbolELF *Symbol = cast<MCSymbolELF>( +      getStreamer().getContext().getOrCreateSymbol(GlobalName)); +  Symbol->setType(ELF::STT_OBJECT); +  Symbol->setBinding(ELF::STB_LOCAL); +} + +void AMDGPUTargetELFStreamer::EmitAMDGPUHsaProgramScopeGlobal( +    StringRef GlobalName) { + +  MCSymbolELF *Symbol = cast<MCSymbolELF>( +      getStreamer().getContext().getOrCreateSymbol(GlobalName)); +  Symbol->setType(ELF::STT_OBJECT); +  Symbol->setBinding(ELF::STB_GLOBAL); +} diff --git a/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.h b/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.h index 30fb3014f9e..83bb728f541 100644 --- a/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.h +++ b/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUTargetStreamer.h @@ -32,6 +32,10 @@ public:    virtual void EmitAMDKernelCodeT(const amd_kernel_code_t &Header) = 0;    virtual void EmitAMDGPUSymbolType(StringRef SymbolName, unsigned Type) = 0; + +  virtual void EmitAMDGPUHsaModuleScopeGlobal(StringRef GlobalName) = 0; + +  virtual void EmitAMDGPUHsaProgramScopeGlobal(StringRef GlobalName) = 0;  };  class AMDGPUTargetAsmStreamer : public AMDGPUTargetStreamer { @@ -48,6 +52,10 @@ public:    void EmitAMDKernelCodeT(const amd_kernel_code_t &Header) override;    void EmitAMDGPUSymbolType(StringRef SymbolName, unsigned Type) override; + +  void EmitAMDGPUHsaModuleScopeGlobal(StringRef GlobalName) override; + +  void EmitAMDGPUHsaProgramScopeGlobal(StringRef GlobalName) override;  };  class AMDGPUTargetELFStreamer : public AMDGPUTargetStreamer { @@ -80,6 +88,10 @@ public:    void EmitAMDKernelCodeT(const amd_kernel_code_t &Header) override;    void EmitAMDGPUSymbolType(StringRef SymbolName, unsigned Type) override; + +  void EmitAMDGPUHsaModuleScopeGlobal(StringRef GlobalName) override; + +  void EmitAMDGPUHsaProgramScopeGlobal(StringRef GlobalName) override;  };  } diff --git a/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp b/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp index 81ade517254..e3c93384bd8 100644 --- a/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp +++ b/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp @@ -68,9 +68,30 @@ MCSection *getHSATextSection(MCContext &Ctx) {                             ELF::SHF_AMDGPU_HSA_CODE);  } +MCSection *getHSADataGlobalAgentSection(MCContext &Ctx) { +  return Ctx.getELFSection(".hsadata_global_agent", ELF::SHT_PROGBITS, +                           ELF::SHF_ALLOC | ELF::SHF_WRITE | +                           ELF::SHF_AMDGPU_HSA_GLOBAL | +                           ELF::SHF_AMDGPU_HSA_AGENT); +} + +MCSection *getHSADataGlobalProgramSection(MCContext &Ctx) { +  return  Ctx.getELFSection(".hsadata_global_program", ELF::SHT_PROGBITS, +                            ELF::SHF_ALLOC | ELF::SHF_WRITE | +                            ELF::SHF_AMDGPU_HSA_GLOBAL); +} +  bool isGroupSegment(const GlobalValue *GV) {    return GV->getType()->getAddressSpace() == AMDGPUAS::LOCAL_ADDRESS;  } +bool isGlobalSegment(const GlobalValue *GV) { +  return GV->getType()->getAddressSpace() == AMDGPUAS::GLOBAL_ADDRESS; +} + +bool isReadOnlySegment(const GlobalValue *GV) { +  return GV->getType()->getAddressSpace() == AMDGPUAS::CONSTANT_ADDRESS; +} +  } // End namespace AMDGPU  } // End namespace llvm diff --git a/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.h b/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.h index bf9377ed86c..cc70064dbc0 100644 --- a/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.h +++ b/llvm/lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.h @@ -32,7 +32,13 @@ void initDefaultAMDKernelCodeT(amd_kernel_code_t &Header,                                 const FeatureBitset &Features);  MCSection *getHSATextSection(MCContext &Ctx); +MCSection *getHSADataGlobalAgentSection(MCContext &Ctx); + +MCSection *getHSADataGlobalProgramSection(MCContext &Ctx); +  bool isGroupSegment(const GlobalValue *GV); +bool isGlobalSegment(const GlobalValue *GV); +bool isReadOnlySegment(const GlobalValue *GV);  } // end namespace AMDGPU  } // end namespace llvm | 

