mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-04 22:31:44 +00:00
[MC] Fix some Clang-tidy modernize and Include What You Use warnings; other minor fixes (NFC).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@294813 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4f013f8a83
commit
a700a60bfc
@ -16,20 +16,22 @@
|
|||||||
#ifndef LLVM_MC_MCASMINFO_H
|
#ifndef LLVM_MC_MCASMINFO_H
|
||||||
#define LLVM_MC_MCASMINFO_H
|
#define LLVM_MC_MCASMINFO_H
|
||||||
|
|
||||||
|
#include "llvm/ADT/StringRef.h"
|
||||||
#include "llvm/MC/MCDirectives.h"
|
#include "llvm/MC/MCDirectives.h"
|
||||||
#include "llvm/MC/MCDwarf.h"
|
#include "llvm/MC/MCDwarf.h"
|
||||||
#include "llvm/MC/MCTargetOptions.h"
|
#include "llvm/MC/MCTargetOptions.h"
|
||||||
#include <cassert>
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
|
class MCContext;
|
||||||
class MCExpr;
|
class MCExpr;
|
||||||
class MCSection;
|
class MCSection;
|
||||||
class MCStreamer;
|
class MCStreamer;
|
||||||
class MCSymbol;
|
class MCSymbol;
|
||||||
class MCContext;
|
|
||||||
|
|
||||||
namespace WinEH {
|
namespace WinEH {
|
||||||
|
|
||||||
enum class EncodingType {
|
enum class EncodingType {
|
||||||
Invalid, /// Invalid
|
Invalid, /// Invalid
|
||||||
Alpha, /// Windows Alpha
|
Alpha, /// Windows Alpha
|
||||||
@ -40,11 +42,14 @@ enum class EncodingType {
|
|||||||
X86, /// Windows x86, uses no CFI, just EH tables
|
X86, /// Windows x86, uses no CFI, just EH tables
|
||||||
MIPS = Alpha,
|
MIPS = Alpha,
|
||||||
};
|
};
|
||||||
}
|
|
||||||
|
} // end namespace WinEH
|
||||||
|
|
||||||
namespace LCOMM {
|
namespace LCOMM {
|
||||||
|
|
||||||
enum LCOMMType { NoAlignment, ByteAlignment, Log2Alignment };
|
enum LCOMMType { NoAlignment, ByteAlignment, Log2Alignment };
|
||||||
}
|
|
||||||
|
} // end namespace LCOMM
|
||||||
|
|
||||||
enum class DebugCompressionType {
|
enum class DebugCompressionType {
|
||||||
DCT_None, // no compression
|
DCT_None, // no compression
|
||||||
@ -61,41 +66,41 @@ protected:
|
|||||||
//
|
//
|
||||||
|
|
||||||
/// Pointer size in bytes. Default is 4.
|
/// Pointer size in bytes. Default is 4.
|
||||||
unsigned PointerSize;
|
unsigned PointerSize = 4;
|
||||||
|
|
||||||
/// Size of the stack slot reserved for callee-saved registers, in bytes.
|
/// Size of the stack slot reserved for callee-saved registers, in bytes.
|
||||||
/// Default is same as pointer size.
|
/// Default is same as pointer size.
|
||||||
unsigned CalleeSaveStackSlotSize;
|
unsigned CalleeSaveStackSlotSize = 4;
|
||||||
|
|
||||||
/// True if target is little endian. Default is true.
|
/// True if target is little endian. Default is true.
|
||||||
bool IsLittleEndian;
|
bool IsLittleEndian = true;
|
||||||
|
|
||||||
/// True if target stack grow up. Default is false.
|
/// True if target stack grow up. Default is false.
|
||||||
bool StackGrowsUp;
|
bool StackGrowsUp = false;
|
||||||
|
|
||||||
/// True if this target has the MachO .subsections_via_symbols directive.
|
/// True if this target has the MachO .subsections_via_symbols directive.
|
||||||
/// Default is false.
|
/// Default is false.
|
||||||
bool HasSubsectionsViaSymbols;
|
bool HasSubsectionsViaSymbols = false;
|
||||||
|
|
||||||
/// True if this is a MachO target that supports the macho-specific .zerofill
|
/// True if this is a MachO target that supports the macho-specific .zerofill
|
||||||
/// directive for emitting BSS Symbols. Default is false.
|
/// directive for emitting BSS Symbols. Default is false.
|
||||||
bool HasMachoZeroFillDirective;
|
bool HasMachoZeroFillDirective = false;
|
||||||
|
|
||||||
/// True if this is a MachO target that supports the macho-specific .tbss
|
/// True if this is a MachO target that supports the macho-specific .tbss
|
||||||
/// directive for emitting thread local BSS Symbols. Default is false.
|
/// directive for emitting thread local BSS Symbols. Default is false.
|
||||||
bool HasMachoTBSSDirective;
|
bool HasMachoTBSSDirective = false;
|
||||||
|
|
||||||
/// This is the maximum possible length of an instruction, which is needed to
|
/// This is the maximum possible length of an instruction, which is needed to
|
||||||
/// compute the size of an inline asm. Defaults to 4.
|
/// compute the size of an inline asm. Defaults to 4.
|
||||||
unsigned MaxInstLength;
|
unsigned MaxInstLength = 4;
|
||||||
|
|
||||||
/// Every possible instruction length is a multiple of this value. Factored
|
/// Every possible instruction length is a multiple of this value. Factored
|
||||||
/// out in .debug_frame and .debug_line. Defaults to 1.
|
/// out in .debug_frame and .debug_line. Defaults to 1.
|
||||||
unsigned MinInstAlignment;
|
unsigned MinInstAlignment = 1;
|
||||||
|
|
||||||
/// The '$' token, when not referencing an identifier or constant, refers to
|
/// The '$' token, when not referencing an identifier or constant, refers to
|
||||||
/// the current PC. Defaults to false.
|
/// the current PC. Defaults to false.
|
||||||
bool DollarIsPC;
|
bool DollarIsPC = false;
|
||||||
|
|
||||||
/// This string, if specified, is used to separate instructions from each
|
/// This string, if specified, is used to separate instructions from each
|
||||||
/// other when on the same line. Defaults to ';'
|
/// other when on the same line. Defaults to ';'
|
||||||
@ -109,10 +114,10 @@ protected:
|
|||||||
const char *LabelSuffix;
|
const char *LabelSuffix;
|
||||||
|
|
||||||
// Print the EH begin symbol with an assignment. Defaults to false.
|
// Print the EH begin symbol with an assignment. Defaults to false.
|
||||||
bool UseAssignmentForEHBegin;
|
bool UseAssignmentForEHBegin = false;
|
||||||
|
|
||||||
// Do we need to create a local symbol for .size?
|
// Do we need to create a local symbol for .size?
|
||||||
bool NeedsLocalForSize;
|
bool NeedsLocalForSize = false;
|
||||||
|
|
||||||
/// This prefix is used for globals like constant pool entries that are
|
/// This prefix is used for globals like constant pool entries that are
|
||||||
/// completely private to the .s file and should not have names in the .o
|
/// completely private to the .s file and should not have names in the .o
|
||||||
@ -142,20 +147,20 @@ protected:
|
|||||||
const char *Code64Directive;
|
const char *Code64Directive;
|
||||||
|
|
||||||
/// Which dialect of an assembler variant to use. Defaults to 0
|
/// Which dialect of an assembler variant to use. Defaults to 0
|
||||||
unsigned AssemblerDialect;
|
unsigned AssemblerDialect = 0;
|
||||||
|
|
||||||
/// This is true if the assembler allows @ characters in symbol names.
|
/// This is true if the assembler allows @ characters in symbol names.
|
||||||
/// Defaults to false.
|
/// Defaults to false.
|
||||||
bool AllowAtInName;
|
bool AllowAtInName = false;
|
||||||
|
|
||||||
/// If this is true, symbol names with invalid characters will be printed in
|
/// If this is true, symbol names with invalid characters will be printed in
|
||||||
/// quotes.
|
/// quotes.
|
||||||
bool SupportsQuotedNames;
|
bool SupportsQuotedNames = true;
|
||||||
|
|
||||||
/// This is true if data region markers should be printed as
|
/// This is true if data region markers should be printed as
|
||||||
/// ".data_region/.end_data_region" directives. If false, use "$d/$a" labels
|
/// ".data_region/.end_data_region" directives. If false, use "$d/$a" labels
|
||||||
/// instead.
|
/// instead.
|
||||||
bool UseDataRegionDirectives;
|
bool UseDataRegionDirectives = false;
|
||||||
|
|
||||||
//===--- Data Emission Directives -------------------------------------===//
|
//===--- Data Emission Directives -------------------------------------===//
|
||||||
|
|
||||||
@ -185,13 +190,13 @@ protected:
|
|||||||
|
|
||||||
/// If non-null, a directive that is used to emit a word which should be
|
/// If non-null, a directive that is used to emit a word which should be
|
||||||
/// relocated as a 64-bit GP-relative offset, e.g. .gpdword on Mips. Defaults
|
/// relocated as a 64-bit GP-relative offset, e.g. .gpdword on Mips. Defaults
|
||||||
/// to NULL.
|
/// to nullptr.
|
||||||
const char *GPRel64Directive;
|
const char *GPRel64Directive = nullptr;
|
||||||
|
|
||||||
/// If non-null, a directive that is used to emit a word which should be
|
/// If non-null, a directive that is used to emit a word which should be
|
||||||
/// relocated as a 32-bit GP-relative offset, e.g. .gpword on Mips or .gprel32
|
/// relocated as a 32-bit GP-relative offset, e.g. .gpword on Mips or .gprel32
|
||||||
/// on Alpha. Defaults to NULL.
|
/// on Alpha. Defaults to nullptr.
|
||||||
const char *GPRel32Directive;
|
const char *GPRel32Directive = nullptr;
|
||||||
|
|
||||||
/// If non-null, directives that are used to emit a word/dword which should
|
/// If non-null, directives that are used to emit a word/dword which should
|
||||||
/// be relocated as a 32/64-bit DTP/TP-relative offset, e.g. .dtprelword/
|
/// be relocated as a 32/64-bit DTP/TP-relative offset, e.g. .dtprelword/
|
||||||
@ -204,14 +209,14 @@ protected:
|
|||||||
/// This is true if this target uses "Sun Style" syntax for section switching
|
/// This is true if this target uses "Sun Style" syntax for section switching
|
||||||
/// ("#alloc,#write" etc) instead of the normal ELF syntax (,"a,w") in
|
/// ("#alloc,#write" etc) instead of the normal ELF syntax (,"a,w") in
|
||||||
/// .section directives. Defaults to false.
|
/// .section directives. Defaults to false.
|
||||||
bool SunStyleELFSectionSwitchSyntax;
|
bool SunStyleELFSectionSwitchSyntax = false;
|
||||||
|
|
||||||
/// This is true if this target uses ELF '.section' directive before the
|
/// This is true if this target uses ELF '.section' directive before the
|
||||||
/// '.bss' one. It's used for PPC/Linux which doesn't support the '.bss'
|
/// '.bss' one. It's used for PPC/Linux which doesn't support the '.bss'
|
||||||
/// directive only. Defaults to false.
|
/// directive only. Defaults to false.
|
||||||
bool UsesELFSectionDirectiveForBSS;
|
bool UsesELFSectionDirectiveForBSS = false;
|
||||||
|
|
||||||
bool NeedsDwarfSectionOffsetDirective;
|
bool NeedsDwarfSectionOffsetDirective = false;
|
||||||
|
|
||||||
//===--- Alignment Information ----------------------------------------===//
|
//===--- Alignment Information ----------------------------------------===//
|
||||||
|
|
||||||
@ -219,11 +224,11 @@ protected:
|
|||||||
/// directives, where N is the number of bytes to align to. Otherwise, it
|
/// directives, where N is the number of bytes to align to. Otherwise, it
|
||||||
/// emits ".align log2(N)", e.g. 3 to align to an 8 byte boundary. Defaults
|
/// emits ".align log2(N)", e.g. 3 to align to an 8 byte boundary. Defaults
|
||||||
/// to true.
|
/// to true.
|
||||||
bool AlignmentIsInBytes;
|
bool AlignmentIsInBytes = true;
|
||||||
|
|
||||||
/// If non-zero, this is used to fill the executable space created as the
|
/// If non-zero, this is used to fill the executable space created as the
|
||||||
/// result of a alignment directive. Defaults to 0
|
/// result of a alignment directive. Defaults to 0
|
||||||
unsigned TextAlignFillValue;
|
unsigned TextAlignFillValue = 0;
|
||||||
|
|
||||||
//===--- Global Variable Emission Directives --------------------------===//
|
//===--- Global Variable Emission Directives --------------------------===//
|
||||||
|
|
||||||
@ -236,7 +241,7 @@ protected:
|
|||||||
/// uses a relocation but it can be suppressed by writing
|
/// uses a relocation but it can be suppressed by writing
|
||||||
/// a = f - g
|
/// a = f - g
|
||||||
/// .long a
|
/// .long a
|
||||||
bool SetDirectiveSuppressesReloc;
|
bool SetDirectiveSuppressesReloc = false;
|
||||||
|
|
||||||
/// False if the assembler requires that we use
|
/// False if the assembler requires that we use
|
||||||
/// \code
|
/// \code
|
||||||
@ -251,98 +256,98 @@ protected:
|
|||||||
/// \endcode
|
/// \endcode
|
||||||
///
|
///
|
||||||
/// Defaults to true.
|
/// Defaults to true.
|
||||||
bool HasAggressiveSymbolFolding;
|
bool HasAggressiveSymbolFolding = true;
|
||||||
|
|
||||||
/// True is .comm's and .lcomms optional alignment is to be specified in bytes
|
/// True is .comm's and .lcomms optional alignment is to be specified in bytes
|
||||||
/// instead of log2(n). Defaults to true.
|
/// instead of log2(n). Defaults to true.
|
||||||
bool COMMDirectiveAlignmentIsInBytes;
|
bool COMMDirectiveAlignmentIsInBytes = true;
|
||||||
|
|
||||||
/// Describes if the .lcomm directive for the target supports an alignment
|
/// Describes if the .lcomm directive for the target supports an alignment
|
||||||
/// argument and how it is interpreted. Defaults to NoAlignment.
|
/// argument and how it is interpreted. Defaults to NoAlignment.
|
||||||
LCOMM::LCOMMType LCOMMDirectiveAlignmentType;
|
LCOMM::LCOMMType LCOMMDirectiveAlignmentType = LCOMM::NoAlignment;
|
||||||
|
|
||||||
// True if the target allows .align directives on functions. This is true for
|
// True if the target allows .align directives on functions. This is true for
|
||||||
// most targets, so defaults to true.
|
// most targets, so defaults to true.
|
||||||
bool HasFunctionAlignment;
|
bool HasFunctionAlignment = true;
|
||||||
|
|
||||||
/// True if the target has .type and .size directives, this is true for most
|
/// True if the target has .type and .size directives, this is true for most
|
||||||
/// ELF targets. Defaults to true.
|
/// ELF targets. Defaults to true.
|
||||||
bool HasDotTypeDotSizeDirective;
|
bool HasDotTypeDotSizeDirective = true;
|
||||||
|
|
||||||
/// True if the target has a single parameter .file directive, this is true
|
/// True if the target has a single parameter .file directive, this is true
|
||||||
/// for ELF targets. Defaults to true.
|
/// for ELF targets. Defaults to true.
|
||||||
bool HasSingleParameterDotFile;
|
bool HasSingleParameterDotFile = true;
|
||||||
|
|
||||||
/// True if the target has a .ident directive, this is true for ELF targets.
|
/// True if the target has a .ident directive, this is true for ELF targets.
|
||||||
/// Defaults to false.
|
/// Defaults to false.
|
||||||
bool HasIdentDirective;
|
bool HasIdentDirective = false;
|
||||||
|
|
||||||
/// True if this target supports the MachO .no_dead_strip directive. Defaults
|
/// True if this target supports the MachO .no_dead_strip directive. Defaults
|
||||||
/// to false.
|
/// to false.
|
||||||
bool HasNoDeadStrip;
|
bool HasNoDeadStrip = false;
|
||||||
|
|
||||||
/// True if this target supports the MachO .alt_entry directive. Defaults to
|
/// True if this target supports the MachO .alt_entry directive. Defaults to
|
||||||
/// false.
|
/// false.
|
||||||
bool HasAltEntry;
|
bool HasAltEntry = false;
|
||||||
|
|
||||||
/// Used to declare a global as being a weak symbol. Defaults to ".weak".
|
/// Used to declare a global as being a weak symbol. Defaults to ".weak".
|
||||||
const char *WeakDirective;
|
const char *WeakDirective;
|
||||||
|
|
||||||
/// This directive, if non-null, is used to declare a global as being a weak
|
/// This directive, if non-null, is used to declare a global as being a weak
|
||||||
/// undefined symbol. Defaults to NULL.
|
/// undefined symbol. Defaults to nullptr.
|
||||||
const char *WeakRefDirective;
|
const char *WeakRefDirective = nullptr;
|
||||||
|
|
||||||
/// True if we have a directive to declare a global as being a weak defined
|
/// True if we have a directive to declare a global as being a weak defined
|
||||||
/// symbol. Defaults to false.
|
/// symbol. Defaults to false.
|
||||||
bool HasWeakDefDirective;
|
bool HasWeakDefDirective = false;
|
||||||
|
|
||||||
/// True if we have a directive to declare a global as being a weak defined
|
/// True if we have a directive to declare a global as being a weak defined
|
||||||
/// symbol that can be hidden (unexported). Defaults to false.
|
/// symbol that can be hidden (unexported). Defaults to false.
|
||||||
bool HasWeakDefCanBeHiddenDirective;
|
bool HasWeakDefCanBeHiddenDirective = false;
|
||||||
|
|
||||||
/// True if we have a .linkonce directive. This is used on cygwin/mingw.
|
/// True if we have a .linkonce directive. This is used on cygwin/mingw.
|
||||||
/// Defaults to false.
|
/// Defaults to false.
|
||||||
bool HasLinkOnceDirective;
|
bool HasLinkOnceDirective = false;
|
||||||
|
|
||||||
/// This attribute, if not MCSA_Invalid, is used to declare a symbol as having
|
/// This attribute, if not MCSA_Invalid, is used to declare a symbol as having
|
||||||
/// hidden visibility. Defaults to MCSA_Hidden.
|
/// hidden visibility. Defaults to MCSA_Hidden.
|
||||||
MCSymbolAttr HiddenVisibilityAttr;
|
MCSymbolAttr HiddenVisibilityAttr = MCSA_Hidden;
|
||||||
|
|
||||||
/// This attribute, if not MCSA_Invalid, is used to declare an undefined
|
/// This attribute, if not MCSA_Invalid, is used to declare an undefined
|
||||||
/// symbol as having hidden visibility. Defaults to MCSA_Hidden.
|
/// symbol as having hidden visibility. Defaults to MCSA_Hidden.
|
||||||
MCSymbolAttr HiddenDeclarationVisibilityAttr;
|
MCSymbolAttr HiddenDeclarationVisibilityAttr = MCSA_Hidden;
|
||||||
|
|
||||||
/// This attribute, if not MCSA_Invalid, is used to declare a symbol as having
|
/// This attribute, if not MCSA_Invalid, is used to declare a symbol as having
|
||||||
/// protected visibility. Defaults to MCSA_Protected
|
/// protected visibility. Defaults to MCSA_Protected
|
||||||
MCSymbolAttr ProtectedVisibilityAttr;
|
MCSymbolAttr ProtectedVisibilityAttr = MCSA_Protected;
|
||||||
|
|
||||||
//===--- Dwarf Emission Directives -----------------------------------===//
|
//===--- Dwarf Emission Directives -----------------------------------===//
|
||||||
|
|
||||||
/// True if target supports emission of debugging information. Defaults to
|
/// True if target supports emission of debugging information. Defaults to
|
||||||
/// false.
|
/// false.
|
||||||
bool SupportsDebugInformation;
|
bool SupportsDebugInformation = false;
|
||||||
|
|
||||||
/// Exception handling format for the target. Defaults to None.
|
/// Exception handling format for the target. Defaults to None.
|
||||||
ExceptionHandling ExceptionsType;
|
ExceptionHandling ExceptionsType = ExceptionHandling::None;
|
||||||
|
|
||||||
/// Windows exception handling data (.pdata) encoding. Defaults to Invalid.
|
/// Windows exception handling data (.pdata) encoding. Defaults to Invalid.
|
||||||
WinEH::EncodingType WinEHEncodingType;
|
WinEH::EncodingType WinEHEncodingType = WinEH::EncodingType::Invalid;
|
||||||
|
|
||||||
/// True if Dwarf2 output generally uses relocations for references to other
|
/// True if Dwarf2 output generally uses relocations for references to other
|
||||||
/// .debug_* sections.
|
/// .debug_* sections.
|
||||||
bool DwarfUsesRelocationsAcrossSections;
|
bool DwarfUsesRelocationsAcrossSections = true;
|
||||||
|
|
||||||
/// True if DWARF FDE symbol reference relocations should be replaced by an
|
/// True if DWARF FDE symbol reference relocations should be replaced by an
|
||||||
/// absolute difference.
|
/// absolute difference.
|
||||||
bool DwarfFDESymbolsUseAbsDiff;
|
bool DwarfFDESymbolsUseAbsDiff = false;
|
||||||
|
|
||||||
/// True if dwarf register numbers are printed instead of symbolic register
|
/// True if dwarf register numbers are printed instead of symbolic register
|
||||||
/// names in .cfi_* directives. Defaults to false.
|
/// names in .cfi_* directives. Defaults to false.
|
||||||
bool DwarfRegNumForCFI;
|
bool DwarfRegNumForCFI = false;
|
||||||
|
|
||||||
/// True if target uses parens to indicate the symbol variant instead of @.
|
/// True if target uses parens to indicate the symbol variant instead of @.
|
||||||
/// For example, foo(plt) instead of foo@plt. Defaults to false.
|
/// For example, foo(plt) instead of foo@plt. Defaults to false.
|
||||||
bool UseParensForSymbolVariant;
|
bool UseParensForSymbolVariant = false;
|
||||||
|
|
||||||
//===--- Prologue State ----------------------------------------------===//
|
//===--- Prologue State ----------------------------------------------===//
|
||||||
|
|
||||||
@ -361,11 +366,11 @@ protected:
|
|||||||
bool PreserveAsmComments;
|
bool PreserveAsmComments;
|
||||||
|
|
||||||
/// Compress DWARF debug sections. Defaults to no compression.
|
/// Compress DWARF debug sections. Defaults to no compression.
|
||||||
DebugCompressionType CompressDebugSections;
|
DebugCompressionType CompressDebugSections = DebugCompressionType::DCT_None;
|
||||||
|
|
||||||
/// True if the integrated assembler should interpret 'a >> b' constant
|
/// True if the integrated assembler should interpret 'a >> b' constant
|
||||||
/// expressions as logical rather than arithmetic.
|
/// expressions as logical rather than arithmetic.
|
||||||
bool UseLogicalShr;
|
bool UseLogicalShr = true;
|
||||||
|
|
||||||
// If true, emit GOTPCRELX/REX_GOTPCRELX instead of GOTPCREL, on
|
// If true, emit GOTPCRELX/REX_GOTPCRELX instead of GOTPCREL, on
|
||||||
// X86_64 ELF.
|
// X86_64 ELF.
|
||||||
@ -475,14 +480,17 @@ public:
|
|||||||
bool needsLocalForSize() const { return NeedsLocalForSize; }
|
bool needsLocalForSize() const { return NeedsLocalForSize; }
|
||||||
StringRef getPrivateGlobalPrefix() const { return PrivateGlobalPrefix; }
|
StringRef getPrivateGlobalPrefix() const { return PrivateGlobalPrefix; }
|
||||||
StringRef getPrivateLabelPrefix() const { return PrivateLabelPrefix; }
|
StringRef getPrivateLabelPrefix() const { return PrivateLabelPrefix; }
|
||||||
|
|
||||||
bool hasLinkerPrivateGlobalPrefix() const {
|
bool hasLinkerPrivateGlobalPrefix() const {
|
||||||
return LinkerPrivateGlobalPrefix[0] != '\0';
|
return LinkerPrivateGlobalPrefix[0] != '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
StringRef getLinkerPrivateGlobalPrefix() const {
|
StringRef getLinkerPrivateGlobalPrefix() const {
|
||||||
if (hasLinkerPrivateGlobalPrefix())
|
if (hasLinkerPrivateGlobalPrefix())
|
||||||
return LinkerPrivateGlobalPrefix;
|
return LinkerPrivateGlobalPrefix;
|
||||||
return getPrivateGlobalPrefix();
|
return getPrivateGlobalPrefix();
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *getInlineAsmStart() const { return InlineAsmStart; }
|
const char *getInlineAsmStart() const { return InlineAsmStart; }
|
||||||
const char *getInlineAsmEnd() const { return InlineAsmEnd; }
|
const char *getInlineAsmEnd() const { return InlineAsmEnd; }
|
||||||
const char *getCode16Directive() const { return Code16Directive; }
|
const char *getCode16Directive() const { return Code16Directive; }
|
||||||
@ -491,25 +499,32 @@ public:
|
|||||||
unsigned getAssemblerDialect() const { return AssemblerDialect; }
|
unsigned getAssemblerDialect() const { return AssemblerDialect; }
|
||||||
bool doesAllowAtInName() const { return AllowAtInName; }
|
bool doesAllowAtInName() const { return AllowAtInName; }
|
||||||
bool supportsNameQuoting() const { return SupportsQuotedNames; }
|
bool supportsNameQuoting() const { return SupportsQuotedNames; }
|
||||||
|
|
||||||
bool doesSupportDataRegionDirectives() const {
|
bool doesSupportDataRegionDirectives() const {
|
||||||
return UseDataRegionDirectives;
|
return UseDataRegionDirectives;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *getZeroDirective() const { return ZeroDirective; }
|
const char *getZeroDirective() const { return ZeroDirective; }
|
||||||
const char *getAsciiDirective() const { return AsciiDirective; }
|
const char *getAsciiDirective() const { return AsciiDirective; }
|
||||||
const char *getAscizDirective() const { return AscizDirective; }
|
const char *getAscizDirective() const { return AscizDirective; }
|
||||||
bool getAlignmentIsInBytes() const { return AlignmentIsInBytes; }
|
bool getAlignmentIsInBytes() const { return AlignmentIsInBytes; }
|
||||||
unsigned getTextAlignFillValue() const { return TextAlignFillValue; }
|
unsigned getTextAlignFillValue() const { return TextAlignFillValue; }
|
||||||
const char *getGlobalDirective() const { return GlobalDirective; }
|
const char *getGlobalDirective() const { return GlobalDirective; }
|
||||||
|
|
||||||
bool doesSetDirectiveSuppressReloc() const {
|
bool doesSetDirectiveSuppressReloc() const {
|
||||||
return SetDirectiveSuppressesReloc;
|
return SetDirectiveSuppressesReloc;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool hasAggressiveSymbolFolding() const { return HasAggressiveSymbolFolding; }
|
bool hasAggressiveSymbolFolding() const { return HasAggressiveSymbolFolding; }
|
||||||
|
|
||||||
bool getCOMMDirectiveAlignmentIsInBytes() const {
|
bool getCOMMDirectiveAlignmentIsInBytes() const {
|
||||||
return COMMDirectiveAlignmentIsInBytes;
|
return COMMDirectiveAlignmentIsInBytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
LCOMM::LCOMMType getLCOMMDirectiveAlignmentType() const {
|
LCOMM::LCOMMType getLCOMMDirectiveAlignmentType() const {
|
||||||
return LCOMMDirectiveAlignmentType;
|
return LCOMMDirectiveAlignmentType;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool hasFunctionAlignment() const { return HasFunctionAlignment; }
|
bool hasFunctionAlignment() const { return HasFunctionAlignment; }
|
||||||
bool hasDotTypeDotSizeDirective() const { return HasDotTypeDotSizeDirective; }
|
bool hasDotTypeDotSizeDirective() const { return HasDotTypeDotSizeDirective; }
|
||||||
bool hasSingleParameterDotFile() const { return HasSingleParameterDotFile; }
|
bool hasSingleParameterDotFile() const { return HasSingleParameterDotFile; }
|
||||||
@ -519,22 +534,29 @@ public:
|
|||||||
const char *getWeakDirective() const { return WeakDirective; }
|
const char *getWeakDirective() const { return WeakDirective; }
|
||||||
const char *getWeakRefDirective() const { return WeakRefDirective; }
|
const char *getWeakRefDirective() const { return WeakRefDirective; }
|
||||||
bool hasWeakDefDirective() const { return HasWeakDefDirective; }
|
bool hasWeakDefDirective() const { return HasWeakDefDirective; }
|
||||||
|
|
||||||
bool hasWeakDefCanBeHiddenDirective() const {
|
bool hasWeakDefCanBeHiddenDirective() const {
|
||||||
return HasWeakDefCanBeHiddenDirective;
|
return HasWeakDefCanBeHiddenDirective;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool hasLinkOnceDirective() const { return HasLinkOnceDirective; }
|
bool hasLinkOnceDirective() const { return HasLinkOnceDirective; }
|
||||||
|
|
||||||
MCSymbolAttr getHiddenVisibilityAttr() const { return HiddenVisibilityAttr; }
|
MCSymbolAttr getHiddenVisibilityAttr() const { return HiddenVisibilityAttr; }
|
||||||
|
|
||||||
MCSymbolAttr getHiddenDeclarationVisibilityAttr() const {
|
MCSymbolAttr getHiddenDeclarationVisibilityAttr() const {
|
||||||
return HiddenDeclarationVisibilityAttr;
|
return HiddenDeclarationVisibilityAttr;
|
||||||
}
|
}
|
||||||
|
|
||||||
MCSymbolAttr getProtectedVisibilityAttr() const {
|
MCSymbolAttr getProtectedVisibilityAttr() const {
|
||||||
return ProtectedVisibilityAttr;
|
return ProtectedVisibilityAttr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool doesSupportDebugInformation() const { return SupportsDebugInformation; }
|
bool doesSupportDebugInformation() const { return SupportsDebugInformation; }
|
||||||
|
|
||||||
bool doesSupportExceptionHandling() const {
|
bool doesSupportExceptionHandling() const {
|
||||||
return ExceptionsType != ExceptionHandling::None;
|
return ExceptionsType != ExceptionHandling::None;
|
||||||
}
|
}
|
||||||
|
|
||||||
ExceptionHandling getExceptionHandlingType() const { return ExceptionsType; }
|
ExceptionHandling getExceptionHandlingType() const { return ExceptionsType; }
|
||||||
WinEH::EncodingType getWinEHEncodingType() const { return WinEHEncodingType; }
|
WinEH::EncodingType getWinEHEncodingType() const { return WinEHEncodingType; }
|
||||||
|
|
||||||
@ -558,6 +580,7 @@ public:
|
|||||||
bool doesDwarfUseRelocationsAcrossSections() const {
|
bool doesDwarfUseRelocationsAcrossSections() const {
|
||||||
return DwarfUsesRelocationsAcrossSections;
|
return DwarfUsesRelocationsAcrossSections;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool doDwarfFDESymbolsUseAbsDiff() const { return DwarfFDESymbolsUseAbsDiff; }
|
bool doDwarfFDESymbolsUseAbsDiff() const { return DwarfFDESymbolsUseAbsDiff; }
|
||||||
bool useDwarfRegNumForCFI() const { return DwarfRegNumForCFI; }
|
bool useDwarfRegNumForCFI() const { return DwarfRegNumForCFI; }
|
||||||
bool useParensForSymbolVariant() const { return UseParensForSymbolVariant; }
|
bool useParensForSymbolVariant() const { return UseParensForSymbolVariant; }
|
||||||
@ -600,6 +623,7 @@ public:
|
|||||||
void setRelaxELFRelocations(bool V) { RelaxELFRelocations = V; }
|
void setRelaxELFRelocations(bool V) { RelaxELFRelocations = V; }
|
||||||
bool hasMipsExpressions() const { return HasMipsExpressions; }
|
bool hasMipsExpressions() const { return HasMipsExpressions; }
|
||||||
};
|
};
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
} // end namespace llvm
|
||||||
|
|
||||||
|
#endif // LLVM_MC_MCASMINFO_H
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCAsmInfoCOFF.h - COFF asm properties -------------------*- C++ -*-===//
|
//===- MCAsmInfoCOFF.h - COFF asm properties --------------------*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -13,24 +13,28 @@
|
|||||||
#include "llvm/MC/MCAsmInfo.h"
|
#include "llvm/MC/MCAsmInfo.h"
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
class MCAsmInfoCOFF : public MCAsmInfo {
|
|
||||||
virtual void anchor();
|
|
||||||
protected:
|
|
||||||
explicit MCAsmInfoCOFF();
|
|
||||||
};
|
|
||||||
|
|
||||||
class MCAsmInfoMicrosoft : public MCAsmInfoCOFF {
|
class MCAsmInfoCOFF : public MCAsmInfo {
|
||||||
void anchor() override;
|
virtual void anchor();
|
||||||
protected:
|
|
||||||
explicit MCAsmInfoMicrosoft();
|
|
||||||
};
|
|
||||||
|
|
||||||
class MCAsmInfoGNUCOFF : public MCAsmInfoCOFF {
|
protected:
|
||||||
void anchor() override;
|
explicit MCAsmInfoCOFF();
|
||||||
protected:
|
};
|
||||||
explicit MCAsmInfoGNUCOFF();
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
class MCAsmInfoMicrosoft : public MCAsmInfoCOFF {
|
||||||
|
void anchor() override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
explicit MCAsmInfoMicrosoft();
|
||||||
|
};
|
||||||
|
|
||||||
|
class MCAsmInfoGNUCOFF : public MCAsmInfoCOFF {
|
||||||
|
void anchor() override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
explicit MCAsmInfoGNUCOFF();
|
||||||
|
};
|
||||||
|
|
||||||
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif // LLVM_MC_MCASMINFOCOFF_H
|
#endif // LLVM_MC_MCASMINFOCOFF_H
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===---- MCAsmInfoDarwin.h - Darwin asm properties -------------*- C++ -*-===//
|
//===- MCAsmInfoDarwin.h - Darwin asm properties ----------------*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -18,12 +18,14 @@
|
|||||||
#include "llvm/MC/MCAsmInfo.h"
|
#include "llvm/MC/MCAsmInfo.h"
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
class MCAsmInfoDarwin : public MCAsmInfo {
|
|
||||||
public:
|
|
||||||
explicit MCAsmInfoDarwin();
|
|
||||||
bool isSectionAtomizableBySymbols(const MCSection &Section) const override;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
class MCAsmInfoDarwin : public MCAsmInfo {
|
||||||
|
public:
|
||||||
|
explicit MCAsmInfoDarwin();
|
||||||
|
|
||||||
|
bool isSectionAtomizableBySymbols(const MCSection &Section) const override;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif // LLVM_MC_MCASMINFODARWIN_H
|
#endif // LLVM_MC_MCASMINFODARWIN_H
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- llvm/MC/MCAsmInfoELF.h - ELF Asm info -------------------*- C++ -*-===//
|
//===- llvm/MC/MCAsmInfoELF.h - ELF Asm info --------------------*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -13,6 +13,7 @@
|
|||||||
#include "llvm/MC/MCAsmInfo.h"
|
#include "llvm/MC/MCAsmInfo.h"
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
class MCAsmInfoELF : public MCAsmInfo {
|
class MCAsmInfoELF : public MCAsmInfo {
|
||||||
virtual void anchor();
|
virtual void anchor();
|
||||||
MCSection *getNonexecutableStackSection(MCContext &Ctx) const final;
|
MCSection *getNonexecutableStackSection(MCContext &Ctx) const final;
|
||||||
@ -20,10 +21,11 @@ class MCAsmInfoELF : public MCAsmInfo {
|
|||||||
protected:
|
protected:
|
||||||
/// Targets which have non-executable stacks by default can set this to false
|
/// Targets which have non-executable stacks by default can set this to false
|
||||||
/// to disable the special section which requests a non-executable stack.
|
/// to disable the special section which requests a non-executable stack.
|
||||||
bool UsesNonexecutableStackSection;
|
bool UsesNonexecutableStackSection = true;
|
||||||
|
|
||||||
MCAsmInfoELF();
|
MCAsmInfoELF();
|
||||||
};
|
};
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
} // end namespace llvm
|
||||||
|
|
||||||
|
#endif // LLVM_MC_MCASMINFOELF_H
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- llvm/MC/MCInst.h - MCInst class -------------------------*- C++ -*-===//
|
//===- llvm/MC/MCInst.h - MCInst class --------------------------*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -18,15 +18,17 @@
|
|||||||
|
|
||||||
#include "llvm/ADT/SmallVector.h"
|
#include "llvm/ADT/SmallVector.h"
|
||||||
#include "llvm/ADT/StringRef.h"
|
#include "llvm/ADT/StringRef.h"
|
||||||
#include "llvm/Support/DataTypes.h"
|
|
||||||
#include "llvm/Support/SMLoc.h"
|
#include "llvm/Support/SMLoc.h"
|
||||||
|
#include <cassert>
|
||||||
|
#include <cstddef>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
class raw_ostream;
|
|
||||||
class MCAsmInfo;
|
|
||||||
class MCInstPrinter;
|
|
||||||
class MCExpr;
|
class MCExpr;
|
||||||
class MCInst;
|
class MCInst;
|
||||||
|
class MCInstPrinter;
|
||||||
|
class raw_ostream;
|
||||||
|
|
||||||
/// \brief Instances of this class represent operands of the MCInst class.
|
/// \brief Instances of this class represent operands of the MCInst class.
|
||||||
/// This is a simple discriminated union.
|
/// This is a simple discriminated union.
|
||||||
@ -39,7 +41,7 @@ class MCOperand {
|
|||||||
kExpr, ///< Relocatable immediate operand.
|
kExpr, ///< Relocatable immediate operand.
|
||||||
kInst ///< Sub-instruction operand.
|
kInst ///< Sub-instruction operand.
|
||||||
};
|
};
|
||||||
MachineOperandType Kind;
|
MachineOperandType Kind = kInvalid;
|
||||||
|
|
||||||
union {
|
union {
|
||||||
unsigned RegVal;
|
unsigned RegVal;
|
||||||
@ -50,7 +52,7 @@ class MCOperand {
|
|||||||
};
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MCOperand() : Kind(kInvalid), FPImmVal(0.0) {}
|
MCOperand() : FPImmVal(0.0) {}
|
||||||
|
|
||||||
bool isValid() const { return Kind != kInvalid; }
|
bool isValid() const { return Kind != kInvalid; }
|
||||||
bool isReg() const { return Kind == kRegister; }
|
bool isReg() const { return Kind == kRegister; }
|
||||||
@ -75,6 +77,7 @@ public:
|
|||||||
assert(isImm() && "This is not an immediate");
|
assert(isImm() && "This is not an immediate");
|
||||||
return ImmVal;
|
return ImmVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
void setImm(int64_t Val) {
|
void setImm(int64_t Val) {
|
||||||
assert(isImm() && "This is not an immediate");
|
assert(isImm() && "This is not an immediate");
|
||||||
ImmVal = Val;
|
ImmVal = Val;
|
||||||
@ -94,6 +97,7 @@ public:
|
|||||||
assert(isExpr() && "This is not an expression");
|
assert(isExpr() && "This is not an expression");
|
||||||
return ExprVal;
|
return ExprVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
void setExpr(const MCExpr *Val) {
|
void setExpr(const MCExpr *Val) {
|
||||||
assert(isExpr() && "This is not an expression");
|
assert(isExpr() && "This is not an expression");
|
||||||
ExprVal = Val;
|
ExprVal = Val;
|
||||||
@ -103,6 +107,7 @@ public:
|
|||||||
assert(isInst() && "This is not a sub-instruction");
|
assert(isInst() && "This is not a sub-instruction");
|
||||||
return InstVal;
|
return InstVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
void setInst(const MCInst *Val) {
|
void setInst(const MCInst *Val) {
|
||||||
assert(isInst() && "This is not a sub-instruction");
|
assert(isInst() && "This is not a sub-instruction");
|
||||||
InstVal = Val;
|
InstVal = Val;
|
||||||
@ -114,24 +119,28 @@ public:
|
|||||||
Op.RegVal = Reg;
|
Op.RegVal = Reg;
|
||||||
return Op;
|
return Op;
|
||||||
}
|
}
|
||||||
|
|
||||||
static MCOperand createImm(int64_t Val) {
|
static MCOperand createImm(int64_t Val) {
|
||||||
MCOperand Op;
|
MCOperand Op;
|
||||||
Op.Kind = kImmediate;
|
Op.Kind = kImmediate;
|
||||||
Op.ImmVal = Val;
|
Op.ImmVal = Val;
|
||||||
return Op;
|
return Op;
|
||||||
}
|
}
|
||||||
|
|
||||||
static MCOperand createFPImm(double Val) {
|
static MCOperand createFPImm(double Val) {
|
||||||
MCOperand Op;
|
MCOperand Op;
|
||||||
Op.Kind = kFPImmediate;
|
Op.Kind = kFPImmediate;
|
||||||
Op.FPImmVal = Val;
|
Op.FPImmVal = Val;
|
||||||
return Op;
|
return Op;
|
||||||
}
|
}
|
||||||
|
|
||||||
static MCOperand createExpr(const MCExpr *Val) {
|
static MCOperand createExpr(const MCExpr *Val) {
|
||||||
MCOperand Op;
|
MCOperand Op;
|
||||||
Op.Kind = kExpr;
|
Op.Kind = kExpr;
|
||||||
Op.ExprVal = Val;
|
Op.ExprVal = Val;
|
||||||
return Op;
|
return Op;
|
||||||
}
|
}
|
||||||
|
|
||||||
static MCOperand createInst(const MCInst *Val) {
|
static MCOperand createInst(const MCInst *Val) {
|
||||||
MCOperand Op;
|
MCOperand Op;
|
||||||
Op.Kind = kInst;
|
Op.Kind = kInst;
|
||||||
@ -148,12 +157,12 @@ template <> struct isPodLike<MCOperand> { static const bool value = true; };
|
|||||||
/// \brief Instances of this class represent a single low-level machine
|
/// \brief Instances of this class represent a single low-level machine
|
||||||
/// instruction.
|
/// instruction.
|
||||||
class MCInst {
|
class MCInst {
|
||||||
unsigned Opcode;
|
unsigned Opcode = 0;
|
||||||
SMLoc Loc;
|
SMLoc Loc;
|
||||||
SmallVector<MCOperand, 8> Operands;
|
SmallVector<MCOperand, 8> Operands;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MCInst() : Opcode(0) {}
|
MCInst() = default;
|
||||||
|
|
||||||
void setOpcode(unsigned Op) { Opcode = Op; }
|
void setOpcode(unsigned Op) { Opcode = Op; }
|
||||||
unsigned getOpcode() const { return Opcode; }
|
unsigned getOpcode() const { return Opcode; }
|
||||||
@ -176,6 +185,7 @@ public:
|
|||||||
const_iterator begin() const { return Operands.begin(); }
|
const_iterator begin() const { return Operands.begin(); }
|
||||||
iterator end() { return Operands.end(); }
|
iterator end() { return Operands.end(); }
|
||||||
const_iterator end() const { return Operands.end(); }
|
const_iterator end() const { return Operands.end(); }
|
||||||
|
|
||||||
iterator insert(iterator I, const MCOperand &Op) {
|
iterator insert(iterator I, const MCOperand &Op) {
|
||||||
return Operands.insert(I, Op);
|
return Operands.insert(I, Op);
|
||||||
}
|
}
|
||||||
@ -202,4 +212,4 @@ inline raw_ostream& operator<<(raw_ostream &OS, const MCInst &MI) {
|
|||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif
|
#endif // LLVM_MC_MCINST_H
|
||||||
|
@ -16,12 +16,12 @@
|
|||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
template <typename T> class ArrayRef;
|
template <typename T> class ArrayRef;
|
||||||
class MCInst;
|
|
||||||
class raw_ostream;
|
|
||||||
class MCAsmInfo;
|
class MCAsmInfo;
|
||||||
|
class MCInst;
|
||||||
class MCInstrInfo;
|
class MCInstrInfo;
|
||||||
class MCRegisterInfo;
|
class MCRegisterInfo;
|
||||||
class MCSubtargetInfo;
|
class MCSubtargetInfo;
|
||||||
|
class raw_ostream;
|
||||||
class StringRef;
|
class StringRef;
|
||||||
|
|
||||||
/// Convert `Bytes' to a hex string and output to `OS'
|
/// Convert `Bytes' to a hex string and output to `OS'
|
||||||
@ -43,28 +43,26 @@ protected:
|
|||||||
/// \brief A stream that comments can be emitted to if desired. Each comment
|
/// \brief A stream that comments can be emitted to if desired. Each comment
|
||||||
/// must end with a newline. This will be null if verbose assembly emission
|
/// must end with a newline. This will be null if verbose assembly emission
|
||||||
/// is disable.
|
/// is disable.
|
||||||
raw_ostream *CommentStream;
|
raw_ostream *CommentStream = nullptr;
|
||||||
const MCAsmInfo &MAI;
|
const MCAsmInfo &MAI;
|
||||||
const MCInstrInfo &MII;
|
const MCInstrInfo &MII;
|
||||||
const MCRegisterInfo &MRI;
|
const MCRegisterInfo &MRI;
|
||||||
|
|
||||||
/// True if we are printing marked up assembly.
|
/// True if we are printing marked up assembly.
|
||||||
bool UseMarkup;
|
bool UseMarkup = false;
|
||||||
|
|
||||||
/// True if we are printing immediates as hex.
|
/// True if we are printing immediates as hex.
|
||||||
bool PrintImmHex;
|
bool PrintImmHex = false;
|
||||||
|
|
||||||
/// Which style to use for printing hexadecimal values.
|
/// Which style to use for printing hexadecimal values.
|
||||||
HexStyle::Style PrintHexStyle;
|
HexStyle::Style PrintHexStyle = HexStyle::C;
|
||||||
|
|
||||||
/// Utility function for printing annotations.
|
/// Utility function for printing annotations.
|
||||||
void printAnnotation(raw_ostream &OS, StringRef Annot);
|
void printAnnotation(raw_ostream &OS, StringRef Annot);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MCInstPrinter(const MCAsmInfo &mai, const MCInstrInfo &mii,
|
MCInstPrinter(const MCAsmInfo &mai, const MCInstrInfo &mii,
|
||||||
const MCRegisterInfo &mri)
|
const MCRegisterInfo &mri) : MAI(mai), MII(mii), MRI(mri) {}
|
||||||
: CommentStream(nullptr), MAI(mai), MII(mii), MRI(mri), UseMarkup(false),
|
|
||||||
PrintImmHex(false), PrintHexStyle(HexStyle::C) {}
|
|
||||||
|
|
||||||
virtual ~MCInstPrinter();
|
virtual ~MCInstPrinter();
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- llvm/MC/MCInstrAnalysis.h - InstrDesc target hooks ------*- C++ -*-===//
|
//===- llvm/MC/MCInstrAnalysis.h - InstrDesc target hooks -------*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -18,18 +18,19 @@
|
|||||||
#include "llvm/MC/MCInst.h"
|
#include "llvm/MC/MCInst.h"
|
||||||
#include "llvm/MC/MCInstrDesc.h"
|
#include "llvm/MC/MCInstrDesc.h"
|
||||||
#include "llvm/MC/MCInstrInfo.h"
|
#include "llvm/MC/MCInstrInfo.h"
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
class MCInstrAnalysis {
|
class MCInstrAnalysis {
|
||||||
protected:
|
protected:
|
||||||
friend class Target;
|
friend class Target;
|
||||||
|
|
||||||
const MCInstrInfo *Info;
|
const MCInstrInfo *Info;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MCInstrAnalysis(const MCInstrInfo *Info) : Info(Info) {}
|
MCInstrAnalysis(const MCInstrInfo *Info) : Info(Info) {}
|
||||||
|
virtual ~MCInstrAnalysis() = default;
|
||||||
virtual ~MCInstrAnalysis() {}
|
|
||||||
|
|
||||||
virtual bool isBranch(const MCInst &Inst) const {
|
virtual bool isBranch(const MCInst &Inst) const {
|
||||||
return Info->get(Inst.getOpcode()).isBranch();
|
return Info->get(Inst.getOpcode()).isBranch();
|
||||||
@ -66,6 +67,6 @@ public:
|
|||||||
uint64_t &Target) const;
|
uint64_t &Target) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // End llvm namespace
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif
|
#endif // LLVM_MC_MCINSTRANALYSIS_H
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- llvm/MC/MCInstrItineraries.h - Scheduling ---------------*- C++ -*-===//
|
//===- llvm/MC/MCInstrItineraries.h - Scheduling ----------------*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -88,7 +88,6 @@ struct InstrStage {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
/// An itinerary represents the scheduling information for an instruction.
|
/// An itinerary represents the scheduling information for an instruction.
|
||||||
/// This includes a set of stages occupied by the instruction and the pipeline
|
/// This includes a set of stages occupied by the instruction and the pipeline
|
||||||
@ -102,23 +101,20 @@ struct InstrItinerary {
|
|||||||
unsigned LastOperandCycle; ///< Index of last + 1 operand rd/wr
|
unsigned LastOperandCycle; ///< Index of last + 1 operand rd/wr
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
/// Itinerary data supplied by a subtarget to be used by a target.
|
/// Itinerary data supplied by a subtarget to be used by a target.
|
||||||
///
|
///
|
||||||
class InstrItineraryData {
|
class InstrItineraryData {
|
||||||
public:
|
public:
|
||||||
MCSchedModel SchedModel; ///< Basic machine properties.
|
MCSchedModel SchedModel =
|
||||||
const InstrStage *Stages; ///< Array of stages selected
|
MCSchedModel::GetDefaultSchedModel(); ///< Basic machine properties.
|
||||||
const unsigned *OperandCycles; ///< Array of operand cycles selected
|
const InstrStage *Stages = nullptr; ///< Array of stages selected
|
||||||
const unsigned *Forwardings; ///< Array of pipeline forwarding paths
|
const unsigned *OperandCycles = nullptr; ///< Array of operand cycles selected
|
||||||
const InstrItinerary *Itineraries; ///< Array of itineraries selected
|
const unsigned *Forwardings = nullptr; ///< Array of pipeline forwarding paths
|
||||||
|
const InstrItinerary *Itineraries =
|
||||||
/// Ctors.
|
nullptr; ///< Array of itineraries selected
|
||||||
InstrItineraryData() : SchedModel(MCSchedModel::GetDefaultSchedModel()),
|
|
||||||
Stages(nullptr), OperandCycles(nullptr),
|
|
||||||
Forwardings(nullptr), Itineraries(nullptr) {}
|
|
||||||
|
|
||||||
|
InstrItineraryData() = default;
|
||||||
InstrItineraryData(const MCSchedModel &SM, const InstrStage *S,
|
InstrItineraryData(const MCSchedModel &SM, const InstrStage *S,
|
||||||
const unsigned *OS, const unsigned *F)
|
const unsigned *OS, const unsigned *F)
|
||||||
: SchedModel(SM), Stages(S), OperandCycles(OS), Forwardings(F),
|
: SchedModel(SM), Stages(S), OperandCycles(OS), Forwardings(F),
|
||||||
@ -234,6 +230,6 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // End llvm namespace
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif
|
#endif // LLVM_MC_MCINSTRITINERARIES_H
|
||||||
|
@ -21,13 +21,14 @@
|
|||||||
#include "llvm/ADT/StringRef.h"
|
#include "llvm/ADT/StringRef.h"
|
||||||
#include "llvm/ADT/StringSwitch.h"
|
#include "llvm/ADT/StringSwitch.h"
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
#include <cassert>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
// Forward declarations.
|
class MachObjectWriter;
|
||||||
class MCAsmLayout;
|
class MCAsmLayout;
|
||||||
class MCSymbol;
|
class MCSymbol;
|
||||||
class MachObjectWriter;
|
|
||||||
|
|
||||||
/// Linker Optimization Hint Type.
|
/// Linker Optimization Hint Type.
|
||||||
enum MCLOHType {
|
enum MCLOHType {
|
||||||
@ -133,7 +134,7 @@ public:
|
|||||||
|
|
||||||
class MCLOHContainer {
|
class MCLOHContainer {
|
||||||
/// Keep track of the emit size of all the LOHs.
|
/// Keep track of the emit size of all the LOHs.
|
||||||
mutable uint64_t EmitSize;
|
mutable uint64_t EmitSize = 0;
|
||||||
|
|
||||||
/// Keep track of all LOH directives.
|
/// Keep track of all LOH directives.
|
||||||
SmallVector<MCLOHDirective, 32> Directives;
|
SmallVector<MCLOHDirective, 32> Directives;
|
||||||
@ -141,7 +142,7 @@ class MCLOHContainer {
|
|||||||
public:
|
public:
|
||||||
typedef SmallVectorImpl<MCLOHDirective> LOHDirectives;
|
typedef SmallVectorImpl<MCLOHDirective> LOHDirectives;
|
||||||
|
|
||||||
MCLOHContainer() : EmitSize(0) {}
|
MCLOHContainer() = default;
|
||||||
|
|
||||||
/// Const accessor to the directives.
|
/// Const accessor to the directives.
|
||||||
const LOHDirectives &getDirectives() const {
|
const LOHDirectives &getDirectives() const {
|
||||||
@ -183,4 +184,4 @@ typedef MCLOHContainer::LOHDirectives MCLOHDirectives;
|
|||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif
|
#endif // LLVM_MC_MCLINKEROPTIMIZATIONHINT_H
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- StringTableBuilder.h - String table building utility ------*- C++ -*-=//
|
//===- StringTableBuilder.h - String table building utility -----*- C++ -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -12,9 +12,12 @@
|
|||||||
|
|
||||||
#include "llvm/ADT/CachedHashString.h"
|
#include "llvm/ADT/CachedHashString.h"
|
||||||
#include "llvm/ADT/DenseMap.h"
|
#include "llvm/ADT/DenseMap.h"
|
||||||
#include <cassert>
|
#include "llvm/ADT/StringRef.h"
|
||||||
|
#include <cstddef>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
class raw_ostream;
|
class raw_ostream;
|
||||||
|
|
||||||
/// \brief Utility for building string tables with deduplicated suffixes.
|
/// \brief Utility for building string tables with deduplicated suffixes.
|
||||||
@ -67,6 +70,6 @@ private:
|
|||||||
bool isFinalized() const { return Finalized; }
|
bool isFinalized() const { return Finalized; }
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end llvm namespace
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif
|
#endif // LLVM_MC_STRINGTABLEBUILDER_H
|
||||||
|
@ -11,30 +11,49 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/MC/MCELFObjectWriter.h"
|
#include "llvm/ADT/ArrayRef.h"
|
||||||
#include "llvm/ADT/STLExtras.h"
|
#include "llvm/ADT/DenseMap.h"
|
||||||
#include "llvm/ADT/SmallPtrSet.h"
|
|
||||||
#include "llvm/ADT/SmallString.h"
|
#include "llvm/ADT/SmallString.h"
|
||||||
#include "llvm/ADT/StringMap.h"
|
#include "llvm/ADT/SmallVector.h"
|
||||||
#include "llvm/MC/MCAsmBackend.h"
|
#include "llvm/ADT/STLExtras.h"
|
||||||
|
#include "llvm/ADT/StringRef.h"
|
||||||
|
#include "llvm/ADT/Twine.h"
|
||||||
#include "llvm/MC/MCAsmInfo.h"
|
#include "llvm/MC/MCAsmInfo.h"
|
||||||
#include "llvm/MC/MCAsmLayout.h"
|
#include "llvm/MC/MCAsmLayout.h"
|
||||||
#include "llvm/MC/MCAssembler.h"
|
#include "llvm/MC/MCAssembler.h"
|
||||||
#include "llvm/MC/MCContext.h"
|
#include "llvm/MC/MCContext.h"
|
||||||
|
#include "llvm/MC/MCELFObjectWriter.h"
|
||||||
#include "llvm/MC/MCExpr.h"
|
#include "llvm/MC/MCExpr.h"
|
||||||
#include "llvm/MC/MCFixupKindInfo.h"
|
#include "llvm/MC/MCFixup.h"
|
||||||
|
#include "llvm/MC/MCFragment.h"
|
||||||
#include "llvm/MC/MCObjectWriter.h"
|
#include "llvm/MC/MCObjectWriter.h"
|
||||||
|
#include "llvm/MC/MCSection.h"
|
||||||
#include "llvm/MC/MCSectionELF.h"
|
#include "llvm/MC/MCSectionELF.h"
|
||||||
|
#include "llvm/MC/MCSymbol.h"
|
||||||
#include "llvm/MC/MCSymbolELF.h"
|
#include "llvm/MC/MCSymbolELF.h"
|
||||||
#include "llvm/MC/MCValue.h"
|
#include "llvm/MC/MCValue.h"
|
||||||
#include "llvm/MC/StringTableBuilder.h"
|
#include "llvm/MC/StringTableBuilder.h"
|
||||||
|
#include "llvm/Support/Allocator.h"
|
||||||
|
#include "llvm/Support/Casting.h"
|
||||||
#include "llvm/Support/Compression.h"
|
#include "llvm/Support/Compression.h"
|
||||||
#include "llvm/Support/Debug.h"
|
|
||||||
#include "llvm/Support/ELF.h"
|
#include "llvm/Support/ELF.h"
|
||||||
#include "llvm/Support/Endian.h"
|
#include "llvm/Support/Endian.h"
|
||||||
#include "llvm/Support/Error.h"
|
#include "llvm/Support/Error.h"
|
||||||
#include "llvm/Support/ErrorHandling.h"
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
|
#include "llvm/Support/Host.h"
|
||||||
|
#include "llvm/Support/MathExtras.h"
|
||||||
|
#include "llvm/Support/SMLoc.h"
|
||||||
#include "llvm/Support/StringSaver.h"
|
#include "llvm/Support/StringSaver.h"
|
||||||
|
#include "llvm/Support/SwapByteOrder.h"
|
||||||
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
#include <algorithm>
|
||||||
|
#include <cassert>
|
||||||
|
#include <cstddef>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <map>
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
@ -43,6 +62,7 @@ using namespace llvm;
|
|||||||
#define DEBUG_TYPE "reloc-info"
|
#define DEBUG_TYPE "reloc-info"
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
typedef DenseMap<const MCSectionELF *, uint32_t> SectionIndexMapTy;
|
typedef DenseMap<const MCSectionELF *, uint32_t> SectionIndexMapTy;
|
||||||
|
|
||||||
class ELFObjectWriter;
|
class ELFObjectWriter;
|
||||||
@ -100,8 +120,7 @@ class ELFObjectWriter : public MCObjectWriter {
|
|||||||
|
|
||||||
DenseMap<const MCSymbolELF *, const MCSymbolELF *> Renames;
|
DenseMap<const MCSymbolELF *, const MCSymbolELF *> Renames;
|
||||||
|
|
||||||
llvm::DenseMap<const MCSectionELF *, std::vector<ELFRelocationEntry>>
|
DenseMap<const MCSectionELF *, std::vector<ELFRelocationEntry>> Relocations;
|
||||||
Relocations;
|
|
||||||
|
|
||||||
/// @}
|
/// @}
|
||||||
/// @name Symbol Table Data
|
/// @name Symbol Table Data
|
||||||
@ -145,6 +164,8 @@ public:
|
|||||||
bool IsLittleEndian)
|
bool IsLittleEndian)
|
||||||
: MCObjectWriter(OS, IsLittleEndian), TargetObjectWriter(MOTW) {}
|
: MCObjectWriter(OS, IsLittleEndian), TargetObjectWriter(MOTW) {}
|
||||||
|
|
||||||
|
~ELFObjectWriter() override = default;
|
||||||
|
|
||||||
void reset() override {
|
void reset() override {
|
||||||
Renames.clear();
|
Renames.clear();
|
||||||
Relocations.clear();
|
Relocations.clear();
|
||||||
@ -153,8 +174,6 @@ public:
|
|||||||
MCObjectWriter::reset();
|
MCObjectWriter::reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
~ELFObjectWriter() override;
|
|
||||||
|
|
||||||
void WriteWord(uint64_t W) {
|
void WriteWord(uint64_t W) {
|
||||||
if (is64Bit())
|
if (is64Bit())
|
||||||
write64(W);
|
write64(W);
|
||||||
@ -235,6 +254,7 @@ public:
|
|||||||
uint32_t GroupSymbolIndex, uint64_t Offset, uint64_t Size,
|
uint32_t GroupSymbolIndex, uint64_t Offset, uint64_t Size,
|
||||||
const MCSectionELF &Section);
|
const MCSectionELF &Section);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end anonymous namespace
|
} // end anonymous namespace
|
||||||
|
|
||||||
void ELFObjectWriter::align(unsigned Alignment) {
|
void ELFObjectWriter::align(unsigned Alignment) {
|
||||||
@ -298,9 +318,6 @@ void SymbolTableWriter::writeSymbol(uint32_t name, uint8_t info, uint64_t value,
|
|||||||
++NumWritten;
|
++NumWritten;
|
||||||
}
|
}
|
||||||
|
|
||||||
ELFObjectWriter::~ELFObjectWriter()
|
|
||||||
{}
|
|
||||||
|
|
||||||
// Emit the ELF header.
|
// Emit the ELF header.
|
||||||
void ELFObjectWriter::writeHeader(const MCAssembler &Asm) {
|
void ELFObjectWriter::writeHeader(const MCAssembler &Asm) {
|
||||||
// ELF Header
|
// ELF Header
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCAsmInfo.cpp - Asm Info -------------------------------------------==//
|
//===- MCAsmInfo.cpp - Asm Info -------------------------------------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -16,29 +16,14 @@
|
|||||||
#include "llvm/MC/MCContext.h"
|
#include "llvm/MC/MCContext.h"
|
||||||
#include "llvm/MC/MCExpr.h"
|
#include "llvm/MC/MCExpr.h"
|
||||||
#include "llvm/MC/MCStreamer.h"
|
#include "llvm/MC/MCStreamer.h"
|
||||||
#include "llvm/Support/DataTypes.h"
|
|
||||||
#include "llvm/Support/Dwarf.h"
|
#include "llvm/Support/Dwarf.h"
|
||||||
#include <cctype>
|
|
||||||
#include <cstring>
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
MCAsmInfo::MCAsmInfo() {
|
MCAsmInfo::MCAsmInfo() {
|
||||||
PointerSize = 4;
|
|
||||||
CalleeSaveStackSlotSize = 4;
|
|
||||||
|
|
||||||
IsLittleEndian = true;
|
|
||||||
StackGrowsUp = false;
|
|
||||||
HasSubsectionsViaSymbols = false;
|
|
||||||
HasMachoZeroFillDirective = false;
|
|
||||||
HasMachoTBSSDirective = false;
|
|
||||||
MaxInstLength = 4;
|
|
||||||
MinInstAlignment = 1;
|
|
||||||
DollarIsPC = false;
|
|
||||||
SeparatorString = ";";
|
SeparatorString = ";";
|
||||||
CommentString = "#";
|
CommentString = "#";
|
||||||
LabelSuffix = ":";
|
LabelSuffix = ":";
|
||||||
UseAssignmentForEHBegin = false;
|
|
||||||
NeedsLocalForSize = false;
|
|
||||||
PrivateGlobalPrefix = "L";
|
PrivateGlobalPrefix = "L";
|
||||||
PrivateLabelPrefix = PrivateGlobalPrefix;
|
PrivateLabelPrefix = PrivateGlobalPrefix;
|
||||||
LinkerPrivateGlobalPrefix = "";
|
LinkerPrivateGlobalPrefix = "";
|
||||||
@ -47,10 +32,6 @@ MCAsmInfo::MCAsmInfo() {
|
|||||||
Code16Directive = ".code16";
|
Code16Directive = ".code16";
|
||||||
Code32Directive = ".code32";
|
Code32Directive = ".code32";
|
||||||
Code64Directive = ".code64";
|
Code64Directive = ".code64";
|
||||||
AssemblerDialect = 0;
|
|
||||||
AllowAtInName = false;
|
|
||||||
SupportsQuotedNames = true;
|
|
||||||
UseDataRegionDirectives = false;
|
|
||||||
ZeroDirective = "\t.zero\t";
|
ZeroDirective = "\t.zero\t";
|
||||||
AsciiDirective = "\t.ascii\t";
|
AsciiDirective = "\t.ascii\t";
|
||||||
AscizDirective = "\t.asciz\t";
|
AscizDirective = "\t.asciz\t";
|
||||||
@ -58,40 +39,8 @@ MCAsmInfo::MCAsmInfo() {
|
|||||||
Data16bitsDirective = "\t.short\t";
|
Data16bitsDirective = "\t.short\t";
|
||||||
Data32bitsDirective = "\t.long\t";
|
Data32bitsDirective = "\t.long\t";
|
||||||
Data64bitsDirective = "\t.quad\t";
|
Data64bitsDirective = "\t.quad\t";
|
||||||
SunStyleELFSectionSwitchSyntax = false;
|
|
||||||
UsesELFSectionDirectiveForBSS = false;
|
|
||||||
AlignmentIsInBytes = true;
|
|
||||||
TextAlignFillValue = 0;
|
|
||||||
GPRel64Directive = nullptr;
|
|
||||||
GPRel32Directive = nullptr;
|
|
||||||
GlobalDirective = "\t.globl\t";
|
GlobalDirective = "\t.globl\t";
|
||||||
SetDirectiveSuppressesReloc = false;
|
|
||||||
HasAggressiveSymbolFolding = true;
|
|
||||||
COMMDirectiveAlignmentIsInBytes = true;
|
|
||||||
LCOMMDirectiveAlignmentType = LCOMM::NoAlignment;
|
|
||||||
HasFunctionAlignment = true;
|
|
||||||
HasDotTypeDotSizeDirective = true;
|
|
||||||
HasSingleParameterDotFile = true;
|
|
||||||
HasIdentDirective = false;
|
|
||||||
HasNoDeadStrip = false;
|
|
||||||
HasAltEntry = false;
|
|
||||||
WeakDirective = "\t.weak\t";
|
WeakDirective = "\t.weak\t";
|
||||||
WeakRefDirective = nullptr;
|
|
||||||
HasWeakDefDirective = false;
|
|
||||||
HasWeakDefCanBeHiddenDirective = false;
|
|
||||||
HasLinkOnceDirective = false;
|
|
||||||
HiddenVisibilityAttr = MCSA_Hidden;
|
|
||||||
HiddenDeclarationVisibilityAttr = MCSA_Hidden;
|
|
||||||
ProtectedVisibilityAttr = MCSA_Protected;
|
|
||||||
SupportsDebugInformation = false;
|
|
||||||
ExceptionsType = ExceptionHandling::None;
|
|
||||||
WinEHEncodingType = WinEH::EncodingType::Invalid;
|
|
||||||
DwarfUsesRelocationsAcrossSections = true;
|
|
||||||
DwarfFDESymbolsUseAbsDiff = false;
|
|
||||||
DwarfRegNumForCFI = false;
|
|
||||||
NeedsDwarfSectionOffsetDirective = false;
|
|
||||||
UseParensForSymbolVariant = false;
|
|
||||||
UseLogicalShr = true;
|
|
||||||
|
|
||||||
// FIXME: Clang's logic should be synced with the logic used to initialize
|
// FIXME: Clang's logic should be synced with the logic used to initialize
|
||||||
// this member and the two implementations should be merged.
|
// this member and the two implementations should be merged.
|
||||||
@ -107,12 +56,9 @@ MCAsmInfo::MCAsmInfo() {
|
|||||||
// - The target subclasses for AArch64, ARM, and X86 handle these cases
|
// - The target subclasses for AArch64, ARM, and X86 handle these cases
|
||||||
UseIntegratedAssembler = false;
|
UseIntegratedAssembler = false;
|
||||||
PreserveAsmComments = true;
|
PreserveAsmComments = true;
|
||||||
|
|
||||||
CompressDebugSections = DebugCompressionType::DCT_None;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MCAsmInfo::~MCAsmInfo() {
|
MCAsmInfo::~MCAsmInfo() = default;
|
||||||
}
|
|
||||||
|
|
||||||
bool MCAsmInfo::isSectionAtomizableBySymbols(const MCSection &Section) const {
|
bool MCAsmInfo::isSectionAtomizableBySymbols(const MCSection &Section) const {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCAsmInfoCOFF.cpp - COFF asm properties -----------------*- C++ -*-===//
|
//===- MCAsmInfoCOFF.cpp - COFF asm properties ----------------------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -13,9 +13,11 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/MC/MCAsmInfoCOFF.h"
|
#include "llvm/MC/MCAsmInfoCOFF.h"
|
||||||
|
#include "llvm/MC/MCDirectives.h"
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
void MCAsmInfoCOFF::anchor() { }
|
void MCAsmInfoCOFF::anchor() {}
|
||||||
|
|
||||||
MCAsmInfoCOFF::MCAsmInfoCOFF() {
|
MCAsmInfoCOFF::MCAsmInfoCOFF() {
|
||||||
// MingW 4.5 and later support .comm with log2 alignment, but .lcomm uses byte
|
// MingW 4.5 and later support .comm with log2 alignment, but .lcomm uses byte
|
||||||
@ -41,13 +43,10 @@ MCAsmInfoCOFF::MCAsmInfoCOFF() {
|
|||||||
UseLogicalShr = false;
|
UseLogicalShr = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MCAsmInfoMicrosoft::anchor() { }
|
void MCAsmInfoMicrosoft::anchor() {}
|
||||||
|
|
||||||
MCAsmInfoMicrosoft::MCAsmInfoMicrosoft() {
|
MCAsmInfoMicrosoft::MCAsmInfoMicrosoft() = default;
|
||||||
}
|
|
||||||
|
|
||||||
void MCAsmInfoGNUCOFF::anchor() { }
|
void MCAsmInfoGNUCOFF::anchor() {}
|
||||||
|
|
||||||
MCAsmInfoGNUCOFF::MCAsmInfoGNUCOFF() {
|
MCAsmInfoGNUCOFF::MCAsmInfoGNUCOFF() = default;
|
||||||
|
|
||||||
}
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCAsmInfoDarwin.cpp - Darwin asm properties -------------*- C++ -*-===//
|
//===- MCAsmInfoDarwin.cpp - Darwin asm properties ------------------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -13,9 +13,10 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/MC/MCAsmInfoDarwin.h"
|
#include "llvm/MC/MCAsmInfoDarwin.h"
|
||||||
#include "llvm/MC/MCContext.h"
|
#include "llvm/MC/MCDirectives.h"
|
||||||
#include "llvm/MC/MCExpr.h"
|
|
||||||
#include "llvm/MC/MCSectionMachO.h"
|
#include "llvm/MC/MCSectionMachO.h"
|
||||||
|
#include "llvm/Support/MachO.h"
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
bool MCAsmInfoDarwin::isSectionAtomizableBySymbols(
|
bool MCAsmInfoDarwin::isSectionAtomizableBySymbols(
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCAsmInfoELF.cpp - ELF asm properties -------------------*- C++ -*-===//
|
//===- MCAsmInfoELF.cpp - ELF asm properties ------------------------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -16,9 +16,10 @@
|
|||||||
#include "llvm/MC/MCContext.h"
|
#include "llvm/MC/MCContext.h"
|
||||||
#include "llvm/MC/MCSectionELF.h"
|
#include "llvm/MC/MCSectionELF.h"
|
||||||
#include "llvm/Support/ELF.h"
|
#include "llvm/Support/ELF.h"
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
void MCAsmInfoELF::anchor() { }
|
void MCAsmInfoELF::anchor() {}
|
||||||
|
|
||||||
MCSection *MCAsmInfoELF::getNonexecutableStackSection(MCContext &Ctx) const {
|
MCSection *MCAsmInfoELF::getNonexecutableStackSection(MCContext &Ctx) const {
|
||||||
if (!UsesNonexecutableStackSection)
|
if (!UsesNonexecutableStackSection)
|
||||||
@ -31,5 +32,4 @@ MCAsmInfoELF::MCAsmInfoELF() {
|
|||||||
WeakRefDirective = "\t.weak\t";
|
WeakRefDirective = "\t.weak\t";
|
||||||
PrivateGlobalPrefix = ".L";
|
PrivateGlobalPrefix = ".L";
|
||||||
PrivateLabelPrefix = ".L";
|
PrivateLabelPrefix = ".L";
|
||||||
UsesNonexecutableStackSection = true;
|
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "llvm/MC/MCInst.h"
|
#include "llvm/MC/MCInst.h"
|
||||||
#include "llvm/MC/MCExpr.h"
|
#include "llvm/MC/MCExpr.h"
|
||||||
#include "llvm/MC/MCInstPrinter.h"
|
#include "llvm/MC/MCInstPrinter.h"
|
||||||
|
#include "llvm/Support/Compiler.h"
|
||||||
#include "llvm/Support/Debug.h"
|
#include "llvm/Support/Debug.h"
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCInstPrinter.cpp - Convert an MCInst to target assembly syntax ---===//
|
//===- MCInstPrinter.cpp - Convert an MCInst to target assembly syntax ----===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -7,13 +7,17 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/MC/MCInstPrinter.h"
|
#include "llvm/ADT/ArrayRef.h"
|
||||||
#include "llvm/ADT/StringRef.h"
|
#include "llvm/ADT/StringRef.h"
|
||||||
#include "llvm/MC/MCAsmInfo.h"
|
#include "llvm/MC/MCAsmInfo.h"
|
||||||
|
#include "llvm/MC/MCInstPrinter.h"
|
||||||
#include "llvm/MC/MCInstrInfo.h"
|
#include "llvm/MC/MCInstrInfo.h"
|
||||||
#include "llvm/Support/ErrorHandling.h"
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
#include "llvm/Support/Format.h"
|
#include "llvm/Support/Format.h"
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
#include <cinttypes>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
void llvm::dumpBytes(ArrayRef<uint8_t> bytes, raw_ostream &OS) {
|
void llvm::dumpBytes(ArrayRef<uint8_t> bytes, raw_ostream &OS) {
|
||||||
@ -25,8 +29,7 @@ void llvm::dumpBytes(ArrayRef<uint8_t> bytes, raw_ostream &OS) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MCInstPrinter::~MCInstPrinter() {
|
MCInstPrinter::~MCInstPrinter() = default;
|
||||||
}
|
|
||||||
|
|
||||||
/// getOpcodeName - Return the name of the specified opcode enum (e.g.
|
/// getOpcodeName - Return the name of the specified opcode enum (e.g.
|
||||||
/// "MOV32ri") or empty if we can't resolve it.
|
/// "MOV32ri") or empty if we can't resolve it.
|
||||||
@ -68,7 +71,7 @@ StringRef MCInstPrinter::markup(StringRef a, StringRef b) const {
|
|||||||
// For asm-style hex (e.g. 0ffh) the first digit always has to be a number.
|
// For asm-style hex (e.g. 0ffh) the first digit always has to be a number.
|
||||||
static bool needsLeadingZero(uint64_t Value)
|
static bool needsLeadingZero(uint64_t Value)
|
||||||
{
|
{
|
||||||
while(Value)
|
while (Value)
|
||||||
{
|
{
|
||||||
uint64_t digit = (Value >> 60) & 0xf;
|
uint64_t digit = (Value >> 60) & 0xf;
|
||||||
if (digit != 0)
|
if (digit != 0)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCInstrAnalysis.cpp - InstrDesc target hooks ------------*- C++ -*-===//
|
//===- MCInstrAnalysis.cpp - InstrDesc target hooks -----------------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -7,7 +7,12 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "llvm/MC/MCInst.h"
|
||||||
#include "llvm/MC/MCInstrAnalysis.h"
|
#include "llvm/MC/MCInstrAnalysis.h"
|
||||||
|
#include "llvm/MC/MCInstrDesc.h"
|
||||||
|
#include "llvm/MC/MCInstrInfo.h"
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
bool MCInstrAnalysis::evaluateBranch(const MCInst &Inst, uint64_t Addr,
|
bool MCInstrAnalysis::evaluateBranch(const MCInst &Inst, uint64_t Addr,
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- llvm/MC/MCLinkerOptimizationHint.cpp ----- LOH handling -*- C++ -*-===//
|
//===- llvm/MC/MCLinkerOptimizationHint.cpp ----- LOH handling ------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -9,9 +9,11 @@
|
|||||||
|
|
||||||
#include "llvm/MC/MCLinkerOptimizationHint.h"
|
#include "llvm/MC/MCLinkerOptimizationHint.h"
|
||||||
#include "llvm/MC/MCAsmLayout.h"
|
#include "llvm/MC/MCAsmLayout.h"
|
||||||
#include "llvm/MC/MCAssembler.h"
|
|
||||||
#include "llvm/MC/MCMachObjectWriter.h"
|
#include "llvm/MC/MCMachObjectWriter.h"
|
||||||
#include "llvm/Support/LEB128.h"
|
#include "llvm/Support/LEB128.h"
|
||||||
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
#include <cstddef>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
@ -41,14 +43,14 @@ void MCLOHDirective::emit(MachObjectWriter &ObjWriter,
|
|||||||
uint64_t MCLOHDirective::getEmitSize(const MachObjectWriter &ObjWriter,
|
uint64_t MCLOHDirective::getEmitSize(const MachObjectWriter &ObjWriter,
|
||||||
const MCAsmLayout &Layout) const {
|
const MCAsmLayout &Layout) const {
|
||||||
class raw_counting_ostream : public raw_ostream {
|
class raw_counting_ostream : public raw_ostream {
|
||||||
uint64_t Count;
|
uint64_t Count = 0;
|
||||||
|
|
||||||
void write_impl(const char *, size_t size) override { Count += size; }
|
void write_impl(const char *, size_t size) override { Count += size; }
|
||||||
|
|
||||||
uint64_t current_pos() const override { return Count; }
|
uint64_t current_pos() const override { return Count; }
|
||||||
|
|
||||||
public:
|
public:
|
||||||
raw_counting_ostream() : Count(0) {}
|
raw_counting_ostream() = default;
|
||||||
~raw_counting_ostream() override { flush(); }
|
~raw_counting_ostream() override { flush(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- MCMachObjectTargetWriter.cpp - Mach-O Target Writer Subclass ------===//
|
//===- MCMachObjectTargetWriter.cpp - Mach-O Target Writer Subclass -------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -16,4 +16,4 @@ MCMachObjectTargetWriter::MCMachObjectTargetWriter(bool Is64Bit_,
|
|||||||
uint32_t CPUSubtype_)
|
uint32_t CPUSubtype_)
|
||||||
: Is64Bit(Is64Bit_), CPUType(CPUType_), CPUSubtype(CPUSubtype_) {}
|
: Is64Bit(Is64Bit_), CPUType(CPUType_), CPUSubtype(CPUSubtype_) {}
|
||||||
|
|
||||||
MCMachObjectTargetWriter::~MCMachObjectTargetWriter() {}
|
MCMachObjectTargetWriter::~MCMachObjectTargetWriter() = default;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//===-- StringTableBuilder.cpp - String table building utility ------------===//
|
//===- StringTableBuilder.cpp - String table building utility -------------===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
@ -7,18 +7,24 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/MC/StringTableBuilder.h"
|
#include "llvm/ADT/CachedHashString.h"
|
||||||
#include "llvm/ADT/STLExtras.h"
|
|
||||||
#include "llvm/ADT/SmallString.h"
|
#include "llvm/ADT/SmallString.h"
|
||||||
|
#include "llvm/ADT/StringRef.h"
|
||||||
|
#include "llvm/MC/StringTableBuilder.h"
|
||||||
#include "llvm/Support/COFF.h"
|
#include "llvm/Support/COFF.h"
|
||||||
#include "llvm/Support/Endian.h"
|
#include "llvm/Support/Endian.h"
|
||||||
|
#include "llvm/Support/MathExtras.h"
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
#include <cassert>
|
||||||
|
#include <cstddef>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <cstring>
|
||||||
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
StringTableBuilder::~StringTableBuilder() {}
|
StringTableBuilder::~StringTableBuilder() = default;
|
||||||
|
|
||||||
void StringTableBuilder::initSize() {
|
void StringTableBuilder::initSize() {
|
||||||
// Account for leading bytes in table so that offsets returned from add are
|
// Account for leading bytes in table so that offsets returned from add are
|
||||||
|
Loading…
x
Reference in New Issue
Block a user