summaryrefslogtreecommitdiff
path: root/lib/MC
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-04-03 03:13:19 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-04-03 03:13:19 +0000
commit04011e8429033ae0623ea629527d2d13de3f8109 (patch)
treecd53708ff252d83d92862acfb8364d477ec54838 /lib/MC
parent729c19482f434d8f3889d2a2c611a6e7813444f0 (diff)
downloadllvm-04011e8429033ae0623ea629527d2d13de3f8109.tar.gz
llvm-04011e8429033ae0623ea629527d2d13de3f8109.tar.bz2
llvm-04011e8429033ae0623ea629527d2d13de3f8109.tar.xz
Fix the fde encoding used by mips to match gas.
This finally fixes the encoding. The patch also * Removes eh-frame.ll. It was an unnecessary .ll to .o test that was checking the wrong value. * Merge fde-reloc.s and eh-frame.s into a single test, since the only difference was the run lines. * Don't blindly test the content of the entire .eh_frame section. It makes it hard to anyone actually fixing a bug and hitting a difference in a binary blob. Instead, use a CHECK for each field and document what is being checked. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@178615 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/MC')
-rw-r--r--lib/MC/MCObjectFileInfo.cpp11
1 files changed, 7 insertions, 4 deletions
diff --git a/lib/MC/MCObjectFileInfo.cpp b/lib/MC/MCObjectFileInfo.cpp
index 0d32ad40e8..d19e79ac64 100644
--- a/lib/MC/MCObjectFileInfo.cpp
+++ b/lib/MC/MCObjectFileInfo.cpp
@@ -223,10 +223,13 @@ void MCObjectFileInfo::InitMachOMCObjectFileInfo(Triple T) {
}
void MCObjectFileInfo::InitELFMCObjectFileInfo(Triple T) {
- if (T.getArch() != Triple::mips &&
- T.getArch() != Triple::mipsel &&
- T.getArch() != Triple::mips64 &&
- T.getArch() != Triple::mips64el )
+ if (T.getArch() == Triple::mips ||
+ T.getArch() == Triple::mipsel)
+ FDECFIEncoding = dwarf::DW_EH_PE_sdata4;
+ else if (T.getArch() == Triple::mips64 ||
+ T.getArch() == Triple::mips64el)
+ FDECFIEncoding = dwarf::DW_EH_PE_sdata8;
+ else
FDECFIEncoding = dwarf::DW_EH_PE_pcrel | dwarf::DW_EH_PE_sdata4;
if (T.getArch() == Triple::x86) {