aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Target/Mips/MipsTargetObjectFile.cpp
diff options
context:
space:
mode:
authorDaniel Sanders <daniel.sanders@imgtec.com>2015-05-26 10:19:18 +0000
committerDaniel Sanders <daniel.sanders@imgtec.com>2015-05-26 10:19:18 +0000
commit58ee4c945106dcca4a3eeb06a99748dbe8b78720 (patch)
tree3f90562dd8ad2071706419f73ac669261f8441ed /llvm/lib/Target/Mips/MipsTargetObjectFile.cpp
parentb48abf5dac71cb5e782fd5058f61d28e26cced81 (diff)
downloadllvm-58ee4c945106dcca4a3eeb06a99748dbe8b78720.zip
llvm-58ee4c945106dcca4a3eeb06a99748dbe8b78720.tar.gz
llvm-58ee4c945106dcca4a3eeb06a99748dbe8b78720.tar.bz2
[mips] Make TTypeEncoding indirect to allow .eh_frame to be read-only.
Summary: Following on from r209907 which made personality encodings indirect, do the same for TType encodings. This fixes the case where a try/catch block needs to generate references to, for example, std::exception in the .gcc_except_table. This commit uses DW_EH_PE_sdata8 for N64 as far as is possible at the moment. However, it is possible to end up with DW_EH_PE_sdata4 when a TargetMachine is not available. There's no risk of issues with inconsistency here since the tables are self describing but it does mean there is a small chance of the PC-relative offset being out of range for particularly large programs. Reviewers: petarj Reviewed By: petarj Subscribers: srhines, joerg, tberghammer, llvm-commits Differential Revision: http://reviews.llvm.org/D9669 llvm-svn: 238190
Diffstat (limited to 'llvm/lib/Target/Mips/MipsTargetObjectFile.cpp')
-rw-r--r--llvm/lib/Target/Mips/MipsTargetObjectFile.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/llvm/lib/Target/Mips/MipsTargetObjectFile.cpp b/llvm/lib/Target/Mips/MipsTargetObjectFile.cpp
index 0f2db60..adbe526 100644
--- a/llvm/lib/Target/Mips/MipsTargetObjectFile.cpp
+++ b/llvm/lib/Target/Mips/MipsTargetObjectFile.cpp
@@ -37,6 +37,7 @@ ExternSData("mextern-sdata", cl::Hidden,
cl::init(true));
void MipsTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM){
+ this->TM = &static_cast<const MipsTargetMachine &>(TM);
TargetLoweringObjectFileELF::Initialize(Ctx, TM);
InitializeELF(TM.Options.UseInitArray);
@@ -45,7 +46,6 @@ void MipsTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM){
SmallBSSSection = getContext().getELFSection(".sbss", ELF::SHT_NOBITS,
ELF::SHF_WRITE | ELF::SHF_ALLOC);
- this->TM = &static_cast<const MipsTargetMachine &>(TM);
}
// A address must be loaded from a small section if its size is less than the
@@ -146,3 +146,9 @@ MipsTargetObjectFile::getSectionForConstant(SectionKind Kind,
// Otherwise, we work the same as ELF.
return TargetLoweringObjectFileELF::getSectionForConstant(Kind, C);
}
+
+unsigned MipsTargetObjectFile::SelectMipsTTypeEncoding() const {
+ return dwarf::DW_EH_PE_indirect | dwarf::DW_EH_PE_pcrel |
+ (TM->getABI().ArePtrs64bit() ? dwarf::DW_EH_PE_sdata8
+ : dwarf::DW_EH_PE_sdata4);
+}