From b0b2c57149d61e9b5f2c542547c0dd8d65480ba5 Mon Sep 17 00:00:00 2001 From: Bill Wendling Date: Tue, 28 Sep 2010 23:11:55 +0000 Subject: [PATCH] Revert r114997. It was causing a failure on darwin10-selfhost. llvm-svn: 115002 --- .../CodeGen/TargetLoweringObjectFileImpl.cpp | 18 +++++++++++++----- llvm/test/CodeGen/X86/non-globl-eh-frame.ll | 2 ++ 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp index 0f36d4296f64..4afdc3ddef52 100644 --- a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp +++ b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp @@ -444,19 +444,27 @@ getExprForDwarfGlobalReference(const GlobalValue *GV, Mangler *Mang, void TargetLoweringObjectFileMachO::Initialize(MCContext &Ctx, const TargetMachine &TM) { + // _foo.eh symbols are currently always exported so that the linker knows + // about them. This is not necessary on 10.6 and later, but it + // doesn't hurt anything. + // FIXME: I need to get this from Triple. IsFunctionEHSymbolGlobal = true; IsFunctionEHFrameSymbolPrivate = false; SupportsWeakOmittedEHFrame = false; Triple T(((LLVMTargetMachine&)TM).getTargetTriple()); if (T.getOS() == Triple::Darwin) { - unsigned MajNum = T.getDarwinMajorNumber(); - if (MajNum == 7 || MajNum == 8) // 10.3 Panther, 10.4 Tiger + switch (T.getDarwinMajorNumber()) { + case 7: // 10.3 Panther. + case 8: // 10.4 Tiger. CommDirectiveSupportsAlignment = false; - if (MajNum > 9) // 10.6 SnowLeopard - IsFunctionEHSymbolGlobal = false; + break; + case 9: // 10.5 Leopard. + case 10: // 10.6 SnowLeopard. + break; + } } - + TargetLoweringObjectFile::Initialize(Ctx, TM); TextSection // .text diff --git a/llvm/test/CodeGen/X86/non-globl-eh-frame.ll b/llvm/test/CodeGen/X86/non-globl-eh-frame.ll index 71349ecafeb6..20fd9a6f1a33 100644 --- a/llvm/test/CodeGen/X86/non-globl-eh-frame.ll +++ b/llvm/test/CodeGen/X86/non-globl-eh-frame.ll @@ -1,5 +1,7 @@ ; RUN: llc < %s -mtriple x86_64-apple-darwin10 -march x86 | not grep {{.globl\[\[:space:\]\]*__Z4funcv.eh}} ; RUN: llc < %s -mtriple x86_64-apple-darwin9 -march x86 | FileCheck %s -check-prefix=DARWIN9 +; XFAIL: * +; Fail this until I can fix the global EH failure. %struct.__pointer_type_info_pseudo = type { %struct.__type_info_pseudo, i32, %"struct.std::type_info"* } %struct.__type_info_pseudo = type { i8*, i8* }