mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-08 19:25:47 +00:00
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:
@@ -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";
|
||||||
|
Reference in New Issue
Block a user