From 73ce0a63e6cfdbf13470154b84b7ee1de06f996f Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 4 Apr 2010 07:23:00 +0000 Subject: [PATCH] mc'ize the remaining uses of O. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100322 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../XCore/AsmPrinter/XCoreAsmPrinter.cpp | 31 +++++++++++-------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/lib/Target/XCore/AsmPrinter/XCoreAsmPrinter.cpp b/lib/Target/XCore/AsmPrinter/XCoreAsmPrinter.cpp index 2545a1f9201..0514f564525 100644 --- a/lib/Target/XCore/AsmPrinter/XCoreAsmPrinter.cpp +++ b/lib/Target/XCore/AsmPrinter/XCoreAsmPrinter.cpp @@ -104,12 +104,14 @@ void XCoreAsmPrinter::emitArrayBound(MCSymbol *Sym, const GlobalVariable *GV) { if (const ArrayType *ATy = dyn_cast( cast(GV->getType())->getElementType())) { OutStreamer.EmitSymbolAttribute(Sym, MCSA_Global); - O << ".globound" << "\n"; - O << "\t.set\t" << *Sym; - O << ".globound" << "," << ATy->getNumElements() << "\n"; + // FIXME: MCStreamerize. + OutStreamer.EmitRawText(StringRef(".globound")); + OutStreamer.EmitRawText("\t.set\t" + Twine(Sym->getName())); + OutStreamer.EmitRawText(".globound," + Twine(ATy->getNumElements())); if (GV->hasWeakLinkage() || GV->hasLinkOnceLinkage()) { // TODO Use COMDAT groups for LinkOnceLinkage - O << MAI->getWeakDefDirective() << *Sym << ".globound" << "\n"; + OutStreamer.EmitRawText(MAI->getWeakDefDirective() +Twine(Sym->getName())+ + ".globound"); } } } @@ -129,7 +131,8 @@ void XCoreAsmPrinter::EmitGlobalVariable(const GlobalVariable *GV) { unsigned Align = (unsigned)TD->getPreferredTypeAlignmentShift(C->getType()); // Mark the start of the global - O << "\t.cc_top " << *GVSym << ".data," << *GVSym << "\n"; + OutStreamer.EmitRawText("\t.cc_top " + Twine(GVSym->getName()) + ".data," + + GVSym->getName()); switch (GV->getLinkage()) { case GlobalValue::AppendingLinkage: @@ -144,7 +147,7 @@ void XCoreAsmPrinter::EmitGlobalVariable(const GlobalVariable *GV) { // TODO Use COMDAT groups for LinkOnceLinkage if (GV->hasWeakLinkage() || GV->hasLinkOnceLinkage()) - O << MAI->getWeakDefDirective() << *GVSym << "\n"; + OutStreamer.EmitSymbolAttribute(GVSym, MCSA_Weak); // FALL THROUGH case GlobalValue::InternalLinkage: case GlobalValue::PrivateLinkage: @@ -165,10 +168,11 @@ void XCoreAsmPrinter::EmitGlobalVariable(const GlobalVariable *GV) { Size *= MaxThreads; } if (MAI->hasDotTypeDotSizeDirective()) { - O << "\t.type " << *GVSym << ",@object\n"; - O << "\t.size " << *GVSym << "," << Size << "\n"; + OutStreamer.EmitSymbolAttribute(GVSym, MCSA_ELF_TypeObject); + OutStreamer.EmitRawText("\t.size " + Twine(GVSym->getName()) + "," + + Twine(Size)); } - O << *GVSym << ":\n"; + OutStreamer.EmitLabel(GVSym); EmitGlobalConstant(C); if (GV->isThreadLocal()) { @@ -181,7 +185,7 @@ void XCoreAsmPrinter::EmitGlobalVariable(const GlobalVariable *GV) { OutStreamer.EmitZeros(4 - Size, 0); // Mark the end of the global - O << "\t.cc_bottom " << *GVSym << ".data\n"; + OutStreamer.EmitRawText("\t.cc_bottom " + Twine(GVSym->getName()) + ".data"); } /// Emit the directives on the start of functions @@ -192,7 +196,8 @@ void XCoreAsmPrinter::emitFunctionStart(MachineFunction &MF) { OutStreamer.SwitchSection(getObjFileLowering().SectionForGlobal(F, Mang, TM)); // Mark the start of the function - O << "\t.cc_top " << *CurrentFnSym << ".function," << *CurrentFnSym << "\n"; + OutStreamer.EmitRawText("\t.cc_top " + Twine(CurrentFnSym->getName()) + + ".function," + CurrentFnSym->getName()); switch (F->getLinkage()) { default: llvm_unreachable("Unknown linkage type!"); @@ -209,13 +214,13 @@ void XCoreAsmPrinter::emitFunctionStart(MachineFunction &MF) { case Function::WeakODRLinkage: // TODO Use COMDAT groups for LinkOnceLinkage OutStreamer.EmitSymbolAttribute(CurrentFnSym, MCSA_Global); - O << MAI->getWeakDefDirective() << *CurrentFnSym << "\n"; + OutStreamer.EmitSymbolAttribute(CurrentFnSym, MCSA_Weak); break; } // (1 << 1) byte aligned EmitAlignment(MF.getAlignment(), F, 1); if (MAI->hasDotTypeDotSizeDirective()) - O << "\t.type " << *CurrentFnSym << ",@function\n"; + OutStreamer.EmitSymbolAttribute(CurrentFnSym, MCSA_ELF_TypeFunction); OutStreamer.EmitLabel(CurrentFnSym); } -- 2.34.1