From 8427d2b0c6c546209cbb73ebe11c4b0be5327c8d Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 3 Feb 2010 06:41:18 +0000 Subject: [PATCH] revert r95206, it is apparently causing bootstrap failure on i386-darwin9 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@95208 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/X86/AsmPrinter/X86AsmPrinter.cpp | 31 +++++---------------- 1 file changed, 7 insertions(+), 24 deletions(-) diff --git a/lib/Target/X86/AsmPrinter/X86AsmPrinter.cpp b/lib/Target/X86/AsmPrinter/X86AsmPrinter.cpp index 5dfb30e46d5..7ca786441ce 100644 --- a/lib/Target/X86/AsmPrinter/X86AsmPrinter.cpp +++ b/lib/Target/X86/AsmPrinter/X86AsmPrinter.cpp @@ -27,7 +27,6 @@ #include "llvm/Type.h" #include "llvm/Assembly/Writer.h" #include "llvm/MC/MCContext.h" -#include "llvm/MC/MCExpr.h" #include "llvm/MC/MCSectionMachO.h" #include "llvm/MC/MCStreamer.h" #include "llvm/MC/MCSymbol.h" @@ -503,17 +502,14 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) { OutStreamer.SwitchSection(TheSection); for (unsigned i = 0, e = Stubs.size(); i != e; ++i) { - // L_foo$stub: - OutStreamer.EmitLabel(Stubs[i].first); - // .indirect_symbol _foo - OutStreamer.EmitSymbolAttribute(Stubs[i].second, MCSA_IndirectSymbol); - // hlt; hlt; hlt; hlt; hlt hlt = 0xf4 = -12. - const char HltInsts[] = { -12, -12, -12, -12, -12 }; - OutStreamer.EmitBytes(StringRef(HltInsts, 5), 0/*addrspace*/); + O << *Stubs[i].first << ":\n"; + // Get the MCSymbol without the $stub suffix. + O << "\t.indirect_symbol " << *Stubs[i].second; + O << "\n\thlt ; hlt ; hlt ; hlt ; hlt\n"; } + O << '\n'; Stubs.clear(); - OutStreamer.AddBlankLine(); } // Output stubs for external and common global variables. @@ -526,15 +522,10 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) { OutStreamer.SwitchSection(TheSection); for (unsigned i = 0, e = Stubs.size(); i != e; ++i) { - // L_foo$non_lazy_ptr: - OutStreamer.EmitLabel(Stubs[i].first); - // .indirect_symbol _foo - OutStreamer.EmitSymbolAttribute(Stubs[i].second, MCSA_IndirectSymbol); - // .long 0 - OutStreamer.EmitIntValue(0, 4/*size*/, 0/*addrspace*/); + O << *Stubs[i].first << ":\n\t.indirect_symbol " << *Stubs[i].second; + O << "\n\t.long\t0\n"; } Stubs.clear(); - OutStreamer.AddBlankLine(); } Stubs = MMIMacho.GetHiddenGVStubList(); @@ -545,16 +536,8 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) { for (unsigned i = 0, e = Stubs.size(); i != e; ++i) { O << *Stubs[i].first << ":\n" << MAI->getData32bitsDirective(); O << *Stubs[i].second << '\n'; - - // L_foo$non_lazy_ptr: - OutStreamer.EmitLabel(Stubs[i].first); - // .long _foo - OutStreamer.EmitValue(MCSymbolRefExpr::Create(Stubs[i].second, - OutContext), - 4/*size*/, 0/*addrspace*/); } Stubs.clear(); - OutStreamer.AddBlankLine(); } // Funny Darwin hack: This flag tells the linker that no global symbols