diff options
| author | Bill Wendling <isanbard@gmail.com> | 2010-03-12 19:20:40 +0000 |
|---|---|---|
| committer | Bill Wendling <isanbard@gmail.com> | 2010-03-12 19:20:40 +0000 |
| commit | 3d0cd822a9d4386faa1493b305a235202df8d5e5 (patch) | |
| tree | 768f40b74a32fb83383e7c6fa33defb2e99df497 /llvm/lib/Target/X86/X86ISelLowering.cpp | |
| parent | d19e302f7764b4f4920a122671f42ccd78fc98e0 (diff) | |
| download | bcm5719-llvm-3d0cd822a9d4386faa1493b305a235202df8d5e5.tar.gz bcm5719-llvm-3d0cd822a9d4386faa1493b305a235202df8d5e5.zip | |
Add a beta-test for placing the LSDA into the TEXT section on X86.
llvm-svn: 98370
Diffstat (limited to 'llvm/lib/Target/X86/X86ISelLowering.cpp')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index 8c09eecd4f6..abc5d9bc1d5 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -37,6 +37,7 @@ #include "llvm/CodeGen/PseudoSourceValue.h" #include "llvm/MC/MCAsmInfo.h" #include "llvm/MC/MCContext.h" +#include "llvm/MC/MCSectionMachO.h" #include "llvm/MC/MCSymbol.h" #include "llvm/ADT/BitVector.h" #include "llvm/ADT/SmallSet.h" @@ -45,10 +46,12 @@ #include "llvm/ADT/VectorExtras.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/Debug.h" +#include "llvm/Support/Dwarf.h" #include "llvm/Support/ErrorHandling.h" #include "llvm/Support/MathExtras.h" #include "llvm/Support/raw_ostream.h" using namespace llvm; +using namespace dwarf; STATISTIC(NumTailCalls, "Number of tail calls"); @@ -67,10 +70,54 @@ Disable16Bit("disable-16bit", cl::Hidden, static SDValue getMOVL(SelectionDAG &DAG, DebugLoc dl, EVT VT, SDValue V1, SDValue V2); +// FIXME: This is for a test. +static cl::opt<bool> +EnableX86EHTest("enable-x86-eh-test", cl::Hidden); + +namespace llvm { + class X86_test_MachoTargetObjectFile : public TargetLoweringObjectFileMachO { + public: + virtual void Initialize(MCContext &Ctx, const TargetMachine &TM) { + TargetLoweringObjectFileMachO::Initialize(Ctx, TM); + + // Exception Handling. + LSDASection = getMachOSection("__TEXT", "__gcc_except_tab", 0, + SectionKind::getReadOnlyWithRel()); + } + + virtual unsigned getTTypeEncoding() const { + return DW_EH_PE_indirect | DW_EH_PE_pcrel | DW_EH_PE_sdata4; + } + }; + + class X8664_test_MachoTargetObjectFile : public X8664_MachoTargetObjectFile { + public: + virtual void Initialize(MCContext &Ctx, const TargetMachine &TM) { + TargetLoweringObjectFileMachO::Initialize(Ctx, TM); + + // Exception Handling. + LSDASection = getMachOSection("__TEXT", "__gcc_except_tab", 0, + SectionKind::getReadOnlyWithRel()); + } + + virtual unsigned getTTypeEncoding() const { + return DW_EH_PE_indirect | DW_EH_PE_pcrel | DW_EH_PE_sdata4; + } + }; +} + static TargetLoweringObjectFile *createTLOF(X86TargetMachine &TM) { switch (TM.getSubtarget<X86Subtarget>().TargetType) { default: llvm_unreachable("unknown subtarget type"); case X86Subtarget::isDarwin: + // FIXME: This is for an EH test. + if (EnableX86EHTest) { + if (TM.getSubtarget<X86Subtarget>().is64Bit()) + return new X8664_test_MachoTargetObjectFile(); + else + return new X86_test_MachoTargetObjectFile(); + } + if (TM.getSubtarget<X86Subtarget>().is64Bit()) return new X8664_MachoTargetObjectFile(); return new TargetLoweringObjectFileMachO(); |

