diff options
author | Jason W Kim <jason.w.kim.2009@gmail.com> | 2011-01-12 00:19:25 +0000 |
---|---|---|
committer | Jason W Kim <jason.w.kim.2009@gmail.com> | 2011-01-12 00:19:25 +0000 |
commit | 9c5b65d289a75f1d2533b76e90468f8071309366 (patch) | |
tree | 2fe6796926baddc6a580ccbab4178a3f99a82041 /llvm/lib/MC/ELFObjectWriter.cpp | |
parent | 25f4620c67520e687b5ca56e648c04334e3e88f2 (diff) | |
download | bcm5719-llvm-9c5b65d289a75f1d2533b76e90468f8071309366.tar.gz bcm5719-llvm-9c5b65d289a75f1d2533b76e90468f8071309366.zip |
1. Support ELF pcrel relocations for movw/movt:
R_ARM_MOVT_PREL and R_ARM_MOVW_PREL_NC.
2. Fix minor bug in ARMAsmPrinter - treat bitfield flag as a bitfield, not an enum.
3. Add support for 3 new elf section types (no-ops)
llvm-svn: 123294
Diffstat (limited to 'llvm/lib/MC/ELFObjectWriter.cpp')
-rw-r--r-- | llvm/lib/MC/ELFObjectWriter.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/llvm/lib/MC/ELFObjectWriter.cpp b/llvm/lib/MC/ELFObjectWriter.cpp index 757a56aa6e1..470c6f58444 100644 --- a/llvm/lib/MC/ELFObjectWriter.cpp +++ b/llvm/lib/MC/ELFObjectWriter.cpp @@ -1268,6 +1268,9 @@ void ELFObjectWriter::WriteSection(MCAssembler &Asm, case ELF::SHT_NOTE: case ELF::SHT_NULL: case ELF::SHT_ARM_ATTRIBUTES: + case ELF::SHT_INIT_ARRAY: + case ELF::SHT_FINI_ARRAY: + case ELF::SHT_PREINIT_ARRAY: // Nothing to do. break; @@ -1490,6 +1493,13 @@ unsigned ARMELFObjectWriter::GetRelocType(const MCValue &Target, default: Type = ELF::R_ARM_CALL; break; } break; + case ARM::fixup_arm_movt_hi16: + case ARM::fixup_arm_movt_hi16_pcrel: + Type = ELF::R_ARM_MOVT_PREL; break; + case ARM::fixup_arm_movw_lo16: + case ARM::fixup_arm_movw_lo16_pcrel: + Type = ELF::R_ARM_MOVW_PREL_NC; break; + } } else { switch ((unsigned)Fixup.getKind()) { |