2009-08-22 20:48:53 +00:00
|
|
|
//===-- MCAsmInfo.cpp - Asm Info -------------------------------------------==//
|
2006-09-06 18:35:33 +00:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-29 20:36:04 +00:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2006-09-06 18:35:33 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file defines target asm properties related what form asm statements
|
|
|
|
// should take.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2009-08-22 20:48:53 +00:00
|
|
|
#include "llvm/MC/MCAsmInfo.h"
|
2011-05-01 03:50:49 +00:00
|
|
|
#include "llvm/MC/MCContext.h"
|
2011-04-28 16:09:09 +00:00
|
|
|
#include "llvm/MC/MCExpr.h"
|
|
|
|
#include "llvm/MC/MCStreamer.h"
|
2010-11-29 18:16:10 +00:00
|
|
|
#include "llvm/Support/DataTypes.h"
|
2011-05-01 03:50:49 +00:00
|
|
|
#include "llvm/Support/Dwarf.h"
|
2007-04-23 20:00:17 +00:00
|
|
|
#include <cctype>
|
|
|
|
#include <cstring>
|
2006-09-06 18:35:33 +00:00
|
|
|
using namespace llvm;
|
|
|
|
|
2010-01-20 06:34:14 +00:00
|
|
|
MCAsmInfo::MCAsmInfo() {
|
2011-07-15 02:09:41 +00:00
|
|
|
PointerSize = 4;
|
2013-01-23 16:22:04 +00:00
|
|
|
CalleeSaveStackSlotSize = 4;
|
2013-01-22 18:02:49 +00:00
|
|
|
|
2011-07-15 02:09:41 +00:00
|
|
|
IsLittleEndian = true;
|
|
|
|
StackGrowsUp = false;
|
2010-01-23 07:21:06 +00:00
|
|
|
HasSubsectionsViaSymbols = false;
|
2010-01-19 02:09:44 +00:00
|
|
|
HasMachoZeroFillDirective = false;
|
2010-05-20 00:49:07 +00:00
|
|
|
HasMachoTBSSDirective = false;
|
2010-01-19 04:34:02 +00:00
|
|
|
HasStaticCtorDtorReferenceInStaticMode = false;
|
2008-09-25 21:00:33 +00:00
|
|
|
MaxInstLength = 4;
|
2013-06-12 14:46:54 +00:00
|
|
|
MinInstAlignment = 1;
|
2013-09-25 10:47:21 +00:00
|
|
|
DollarIsPC = false;
|
2011-03-24 18:46:34 +00:00
|
|
|
SeparatorString = ";";
|
2008-09-25 21:00:33 +00:00
|
|
|
CommentString = "#";
|
2010-09-22 22:19:53 +00:00
|
|
|
LabelSuffix = ":";
|
2014-06-24 22:45:16 +00:00
|
|
|
UseAssignmentForEHBegin = false;
|
2015-03-05 18:55:50 +00:00
|
|
|
NeedsLocalForSize = false;
|
2013-12-02 23:39:26 +00:00
|
|
|
PrivateGlobalPrefix = "L";
|
2014-12-04 00:06:57 +00:00
|
|
|
PrivateLabelPrefix = PrivateGlobalPrefix;
|
2014-03-29 07:05:06 +00:00
|
|
|
LinkerPrivateGlobalPrefix = "";
|
2009-08-11 22:39:40 +00:00
|
|
|
InlineAsmStart = "APP";
|
|
|
|
InlineAsmEnd = "NO_APP";
|
2011-07-27 00:38:12 +00:00
|
|
|
Code16Directive = ".code16";
|
|
|
|
Code32Directive = ".code32";
|
|
|
|
Code64Directive = ".code64";
|
2008-09-25 21:00:33 +00:00
|
|
|
AssemblerDialect = 0;
|
2013-10-18 20:46:28 +00:00
|
|
|
AllowAtInName = false;
|
2012-05-18 19:12:01 +00:00
|
|
|
UseDataRegionDirectives = false;
|
2008-09-25 21:00:33 +00:00
|
|
|
ZeroDirective = "\t.zero\t";
|
|
|
|
AsciiDirective = "\t.ascii\t";
|
|
|
|
AscizDirective = "\t.asciz\t";
|
|
|
|
Data8bitsDirective = "\t.byte\t";
|
|
|
|
Data16bitsDirective = "\t.short\t";
|
|
|
|
Data32bitsDirective = "\t.long\t";
|
|
|
|
Data64bitsDirective = "\t.quad\t";
|
2009-08-08 20:43:12 +00:00
|
|
|
SunStyleELFSectionSwitchSyntax = false;
|
2009-08-13 23:30:21 +00:00
|
|
|
UsesELFSectionDirectiveForBSS = false;
|
2008-09-25 21:00:33 +00:00
|
|
|
AlignmentIsInBytes = true;
|
|
|
|
TextAlignFillValue = 0;
|
2014-04-13 04:57:38 +00:00
|
|
|
GPRel64Directive = nullptr;
|
|
|
|
GPRel32Directive = nullptr;
|
2008-09-25 21:00:33 +00:00
|
|
|
GlobalDirective = "\t.globl\t";
|
2014-10-21 01:17:30 +00:00
|
|
|
SetDirectiveSuppressesReloc = false;
|
2010-12-22 21:51:29 +00:00
|
|
|
HasAggressiveSymbolFolding = true;
|
2010-01-26 20:21:43 +00:00
|
|
|
COMMDirectiveAlignmentIsInBytes = true;
|
2012-09-07 21:08:01 +00:00
|
|
|
LCOMMDirectiveAlignmentType = LCOMM::NoAlignment;
|
2015-03-12 01:50:30 +00:00
|
|
|
HasFunctionAlignment = true;
|
2008-09-25 21:00:33 +00:00
|
|
|
HasDotTypeDotSizeDirective = true;
|
2008-12-03 11:01:37 +00:00
|
|
|
HasSingleParameterDotFile = true;
|
2013-10-16 01:05:45 +00:00
|
|
|
HasIdentDirective = false;
|
2010-01-23 05:51:36 +00:00
|
|
|
HasNoDeadStrip = false;
|
2014-12-01 21:16:17 +00:00
|
|
|
WeakDirective = "\t.weak\t";
|
2014-04-13 04:57:38 +00:00
|
|
|
WeakRefDirective = nullptr;
|
2013-12-02 23:04:51 +00:00
|
|
|
HasWeakDefDirective = false;
|
2013-12-10 21:37:41 +00:00
|
|
|
HasWeakDefCanBeHiddenDirective = false;
|
2013-12-02 23:04:51 +00:00
|
|
|
HasLinkOnceDirective = false;
|
2010-01-23 06:53:23 +00:00
|
|
|
HiddenVisibilityAttr = MCSA_Hidden;
|
2011-02-23 02:27:05 +00:00
|
|
|
HiddenDeclarationVisibilityAttr = MCSA_Hidden;
|
2010-01-23 06:53:23 +00:00
|
|
|
ProtectedVisibilityAttr = MCSA_Protected;
|
2008-09-25 21:00:33 +00:00
|
|
|
SupportsDebugInformation = false;
|
2009-08-11 00:09:57 +00:00
|
|
|
ExceptionsType = ExceptionHandling::None;
|
2014-09-01 23:48:29 +00:00
|
|
|
WinEHEncodingType = WinEH::EncodingType::Invalid;
|
2012-06-22 01:25:12 +00:00
|
|
|
DwarfUsesRelocationsAcrossSections = true;
|
2014-01-08 10:22:54 +00:00
|
|
|
DwarfFDESymbolsUseAbsDiff = false;
|
2011-07-07 20:30:33 +00:00
|
|
|
DwarfRegNumForCFI = false;
|
2013-04-22 22:49:11 +00:00
|
|
|
NeedsDwarfSectionOffsetDirective = false;
|
2013-12-04 22:43:20 +00:00
|
|
|
UseParensForSymbolVariant = false;
|
2015-04-28 01:37:11 +00:00
|
|
|
UseLogicalShr = true;
|
2014-02-13 14:44:26 +00:00
|
|
|
|
|
|
|
// FIXME: Clang's logic should be synced with the logic used to initialize
|
|
|
|
// this member and the two implementations should be merged.
|
|
|
|
// For reference:
|
|
|
|
// - Solaris always enables the integrated assembler by default
|
|
|
|
// - SparcELFMCAsmInfo and X86ELFMCAsmInfo are handling this case
|
|
|
|
// - Windows always enables the integrated assembler by default
|
|
|
|
// - MCAsmInfoCOFF is handling this case, should it be MCAsmInfoMicrosoft?
|
|
|
|
// - MachO targets always enables the integrated assembler by default
|
|
|
|
// - MCAsmInfoDarwin is handling this case
|
|
|
|
// - Generic_GCC toolchains enable the integrated assembler on a per
|
|
|
|
// architecture basis.
|
2014-06-11 04:19:25 +00:00
|
|
|
// - The target subclasses for AArch64, ARM, and X86 handle these cases
|
2014-02-13 14:44:26 +00:00
|
|
|
UseIntegratedAssembler = false;
|
2014-03-27 20:45:58 +00:00
|
|
|
|
|
|
|
CompressDebugSections = false;
|
2006-10-13 17:50:07 +00:00
|
|
|
}
|
2006-10-05 00:35:16 +00:00
|
|
|
|
2009-08-22 20:48:53 +00:00
|
|
|
MCAsmInfo::~MCAsmInfo() {
|
2006-10-05 00:35:16 +00:00
|
|
|
}
|
2006-10-13 17:50:07 +00:00
|
|
|
|
2015-01-09 18:55:42 +00:00
|
|
|
bool MCAsmInfo::isSectionAtomizableBySymbols(const MCSection &Section) const {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2011-04-28 16:09:09 +00:00
|
|
|
const MCExpr *
|
|
|
|
MCAsmInfo::getExprForPersonalitySymbol(const MCSymbol *Sym,
|
2011-05-01 03:50:49 +00:00
|
|
|
unsigned Encoding,
|
2011-04-28 16:09:09 +00:00
|
|
|
MCStreamer &Streamer) const {
|
2011-05-01 03:50:49 +00:00
|
|
|
return getExprForFDESymbol(Sym, Encoding, Streamer);
|
2011-04-28 21:04:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const MCExpr *
|
|
|
|
MCAsmInfo::getExprForFDESymbol(const MCSymbol *Sym,
|
2011-05-01 03:50:49 +00:00
|
|
|
unsigned Encoding,
|
2011-04-28 21:04:39 +00:00
|
|
|
MCStreamer &Streamer) const {
|
2011-05-01 03:50:49 +00:00
|
|
|
if (!(Encoding & dwarf::DW_EH_PE_pcrel))
|
2015-05-30 01:25:56 +00:00
|
|
|
return MCSymbolRefExpr::create(Sym, Streamer.getContext());
|
2011-05-01 03:50:49 +00:00
|
|
|
|
|
|
|
MCContext &Context = Streamer.getContext();
|
2015-05-30 01:25:56 +00:00
|
|
|
const MCExpr *Res = MCSymbolRefExpr::create(Sym, Context);
|
2015-05-18 18:43:14 +00:00
|
|
|
MCSymbol *PCSym = Context.createTempSymbol();
|
2011-05-01 03:50:49 +00:00
|
|
|
Streamer.EmitLabel(PCSym);
|
2015-05-30 01:25:56 +00:00
|
|
|
const MCExpr *PC = MCSymbolRefExpr::create(PCSym, Context);
|
|
|
|
return MCBinaryExpr::createSub(Res, PC, Context);
|
2011-04-28 16:09:09 +00:00
|
|
|
}
|