summaryrefslogtreecommitdiffstats
path: root/llvm/lib/MC/ELFObjectWriter.cpp
diff options
context:
space:
mode:
authorJason W Kim <jason.w.kim.2009@gmail.com>2011-01-12 00:19:25 +0000
committerJason W Kim <jason.w.kim.2009@gmail.com>2011-01-12 00:19:25 +0000
commit9c5b65d289a75f1d2533b76e90468f8071309366 (patch)
tree2fe6796926baddc6a580ccbab4178a3f99a82041 /llvm/lib/MC/ELFObjectWriter.cpp
parent25f4620c67520e687b5ca56e648c04334e3e88f2 (diff)
downloadbcm5719-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.cpp10
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()) {
OpenPOWER on IntegriCloud