17d523365SDimitry Andric //===-- AMDGPUHSATargetObjectFile.cpp - AMDGPU Object Files ---------------===//
27d523365SDimitry Andric //
37d523365SDimitry Andric //                     The LLVM Compiler Infrastructure
47d523365SDimitry Andric //
57d523365SDimitry Andric // This file is distributed under the University of Illinois Open Source
67d523365SDimitry Andric // License. See LICENSE.TXT for details.
77d523365SDimitry Andric //
87d523365SDimitry Andric //===----------------------------------------------------------------------===//
97d523365SDimitry Andric 
107d523365SDimitry Andric #include "AMDGPUTargetObjectFile.h"
117d523365SDimitry Andric #include "AMDGPU.h"
12db17bf38SDimitry Andric #include "AMDGPUTargetMachine.h"
13db17bf38SDimitry Andric #include "Utils/AMDGPUBaseInfo.h"
14db17bf38SDimitry Andric #include "llvm/BinaryFormat/ELF.h"
157d523365SDimitry Andric #include "llvm/MC/MCContext.h"
167d523365SDimitry Andric #include "llvm/MC/MCSectionELF.h"
177d523365SDimitry Andric 
187d523365SDimitry Andric using namespace llvm;
197d523365SDimitry Andric 
207d523365SDimitry Andric //===----------------------------------------------------------------------===//
217d523365SDimitry Andric // Generic Object File
227d523365SDimitry Andric //===----------------------------------------------------------------------===//
237d523365SDimitry Andric 
SelectSectionForGlobal(const GlobalObject * GO,SectionKind Kind,const TargetMachine & TM) const24d88c1a5aSDimitry Andric MCSection *AMDGPUTargetObjectFile::SelectSectionForGlobal(
25d88c1a5aSDimitry Andric     const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const {
262cab237bSDimitry Andric   if (Kind.isReadOnly() && AMDGPU::isReadOnlySegment(GO) &&
27d88c1a5aSDimitry Andric       AMDGPU::shouldEmitConstantsToTextSection(TM.getTargetTriple()))
287d523365SDimitry Andric     return TextSection;
297d523365SDimitry Andric 
30d88c1a5aSDimitry Andric   return TargetLoweringObjectFileELF::SelectSectionForGlobal(GO, Kind, TM);
317d523365SDimitry Andric }
32*b5893f02SDimitry Andric 
getExplicitSectionGlobal(const GlobalObject * GO,SectionKind SK,const TargetMachine & TM) const33*b5893f02SDimitry Andric MCSection *AMDGPUTargetObjectFile::getExplicitSectionGlobal(
34*b5893f02SDimitry Andric     const GlobalObject *GO, SectionKind SK, const TargetMachine &TM) const {
35*b5893f02SDimitry Andric   // Set metadata access for the explicit section
36*b5893f02SDimitry Andric   StringRef SectionName = GO->getSection();
37*b5893f02SDimitry Andric   if (SectionName.startswith(".AMDGPU.comment."))
38*b5893f02SDimitry Andric     SK = SectionKind::getMetadata();
39*b5893f02SDimitry Andric 
40*b5893f02SDimitry Andric   return TargetLoweringObjectFileELF::getExplicitSectionGlobal(GO, SK, TM);
41*b5893f02SDimitry Andric }
42