mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 17:39:16 +00:00
Keep source information, if available, around for ARM Fixups.
Adjust an example MachObjectWriter diagnostic to use the information to issue a better message. Before: LLVM ERROR: unknown ARM fixup kind! After: x.s:6:5: error: unsupported relocation on symbol beq bar ^ rdar://9800182 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@149093 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
82f4ce5081
commit
42e6bd38e0
@ -7157,6 +7157,7 @@ MatchAndEmitInstruction(SMLoc IDLoc,
|
||||
if (Inst.getOpcode() == ARM::ITasm)
|
||||
return false;
|
||||
|
||||
Inst.setLoc(IDLoc);
|
||||
Out.EmitInstruction(Inst);
|
||||
return false;
|
||||
case Match_MissingFeature:
|
||||
|
@ -464,7 +464,7 @@ static uint32_t getBranchTargetOpValue(const MCInst &MI, unsigned OpIdx,
|
||||
assert(MO.isExpr() && "Unexpected branch target type!");
|
||||
const MCExpr *Expr = MO.getExpr();
|
||||
MCFixupKind Kind = MCFixupKind(FixupKind);
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind));
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind, MI.getLoc()));
|
||||
|
||||
// All of the information is in the fixup.
|
||||
return 0;
|
||||
@ -716,7 +716,7 @@ getAddrModeImm12OpValue(const MCInst &MI, unsigned OpIdx,
|
||||
Kind = MCFixupKind(ARM::fixup_t2_ldst_pcrel_12);
|
||||
else
|
||||
Kind = MCFixupKind(ARM::fixup_arm_ldst_pcrel_12);
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind));
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind, MI.getLoc()));
|
||||
|
||||
++MCNumCPRelocations;
|
||||
} else {
|
||||
@ -791,7 +791,7 @@ getT2AddrModeImm8s4OpValue(const MCInst &MI, unsigned OpIdx,
|
||||
assert(MO.isExpr() && "Unexpected machine operand type!");
|
||||
const MCExpr *Expr = MO.getExpr();
|
||||
MCFixupKind Kind = MCFixupKind(ARM::fixup_t2_pcrel_10);
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind));
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind, MI.getLoc()));
|
||||
|
||||
++MCNumCPRelocations;
|
||||
} else
|
||||
@ -878,7 +878,7 @@ ARMMCCodeEmitter::getHiLo16ImmOpValue(const MCInst &MI, unsigned OpIdx,
|
||||
: ARM::fixup_arm_movw_lo16);
|
||||
break;
|
||||
}
|
||||
Fixups.push_back(MCFixup::Create(0, E, Kind));
|
||||
Fixups.push_back(MCFixup::Create(0, E, Kind, MI.getLoc()));
|
||||
return 0;
|
||||
};
|
||||
|
||||
@ -999,7 +999,7 @@ getAddrMode3OpValue(const MCInst &MI, unsigned OpIdx,
|
||||
assert(MO.isExpr() && "Unexpected machine operand type!");
|
||||
const MCExpr *Expr = MO.getExpr();
|
||||
MCFixupKind Kind = MCFixupKind(ARM::fixup_arm_pcrel_10_unscaled);
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind));
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind, MI.getLoc()));
|
||||
|
||||
++MCNumCPRelocations;
|
||||
return (Rn << 9) | (1 << 13);
|
||||
@ -1077,7 +1077,7 @@ getAddrMode5OpValue(const MCInst &MI, unsigned OpIdx,
|
||||
Kind = MCFixupKind(ARM::fixup_t2_pcrel_10);
|
||||
else
|
||||
Kind = MCFixupKind(ARM::fixup_arm_pcrel_10);
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind));
|
||||
Fixups.push_back(MCFixup::Create(0, Expr, Kind, MI.getLoc()));
|
||||
|
||||
++MCNumCPRelocations;
|
||||
} else {
|
||||
|
@ -13,6 +13,7 @@
|
||||
#include "llvm/MC/MCAssembler.h"
|
||||
#include "llvm/MC/MCAsmLayout.h"
|
||||
#include "llvm/MC/MCMachObjectWriter.h"
|
||||
#include "llvm/MC/MCContext.h"
|
||||
#include "llvm/MC/MCExpr.h"
|
||||
#include "llvm/MC/MCFixup.h"
|
||||
#include "llvm/MC/MCFixupKindInfo.h"
|
||||
@ -294,9 +295,13 @@ void ARMMachObjectWriter::RecordRelocation(MachObjectWriter *Writer,
|
||||
unsigned IsPCRel = Writer->isFixupKindPCRel(Asm, Fixup.getKind());
|
||||
unsigned Log2Size;
|
||||
unsigned RelocType = macho::RIT_Vanilla;
|
||||
if (!getARMFixupKindMachOInfo(Fixup.getKind(), RelocType, Log2Size)) {
|
||||
report_fatal_error("unknown ARM fixup kind!");
|
||||
}
|
||||
if (!getARMFixupKindMachOInfo(Fixup.getKind(), RelocType, Log2Size))
|
||||
// If we failed to get fixup kind info, it's because there's no legal
|
||||
// relocation type for the fixup kind. This happens when it's a fixup that's
|
||||
// expected to always be resolvable at assembly time and not have any
|
||||
// relocations needed.
|
||||
Asm.getContext().FatalError(Fixup.getLoc(),
|
||||
"unsupported relocation on symbol");
|
||||
|
||||
// If this is a difference or a defined symbol plus an offset, then we need a
|
||||
// scattered relocation entry. Differences always require scattered
|
||||
|
Loading…
x
Reference in New Issue
Block a user