xref: /freebsd/contrib/llvm-project/llvm/lib/Target/AMDGPU/MCTargetDesc/AMDGPUMCAsmInfo.cpp (revision c1d255d3ffdbe447de3ab875bf4e7d7accc5bfc5)
1 //===-- MCTargetDesc/AMDGPUMCAsmInfo.cpp - Assembly Info ------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 /// \file
8 //===----------------------------------------------------------------------===//
9 
10 #include "AMDGPUMCAsmInfo.h"
11 #include "llvm/ADT/Triple.h"
12 #include "llvm/MC/MCSubtargetInfo.h"
13 #include "MCTargetDesc/AMDGPUMCTargetDesc.h"
14 
15 using namespace llvm;
16 
17 AMDGPUMCAsmInfo::AMDGPUMCAsmInfo(const Triple &TT,
18                                  const MCTargetOptions &Options)
19     : MCAsmInfoELF() {
20   CodePointerSize = (TT.getArch() == Triple::amdgcn) ? 8 : 4;
21   StackGrowsUp = true;
22   HasSingleParameterDotFile = false;
23   //===------------------------------------------------------------------===//
24   MinInstAlignment = 4;
25 
26   // This is the maximum instruction encoded size for gfx10. With a known
27   // subtarget, it can be reduced to 8 bytes.
28   MaxInstLength = (TT.getArch() == Triple::amdgcn) ? 20 : 16;
29   SeparatorString = "\n";
30   CommentString = ";";
31   PrivateLabelPrefix = "";
32   InlineAsmStart = ";#ASMSTART";
33   InlineAsmEnd = ";#ASMEND";
34 
35   //===--- Data Emission Directives -------------------------------------===//
36   SunStyleELFSectionSwitchSyntax = true;
37   UsesELFSectionDirectiveForBSS = true;
38 
39   //===--- Global Variable Emission Directives --------------------------===//
40   HasAggressiveSymbolFolding = true;
41   COMMDirectiveAlignmentIsInBytes = false;
42   HasNoDeadStrip = true;
43   //===--- Dwarf Emission Directives -----------------------------------===//
44   SupportsDebugInformation = true;
45   DwarfRegNumForCFI = true;
46 
47   UseIntegratedAssembler = false;
48 }
49 
50 bool AMDGPUMCAsmInfo::shouldOmitSectionDirective(StringRef SectionName) const {
51   return SectionName == ".hsatext" || SectionName == ".hsadata_global_agent" ||
52          SectionName == ".hsadata_global_program" ||
53          SectionName == ".hsarodata_readonly_agent" ||
54          MCAsmInfo::shouldOmitSectionDirective(SectionName);
55 }
56 
57 unsigned AMDGPUMCAsmInfo::getMaxInstLength(const MCSubtargetInfo *STI) const {
58   if (!STI || STI->getTargetTriple().getArch() == Triple::r600)
59     return MaxInstLength;
60 
61   // Maximum for NSA encoded images
62   if (STI->getFeatureBits()[AMDGPU::FeatureNSAEncoding])
63     return 20;
64 
65   // 64-bit instruction with 32-bit literal.
66   if (STI->getFeatureBits()[AMDGPU::FeatureVOP3Literal])
67     return 12;
68 
69   return 8;
70 }
71