aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/Mips/MCTargetDesc
diff options
context:
space:
mode:
authorJack Carter <jcarter@mips.com>2012-08-22 00:49:30 +0000
committerJack Carter <jcarter@mips.com>2012-08-22 00:49:30 +0000
commit101771ba4d9c2421f836069fcedf9ddc8a0c9dc7 (patch)
tree1f743fb5f09df0548a3df1224fd0ad863cb4877a /lib/Target/Mips/MCTargetDesc
parentcb1f68d7c8bea99530ba55813c2b4ddd14556286 (diff)
downloadexternal_llvm-101771ba4d9c2421f836069fcedf9ddc8a0c9dc7.zip
external_llvm-101771ba4d9c2421f836069fcedf9ddc8a0c9dc7.tar.gz
external_llvm-101771ba4d9c2421f836069fcedf9ddc8a0c9dc7.tar.bz2
For mips64 switch statements in subroutines could generate
within the codegen EK_GPRel64BlockAddress. This was not supported for direct object output and resulted in an assertion. This change adds support for EK_GPRel64BlockAddress for direct object. One fallout from this is to turn on rela relocations for mips64 to match gas. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@162334 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/Mips/MCTargetDesc')
-rw-r--r--lib/Target/Mips/MCTargetDesc/MipsELFObjectWriter.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/Target/Mips/MCTargetDesc/MipsELFObjectWriter.cpp b/lib/Target/Mips/MCTargetDesc/MipsELFObjectWriter.cpp
index b8489ca..5d240fe 100644
--- a/lib/Target/Mips/MCTargetDesc/MipsELFObjectWriter.cpp
+++ b/lib/Target/Mips/MCTargetDesc/MipsELFObjectWriter.cpp
@@ -56,7 +56,7 @@ namespace {
MipsELFObjectWriter::MipsELFObjectWriter(bool _is64Bit, uint8_t OSABI,
bool _isN64, bool IsLittleEndian)
: MCELFObjectTargetWriter(_is64Bit, OSABI, ELF::EM_MIPS,
- /*HasRelocationAddend*/ false,
+ /*HasRelocationAddend*/ (_isN64) ? true : false,
/*IsN64*/ _isN64) {}
MipsELFObjectWriter::~MipsELFObjectWriter() {}