1 //===-- AMDGPUHSATargetObjectFile.cpp - AMDGPU Object Files ---------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 
10 #include "AMDGPUTargetObjectFile.h"
11 #include "AMDGPU.h"
12 #include "AMDGPUTargetMachine.h"
13 #include "Utils/AMDGPUBaseInfo.h"
14 #include "llvm/BinaryFormat/ELF.h"
15 #include "llvm/MC/MCContext.h"
16 #include "llvm/MC/MCSectionELF.h"
17 
18 using namespace llvm;
19 
20 //===----------------------------------------------------------------------===//
21 // Generic Object File
22 //===----------------------------------------------------------------------===//
23 
24 MCSection *AMDGPUTargetObjectFile::SelectSectionForGlobal(
25     const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const {
26   auto AS = static_cast<const AMDGPUTargetMachine*>(&TM)->getAMDGPUAS();
27   if (Kind.isReadOnly() && AMDGPU::isReadOnlySegment(GO, AS) &&
28       AMDGPU::shouldEmitConstantsToTextSection(TM.getTargetTriple()))
29     return TextSection;
30 
31   return TargetLoweringObjectFileELF::SelectSectionForGlobal(GO, Kind, TM);
32 }
33