mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-05-14 09:38:40 +00:00
Allow target to customize directive used to switch to arbitrary section in SwitchSection,
add generic constant pool emitter git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24464 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
97e32e3239
commit
3b4fd32a41
@ -14,6 +14,7 @@
|
|||||||
#include "llvm/CodeGen/AsmPrinter.h"
|
#include "llvm/CodeGen/AsmPrinter.h"
|
||||||
#include "llvm/Constants.h"
|
#include "llvm/Constants.h"
|
||||||
#include "llvm/Module.h"
|
#include "llvm/Module.h"
|
||||||
|
#include "llvm/CodeGen/MachineConstantPool.h"
|
||||||
#include "llvm/Support/Mangler.h"
|
#include "llvm/Support/Mangler.h"
|
||||||
#include "llvm/Support/MathExtras.h"
|
#include "llvm/Support/MathExtras.h"
|
||||||
#include "llvm/Target/TargetMachine.h"
|
#include "llvm/Target/TargetMachine.h"
|
||||||
@ -26,7 +27,7 @@ void AsmPrinter::SwitchSection(const char *NewSection, const GlobalValue *GV) {
|
|||||||
std::string NS;
|
std::string NS;
|
||||||
|
|
||||||
if (GV && GV->hasSection())
|
if (GV && GV->hasSection())
|
||||||
NS = ".section " + GV->getSection();
|
NS = SwitchToSectionDirective + GV->getSection();
|
||||||
else
|
else
|
||||||
NS = NewSection;
|
NS = NewSection;
|
||||||
|
|
||||||
@ -54,6 +55,32 @@ void AsmPrinter::SetupMachineFunction(MachineFunction &MF) {
|
|||||||
IncrementFunctionNumber();
|
IncrementFunctionNumber();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// EmitConstantPool - Print to the current output stream assembly
|
||||||
|
/// representations of the constants in the constant pool MCP. This is
|
||||||
|
/// used to print out constants which have been "spilled to memory" by
|
||||||
|
/// the code generator.
|
||||||
|
///
|
||||||
|
void AsmPrinter::EmitConstantPool(MachineConstantPool *MCP) {
|
||||||
|
const std::vector<Constant*> &CP = MCP->getConstants();
|
||||||
|
if (CP.empty()) return;
|
||||||
|
const TargetData &TD = TM.getTargetData();
|
||||||
|
|
||||||
|
SwitchSection(ConstantPoolSection, 0);
|
||||||
|
for (unsigned i = 0, e = CP.size(); i != e; ++i) {
|
||||||
|
// FIXME: force doubles to be naturally aligned. We should handle this
|
||||||
|
// more correctly in the future.
|
||||||
|
unsigned Alignment = TD.getTypeAlignmentShift(CP[i]->getType());
|
||||||
|
if (CP[i]->getType() == Type::DoubleTy && Alignment < 3) Alignment = 3;
|
||||||
|
|
||||||
|
EmitAlignment(Alignment);
|
||||||
|
O << PrivateGlobalPrefix << "CPI" << getFunctionNumber() << '_' << i
|
||||||
|
<< ":\t\t\t\t\t" << CommentString << *CP[i] << '\n';
|
||||||
|
EmitGlobalConstant(CP[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// EmitAlignment - Emit an alignment directive to the specified power of two.
|
// EmitAlignment - Emit an alignment directive to the specified power of two.
|
||||||
void AsmPrinter::EmitAlignment(unsigned NumBits, const GlobalValue *GV) const {
|
void AsmPrinter::EmitAlignment(unsigned NumBits, const GlobalValue *GV) const {
|
||||||
if (GV && GV->getAlignment())
|
if (GV && GV->getAlignment())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user