forked from OSchip/llvm-project
48 lines
1.7 KiB
C++
48 lines
1.7 KiB
C++
//===-- MCTargetDesc/AMDGPUMCAsmInfo.cpp - Assembly Info ------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
/// \file
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "AMDGPUMCAsmInfo.h"
|
|
#include "llvm/ADT/Triple.h"
|
|
|
|
using namespace llvm;
|
|
|
|
AMDGPUMCAsmInfo::AMDGPUMCAsmInfo(const Triple &TT) : MCAsmInfoELF() {
|
|
CodePointerSize = (TT.getArch() == Triple::amdgcn) ? 8 : 4;
|
|
StackGrowsUp = true;
|
|
HasSingleParameterDotFile = false;
|
|
//===------------------------------------------------------------------===//
|
|
MinInstAlignment = 4;
|
|
MaxInstLength = (TT.getArch() == Triple::amdgcn) ? 8 : 16;
|
|
SeparatorString = "\n";
|
|
CommentString = ";";
|
|
PrivateLabelPrefix = "";
|
|
InlineAsmStart = ";#ASMSTART";
|
|
InlineAsmEnd = ";#ASMEND";
|
|
|
|
//===--- Data Emission Directives -------------------------------------===//
|
|
SunStyleELFSectionSwitchSyntax = true;
|
|
UsesELFSectionDirectiveForBSS = true;
|
|
|
|
//===--- Global Variable Emission Directives --------------------------===//
|
|
HasAggressiveSymbolFolding = true;
|
|
COMMDirectiveAlignmentIsInBytes = false;
|
|
HasNoDeadStrip = true;
|
|
WeakRefDirective = ".weakref\t";
|
|
//===--- Dwarf Emission Directives -----------------------------------===//
|
|
SupportsDebugInformation = true;
|
|
}
|
|
|
|
bool AMDGPUMCAsmInfo::shouldOmitSectionDirective(StringRef SectionName) const {
|
|
return SectionName == ".hsatext" || SectionName == ".hsadata_global_agent" ||
|
|
SectionName == ".hsadata_global_program" ||
|
|
SectionName == ".hsarodata_readonly_agent" ||
|
|
MCAsmInfo::shouldOmitSectionDirective(SectionName);
|
|
}
|