diff options
| author | Daniel Dunbar <daniel@zuster.org> | 2010-03-19 09:28:12 +0000 |
|---|---|---|
| committer | Daniel Dunbar <daniel@zuster.org> | 2010-03-19 09:28:12 +0000 |
| commit | f0517efc6c2d7e3476481d9b4b6a59f833b6f9e9 (patch) | |
| tree | bf6d24f94486e1bf7dc294cf8034021fae07c35c /llvm/lib/Target/X86/X86AsmBackend.cpp | |
| parent | ef01f71a5a7b80921b8f6a95af78faeb04f02163 (diff) | |
| download | bcm5719-llvm-f0517efc6c2d7e3476481d9b4b6a59f833b6f9e9.tar.gz bcm5719-llvm-f0517efc6c2d7e3476481d9b4b6a59f833b6f9e9.zip | |
MCAssembler: Move ApplyFixup to the TargetAsmBackend, this is a target specific not object writer specific task.
llvm-svn: 98947
Diffstat (limited to 'llvm/lib/Target/X86/X86AsmBackend.cpp')
| -rw-r--r-- | llvm/lib/Target/X86/X86AsmBackend.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/X86AsmBackend.cpp b/llvm/lib/Target/X86/X86AsmBackend.cpp index d7a9e1a9653..fec563817e6 100644 --- a/llvm/lib/Target/X86/X86AsmBackend.cpp +++ b/llvm/lib/Target/X86/X86AsmBackend.cpp @@ -9,6 +9,8 @@ #include "llvm/Target/TargetAsmBackend.h" #include "X86.h" +#include "X86FixupKinds.h" +#include "llvm/MC/MCAssembler.h" #include "llvm/MC/MCSectionMachO.h" #include "llvm/Target/TargetRegistry.h" #include "llvm/Target/TargetAsmBackend.h" @@ -16,10 +18,34 @@ using namespace llvm; namespace { +static unsigned getFixupKindLog2Size(unsigned Kind) { + switch (Kind) { + default: assert(0 && "invalid fixup kind!"); + case X86::reloc_pcrel_1byte: + case FK_Data_1: return 0; + case FK_Data_2: return 1; + case X86::reloc_pcrel_4byte: + case X86::reloc_riprel_4byte: + case X86::reloc_riprel_4byte_movq_load: + case FK_Data_4: return 2; + case FK_Data_8: return 3; + } +} + class X86AsmBackend : public TargetAsmBackend { public: X86AsmBackend(const Target &T) : TargetAsmBackend(T) {} + + void ApplyFixup(const MCAsmFixup &Fixup, MCDataFragment &DF, + uint64_t Value) const { + unsigned Size = 1 << getFixupKindLog2Size(Fixup.Kind); + + assert(Fixup.Offset + Size <= DF.getContents().size() && + "Invalid fixup offset!"); + for (unsigned i = 0; i != Size; ++i) + DF.getContents()[Fixup.Offset + i] = uint8_t(Value >> (i * 8)); + } }; class DarwinX86AsmBackend : public X86AsmBackend { |

