Switch to the new shared SwitchSection

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24450 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner
2005-11-21 07:30:28 +00:00
parent 4bfa3a3eb0
commit 0a70a49dd6

View File

@@ -21,12 +21,9 @@
#include "llvm/CodeGen/MachineConstantPool.h" #include "llvm/CodeGen/MachineConstantPool.h"
#include "llvm/CodeGen/ValueTypes.h" #include "llvm/CodeGen/ValueTypes.h"
#include "llvm/CodeGen/AsmPrinter.h" #include "llvm/CodeGen/AsmPrinter.h"
#include "llvm/Target/TargetMachine.h" #include "llvm/Target/TargetMachine.h"
#include "llvm/Support/Mangler.h" #include "llvm/Support/Mangler.h"
#include "llvm/ADT/Statistic.h" #include "llvm/ADT/Statistic.h"
#include "llvm/Support/CommandLine.h"
using namespace llvm; using namespace llvm;
@@ -66,7 +63,6 @@ namespace {
bool runOnMachineFunction(MachineFunction &F); bool runOnMachineFunction(MachineFunction &F);
bool doInitialization(Module &M); bool doInitialization(Module &M);
bool doFinalization(Module &M); bool doFinalization(Module &M);
void switchSection(std::ostream &OS, const char *NewSection);
}; };
} // end of anonymous namespace } // end of anonymous namespace
@@ -180,7 +176,7 @@ bool AlphaAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
printConstantPool(MF.getConstantPool()); printConstantPool(MF.getConstantPool());
// Print out labels for the function. // Print out labels for the function.
switchSection(O, "text"); SwitchSection("\t.section .text", MF.getFunction());
emitAlignment(4); emitAlignment(4);
O << "\t.globl " << CurrentFnName << "\n"; O << "\t.globl " << CurrentFnName << "\n";
O << "\t.ent " << CurrentFnName << "\n"; O << "\t.ent " << CurrentFnName << "\n";
@@ -220,9 +216,8 @@ void AlphaAsmPrinter::printConstantPool(MachineConstantPool *MCP) {
if (CP.empty()) return; if (CP.empty()) return;
switchSection(O, "rodata"); SwitchSection("\t.section .rodata", 0);
for (unsigned i = 0, e = CP.size(); i != e; ++i) { for (unsigned i = 0, e = CP.size(); i != e; ++i) {
// switchSection(O, "section .rodata, \"dr\"");
emitAlignment(TD.getTypeAlignmentShift(CP[i]->getType())); emitAlignment(TD.getTypeAlignmentShift(CP[i]->getType()));
O << PrivateGlobalPrefix << "CPI" << CurrentFnName << "_" << i O << PrivateGlobalPrefix << "CPI" << CurrentFnName << "_" << i
<< ":\t\t\t\t\t" << CommentString << *CP[i] << "\n"; << ":\t\t\t\t\t" << CommentString << *CP[i] << "\n";
@@ -242,19 +237,6 @@ bool AlphaAsmPrinter::doInitialization(Module &M)
return false; return false;
} }
// switchSection - Switch to the specified section of the executable if we are
// not already in it!
//
void AlphaAsmPrinter::switchSection(std::ostream &OS, const char *NewSection)
{
if (CurSection != NewSection) {
CurSection = NewSection;
if (!CurSection.empty())
OS << "\t.section ." << NewSection << "\n";
}
}
bool AlphaAsmPrinter::doFinalization(Module &M) { bool AlphaAsmPrinter::doFinalization(Module &M) {
const TargetData &TD = TM.getTargetData(); const TargetData &TD = TM.getTargetData();
@@ -269,7 +251,7 @@ bool AlphaAsmPrinter::doFinalization(Module &M) {
if (C->isNullValue() && if (C->isNullValue() &&
(I->hasLinkOnceLinkage() || I->hasInternalLinkage() || (I->hasLinkOnceLinkage() || I->hasInternalLinkage() ||
I->hasWeakLinkage() /* FIXME: Verify correct */)) { I->hasWeakLinkage() /* FIXME: Verify correct */)) {
switchSection(O, "data"); SwitchSection("\t.section .data", I);
if (I->hasInternalLinkage()) if (I->hasInternalLinkage())
O << "\t.local " << name << "\n"; O << "\t.local " << name << "\n";
@@ -284,8 +266,8 @@ bool AlphaAsmPrinter::doFinalization(Module &M) {
case GlobalValue::WeakLinkage: // FIXME: Verify correct for weak. case GlobalValue::WeakLinkage: // FIXME: Verify correct for weak.
// Nonnull linkonce -> weak // Nonnull linkonce -> weak
O << "\t.weak " << name << "\n"; O << "\t.weak " << name << "\n";
switchSection(O, "");
O << "\t.section\t.llvm.linkonce.d." << name << ",\"aw\",@progbits\n"; O << "\t.section\t.llvm.linkonce.d." << name << ",\"aw\",@progbits\n";
SwitchSection("", I);
break; break;
case GlobalValue::AppendingLinkage: case GlobalValue::AppendingLinkage:
// FIXME: appending linkage variables should go into a section of // FIXME: appending linkage variables should go into a section of
@@ -295,10 +277,8 @@ bool AlphaAsmPrinter::doFinalization(Module &M) {
O << "\t.globl " << name << "\n"; O << "\t.globl " << name << "\n";
// FALL THROUGH // FALL THROUGH
case GlobalValue::InternalLinkage: case GlobalValue::InternalLinkage:
if (C->isNullValue()) SwitchSection(C->isNullValue() ? "\t.section .bss" :
switchSection(O, "bss"); "\t.section .data", I);
else
switchSection(O, "data");
break; break;
case GlobalValue::GhostLinkage: case GlobalValue::GhostLinkage:
std::cerr << "GhostLinkage cannot appear in AlphaAsmPrinter!\n"; std::cerr << "GhostLinkage cannot appear in AlphaAsmPrinter!\n";