mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-09 11:25:55 +00:00
Enable DebugInfo support for COFF object files.
Patch by Nathan Jeffords! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@126425 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -239,6 +239,11 @@ namespace llvm {
|
|||||||
/// EndCOFFSymbolDef - Marks the end of the symbol definition.
|
/// EndCOFFSymbolDef - Marks the end of the symbol definition.
|
||||||
virtual void EndCOFFSymbolDef() = 0;
|
virtual void EndCOFFSymbolDef() = 0;
|
||||||
|
|
||||||
|
/// EmitCOFFSecRel32 - Emits a COFF section relative relocation.
|
||||||
|
///
|
||||||
|
/// @param Symbol - Symbol the section relative realocation should point to.
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol) = 0;
|
||||||
|
|
||||||
/// EmitELFSize - Emit an ELF .size directive.
|
/// EmitELFSize - Emit an ELF .size directive.
|
||||||
///
|
///
|
||||||
/// This corresponds to an assembler statement such as:
|
/// This corresponds to an assembler statement such as:
|
||||||
|
@@ -178,8 +178,7 @@ void AsmPrinter::EmitSectionOffset(const MCSymbol *Label,
|
|||||||
const MCSymbol *SectionLabel) const {
|
const MCSymbol *SectionLabel) const {
|
||||||
// On COFF targets, we have to emit the special .secrel32 directive.
|
// On COFF targets, we have to emit the special .secrel32 directive.
|
||||||
if (const char *SecOffDir = MAI->getDwarfSectionOffsetDirective()) {
|
if (const char *SecOffDir = MAI->getDwarfSectionOffsetDirective()) {
|
||||||
// FIXME: MCize.
|
OutStreamer.EmitCOFFSecRel32(Label);
|
||||||
OutStreamer.EmitRawText(SecOffDir + Twine(Label->getName()));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -276,6 +276,29 @@ void DIELabel::print(raw_ostream &O) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
// DIESectionOffset Implementation
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
/// EmitValue - Emit label value.
|
||||||
|
///
|
||||||
|
void DIESectionOffset::EmitValue(AsmPrinter *AP, unsigned Form) const {
|
||||||
|
AP->EmitSectionOffset (Label, Label);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// SizeOf - Determine size of label value in bytes.
|
||||||
|
///
|
||||||
|
unsigned DIESectionOffset::SizeOf(AsmPrinter *AP, unsigned Form) const {
|
||||||
|
if (Form == dwarf::DW_FORM_data4) return 4;
|
||||||
|
return AP->getTargetData().getPointerSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef NDEBUG
|
||||||
|
void DIESectionOffset::print(raw_ostream &O) {
|
||||||
|
O << "SecRelLbl: " << Label->getName();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// DIEDelta Implementation
|
// DIEDelta Implementation
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
@@ -327,6 +327,36 @@ namespace llvm {
|
|||||||
static bool classof(const DIELabel *) { return true; }
|
static bool classof(const DIELabel *) { return true; }
|
||||||
static bool classof(const DIEValue *L) { return L->getType() == isLabel; }
|
static bool classof(const DIEValue *L) { return L->getType() == isLabel; }
|
||||||
|
|
||||||
|
#ifndef NDEBUG
|
||||||
|
virtual void print(raw_ostream &O);
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
//===--------------------------------------------------------------------===//
|
||||||
|
/// DIESectionOffset - A section relative label expression DIE.
|
||||||
|
//
|
||||||
|
class DIESectionOffset : public DIEValue {
|
||||||
|
const MCSymbol *Label;
|
||||||
|
public:
|
||||||
|
explicit DIESectionOffset(const MCSymbol *L) : DIEValue(isSectionOffset),
|
||||||
|
Label(L) {}
|
||||||
|
|
||||||
|
/// EmitValue - Emit label value.
|
||||||
|
///
|
||||||
|
virtual void EmitValue(AsmPrinter *AP, unsigned Form) const;
|
||||||
|
|
||||||
|
/// getValue - Get MCSymbol.
|
||||||
|
///
|
||||||
|
const MCSymbol *getValue() const { return Label; }
|
||||||
|
|
||||||
|
/// SizeOf - Determine size of label value in bytes.
|
||||||
|
///
|
||||||
|
virtual unsigned SizeOf(AsmPrinter *AP, unsigned Form) const;
|
||||||
|
|
||||||
|
// Implement isa/cast/dyncast.
|
||||||
|
static bool classof(const DIELabel *) { return true; }
|
||||||
|
static bool classof(const DIEValue *L) { return L->getType() == isSectionOffset; }
|
||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
virtual void print(raw_ostream &O);
|
virtual void print(raw_ostream &O);
|
||||||
#endif
|
#endif
|
||||||
|
@@ -481,6 +481,15 @@ void DwarfDebug::addLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
|||||||
Die->addValue(Attribute, Form, Value);
|
Die->addValue(Attribute, Form, Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// addSectionOffset - Add a Dwarf section relative label attribute data and
|
||||||
|
/// value.
|
||||||
|
///
|
||||||
|
void DwarfDebug::addSectionOffset(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
|
const MCSymbol *Label) {
|
||||||
|
DIEValue *Value = new (DIEValueAllocator) DIESectionOffset(Label);
|
||||||
|
Die->addValue(Attribute, Form, Value);
|
||||||
|
}
|
||||||
|
|
||||||
/// addDelta - Add a label delta attribute data and value.
|
/// addDelta - Add a label delta attribute data and value.
|
||||||
///
|
///
|
||||||
void DwarfDebug::addDelta(DIE *Die, unsigned Attribute, unsigned Form,
|
void DwarfDebug::addDelta(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
@@ -1904,8 +1913,8 @@ void DwarfDebug::constructCompileUnit(const MDNode *N) {
|
|||||||
// DW_AT_stmt_list is a offset of line number information for this
|
// DW_AT_stmt_list is a offset of line number information for this
|
||||||
// compile unit in debug_line section.
|
// compile unit in debug_line section.
|
||||||
if (Asm->MAI->doesDwarfUsesAbsoluteLabelForStmtList())
|
if (Asm->MAI->doesDwarfUsesAbsoluteLabelForStmtList())
|
||||||
addLabel(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_addr,
|
addSectionOffset(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_addr,
|
||||||
Asm->GetTempSymbol("section_line"));
|
Asm->GetTempSymbol("section_line"));
|
||||||
else
|
else
|
||||||
addUInt(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_data4, 0);
|
addUInt(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_data4, 0);
|
||||||
|
|
||||||
|
@@ -280,6 +280,12 @@ private:
|
|||||||
void addLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
void addLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
const MCSymbol *Label);
|
const MCSymbol *Label);
|
||||||
|
|
||||||
|
/// addSectionOffset - Add a Dwarf section relative label attribute data and
|
||||||
|
/// value.
|
||||||
|
///
|
||||||
|
void addSectionOffset(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
|
const MCSymbol *Label);
|
||||||
|
|
||||||
/// addDelta - Add a label delta attribute data and value.
|
/// addDelta - Add a label delta attribute data and value.
|
||||||
///
|
///
|
||||||
void addDelta(DIE *Die, unsigned Attribute, unsigned Form,
|
void addDelta(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
|
@@ -33,5 +33,6 @@ MCAsmInfoCOFF::MCAsmInfoCOFF() {
|
|||||||
HasLEB128 = true; // Target asm supports leb128 directives (little-endian)
|
HasLEB128 = true; // Target asm supports leb128 directives (little-endian)
|
||||||
SupportsDebugInformation = true;
|
SupportsDebugInformation = true;
|
||||||
DwarfSectionOffsetDirective = "\t.secrel32\t";
|
DwarfSectionOffsetDirective = "\t.secrel32\t";
|
||||||
|
DwarfUsesAbsoluteLabelForStmtList = false;
|
||||||
HasMicrosoftFastStdCallMangling = true;
|
HasMicrosoftFastStdCallMangling = true;
|
||||||
}
|
}
|
||||||
|
@@ -135,6 +135,7 @@ public:
|
|||||||
virtual void EmitCOFFSymbolStorageClass(int StorageClass);
|
virtual void EmitCOFFSymbolStorageClass(int StorageClass);
|
||||||
virtual void EmitCOFFSymbolType(int Type);
|
virtual void EmitCOFFSymbolType(int Type);
|
||||||
virtual void EndCOFFSymbolDef();
|
virtual void EndCOFFSymbolDef();
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol);
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value);
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value);
|
||||||
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
||||||
unsigned ByteAlignment);
|
unsigned ByteAlignment);
|
||||||
@@ -384,6 +385,11 @@ void MCAsmStreamer::EndCOFFSymbolDef() {
|
|||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MCAsmStreamer::EmitCOFFSecRel32(MCSymbol const *Symbol) {
|
||||||
|
OS << "\t.secrel32\t" << *Symbol << '\n';
|
||||||
|
EmitEOL();
|
||||||
|
}
|
||||||
|
|
||||||
void MCAsmStreamer::EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
void MCAsmStreamer::EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
||||||
assert(MAI.hasDotTypeDotSizeDirective());
|
assert(MAI.hasDotTypeDotSizeDirective());
|
||||||
OS << "\t.size\t" << *Symbol << ", " << *Value << '\n';
|
OS << "\t.size\t" << *Symbol << ", " << *Value << '\n';
|
||||||
|
@@ -108,6 +108,10 @@ public:
|
|||||||
assert(0 && "ELF doesn't support this directive");
|
assert(0 && "ELF doesn't support this directive");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol) {
|
||||||
|
assert(0 && "ELF doesn't support this directive");
|
||||||
|
}
|
||||||
|
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
||||||
MCSymbolData &SD = getAssembler().getOrCreateSymbolData(*Symbol);
|
MCSymbolData &SD = getAssembler().getOrCreateSymbolData(*Symbol);
|
||||||
SD.setSize(Value);
|
SD.setSize(Value);
|
||||||
|
@@ -120,6 +120,11 @@ public:
|
|||||||
return Child->EndCOFFSymbolDef();
|
return Child->EndCOFFSymbolDef();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol) {
|
||||||
|
LogCall("EndCOFFSymbolDef");
|
||||||
|
return Child->EmitCOFFSecRel32(Symbol);
|
||||||
|
}
|
||||||
|
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
||||||
LogCall("EmitELFSize");
|
LogCall("EmitELFSize");
|
||||||
return Child->EmitELFSize(Symbol, Value);
|
return Child->EmitELFSize(Symbol, Value);
|
||||||
|
@@ -63,6 +63,9 @@ public:
|
|||||||
virtual void EndCOFFSymbolDef() {
|
virtual void EndCOFFSymbolDef() {
|
||||||
assert(0 && "macho doesn't support this directive");
|
assert(0 && "macho doesn't support this directive");
|
||||||
}
|
}
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol) {
|
||||||
|
assert(0 && "macho doesn't support this directive");
|
||||||
|
}
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
||||||
assert(0 && "macho doesn't support this directive");
|
assert(0 && "macho doesn't support this directive");
|
||||||
}
|
}
|
||||||
|
@@ -54,6 +54,7 @@ namespace {
|
|||||||
virtual void EmitCOFFSymbolStorageClass(int StorageClass) {}
|
virtual void EmitCOFFSymbolStorageClass(int StorageClass) {}
|
||||||
virtual void EmitCOFFSymbolType(int Type) {}
|
virtual void EmitCOFFSymbolType(int Type) {}
|
||||||
virtual void EndCOFFSymbolDef() {}
|
virtual void EndCOFFSymbolDef() {}
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol) {}
|
||||||
|
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {}
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {}
|
||||||
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
||||||
|
@@ -83,6 +83,9 @@ public:
|
|||||||
virtual void EndCOFFSymbolDef() {
|
virtual void EndCOFFSymbolDef() {
|
||||||
report_fatal_error("unsupported directive in pure streamer");
|
report_fatal_error("unsupported directive in pure streamer");
|
||||||
}
|
}
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol) {
|
||||||
|
report_fatal_error("unsupported directive in pure streamer");
|
||||||
|
}
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
||||||
report_fatal_error("unsupported directive in pure streamer");
|
report_fatal_error("unsupported directive in pure streamer");
|
||||||
}
|
}
|
||||||
|
@@ -705,6 +705,10 @@ void WinCOFFObjectWriter::RecordRelocation(const MCAssembler &Asm,
|
|||||||
else
|
else
|
||||||
llvm_unreachable("unsupported relocation type");
|
llvm_unreachable("unsupported relocation type");
|
||||||
break;
|
break;
|
||||||
|
case X86::reloc_coff_secrel32:
|
||||||
|
Reloc.Data.Type = Is64Bit ? COFF::IMAGE_REL_AMD64_SREL32
|
||||||
|
: COFF::IMAGE_REL_I386_SECREL;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("unsupported relocation type");
|
llvm_unreachable("unsupported relocation type");
|
||||||
}
|
}
|
||||||
|
@@ -31,6 +31,9 @@
|
|||||||
#include "llvm/Support/Debug.h"
|
#include "llvm/Support/Debug.h"
|
||||||
#include "llvm/Support/ErrorHandling.h"
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
|
||||||
|
#include "../Target/X86/X86FixupKinds.h"
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
@@ -59,6 +62,7 @@ public:
|
|||||||
virtual void EmitCOFFSymbolStorageClass(int StorageClass);
|
virtual void EmitCOFFSymbolStorageClass(int StorageClass);
|
||||||
virtual void EmitCOFFSymbolType(int Type);
|
virtual void EmitCOFFSymbolType(int Type);
|
||||||
virtual void EndCOFFSymbolDef();
|
virtual void EndCOFFSymbolDef();
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol);
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value);
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value);
|
||||||
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
||||||
unsigned ByteAlignment);
|
unsigned ByteAlignment);
|
||||||
@@ -290,6 +294,16 @@ void WinCOFFStreamer::EndCOFFSymbolDef() {
|
|||||||
CurSymbol = NULL;
|
CurSymbol = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WinCOFFStreamer::EmitCOFFSecRel32(MCSymbol const *Symbol)
|
||||||
|
{
|
||||||
|
MCDataFragment *DF = getOrCreateDataFragment();
|
||||||
|
|
||||||
|
DF->addFixup(MCFixup::Create(DF->getContents().size(),
|
||||||
|
MCSymbolRefExpr::Create (Symbol, getContext ()),
|
||||||
|
(MCFixupKind)X86::reloc_coff_secrel32));
|
||||||
|
DF->getContents().resize(DF->getContents().size() + 4, 0);
|
||||||
|
}
|
||||||
|
|
||||||
void WinCOFFStreamer::EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
void WinCOFFStreamer::EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {
|
||||||
llvm_unreachable("not implemented");
|
llvm_unreachable("not implemented");
|
||||||
}
|
}
|
||||||
@@ -368,6 +382,10 @@ void WinCOFFStreamer::EmitInstruction(const MCInst &Instruction) {
|
|||||||
|
|
||||||
getCurrentSectionData()->setHasInstructions(true);
|
getCurrentSectionData()->setHasInstructions(true);
|
||||||
|
|
||||||
|
// Now that a machine instruction has been assembled into this section, make
|
||||||
|
// a line entry for any .loc directive that has been seen.
|
||||||
|
MCLineEntry::Make(this, getCurrentSection());
|
||||||
|
|
||||||
MCInstFragment *Fragment =
|
MCInstFragment *Fragment =
|
||||||
new MCInstFragment(Instruction, getCurrentSectionData());
|
new MCInstFragment(Instruction, getCurrentSectionData());
|
||||||
|
|
||||||
|
@@ -124,6 +124,7 @@ public:
|
|||||||
virtual void EmitCOFFSymbolStorageClass(int StorageClass);
|
virtual void EmitCOFFSymbolStorageClass(int StorageClass);
|
||||||
virtual void EmitCOFFSymbolType(int Type);
|
virtual void EmitCOFFSymbolType(int Type);
|
||||||
virtual void EndCOFFSymbolDef();
|
virtual void EndCOFFSymbolDef();
|
||||||
|
virtual void EmitCOFFSecRel32(MCSymbol const *Symbol);
|
||||||
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value);
|
virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value);
|
||||||
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
||||||
unsigned ByteAlignment);
|
unsigned ByteAlignment);
|
||||||
@@ -277,6 +278,8 @@ void PTXMCAsmStreamer::EmitCOFFSymbolType (int Type) {}
|
|||||||
|
|
||||||
void PTXMCAsmStreamer::EndCOFFSymbolDef() {}
|
void PTXMCAsmStreamer::EndCOFFSymbolDef() {}
|
||||||
|
|
||||||
|
void PTXMCAsmStreamer::EmitCOFFSecRel32(MCSymbol const *Symbol) {}
|
||||||
|
|
||||||
void PTXMCAsmStreamer::EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {}
|
void PTXMCAsmStreamer::EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) {}
|
||||||
|
|
||||||
void PTXMCAsmStreamer::EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
void PTXMCAsmStreamer::EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
||||||
|
@@ -40,6 +40,7 @@ static unsigned getFixupKindLog2Size(unsigned Kind) {
|
|||||||
case X86::reloc_riprel_4byte_movq_load:
|
case X86::reloc_riprel_4byte_movq_load:
|
||||||
case X86::reloc_signed_4byte:
|
case X86::reloc_signed_4byte:
|
||||||
case X86::reloc_global_offset_table:
|
case X86::reloc_global_offset_table:
|
||||||
|
case X86::reloc_coff_secrel32:
|
||||||
case FK_Data_4: return 2;
|
case FK_Data_4: return 2;
|
||||||
case FK_PCRel_8:
|
case FK_PCRel_8:
|
||||||
case FK_Data_8: return 3;
|
case FK_Data_8: return 3;
|
||||||
@@ -69,7 +70,8 @@ public:
|
|||||||
{ "reloc_riprel_4byte", 0, 4 * 8, MCFixupKindInfo::FKF_IsPCRel },
|
{ "reloc_riprel_4byte", 0, 4 * 8, MCFixupKindInfo::FKF_IsPCRel },
|
||||||
{ "reloc_riprel_4byte_movq_load", 0, 4 * 8, MCFixupKindInfo::FKF_IsPCRel},
|
{ "reloc_riprel_4byte_movq_load", 0, 4 * 8, MCFixupKindInfo::FKF_IsPCRel},
|
||||||
{ "reloc_signed_4byte", 0, 4 * 8, 0},
|
{ "reloc_signed_4byte", 0, 4 * 8, 0},
|
||||||
{ "reloc_global_offset_table", 0, 4 * 8, 0}
|
{ "reloc_global_offset_table", 0, 4 * 8, 0},
|
||||||
|
{ "reloc_coff_secrel32", 0, 4 * 8, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
if (Kind < FirstTargetFixupKind)
|
if (Kind < FirstTargetFixupKind)
|
||||||
|
@@ -23,6 +23,8 @@ enum Fixups {
|
|||||||
reloc_global_offset_table, // 32-bit, relative to the start
|
reloc_global_offset_table, // 32-bit, relative to the start
|
||||||
// of the instruction. Used only
|
// of the instruction. Used only
|
||||||
// for _GLOBAL_OFFSET_TABLE_.
|
// for _GLOBAL_OFFSET_TABLE_.
|
||||||
|
reloc_coff_secrel32, // PE-COFF section relative 32
|
||||||
|
// (only valid for win32 COFF)
|
||||||
// Marker
|
// Marker
|
||||||
LastTargetFixupKind,
|
LastTargetFixupKind,
|
||||||
NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind
|
NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind
|
||||||
|
@@ -113,4 +113,7 @@ X86MCAsmInfoCOFF::X86MCAsmInfoCOFF(const Triple &Triple) {
|
|||||||
AssemblerDialect = AsmWriterFlavor;
|
AssemblerDialect = AsmWriterFlavor;
|
||||||
|
|
||||||
TextAlignFillValue = 0x90;
|
TextAlignFillValue = 0x90;
|
||||||
|
|
||||||
|
// Debug Information
|
||||||
|
SupportsDebugInformation = true;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user