mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
Adjust to MachineConstantPool interface change: instead of keeping a
value/alignment pair for each constant, keep a value/offset pair. llvm-svn: 26078
This commit is contained in:
parent
7775687364
commit
c81f375f21
@ -111,11 +111,17 @@ void AsmPrinter::EmitConstantPool(MachineConstantPool *MCP) {
|
||||
const TargetData &TD = TM.getTargetData();
|
||||
|
||||
SwitchSection(ConstantPoolSection, 0);
|
||||
EmitAlignment(MCP->getConstantPoolAlignment());
|
||||
for (unsigned i = 0, e = CP.size(); i != e; ++i) {
|
||||
EmitAlignment(CP[i].Alignment);
|
||||
O << PrivateGlobalPrefix << "CPI" << getFunctionNumber() << '_' << i
|
||||
<< ":\t\t\t\t\t" << CommentString << *CP[i].Val << '\n';
|
||||
EmitGlobalConstant(CP[i].Val);
|
||||
if (i != e-1) {
|
||||
unsigned EntSize = TM.getTargetData().getTypeSize(CP[i].Val->getType());
|
||||
unsigned ValEnd = CP[i].Offset + EntSize;
|
||||
// Emit inter-object padding for alignment.
|
||||
EmitZeros(CP[i+1].Offset-ValEnd);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -112,7 +112,7 @@ MachineFunction::MachineFunction(const Function *F,
|
||||
SSARegMapping = new SSARegMap();
|
||||
MFInfo = 0;
|
||||
FrameInfo = new MachineFrameInfo();
|
||||
ConstantPool = new MachineConstantPool();
|
||||
ConstantPool = new MachineConstantPool(TM.getTargetData());
|
||||
BasicBlocks.Parent = this;
|
||||
}
|
||||
|
||||
@ -345,10 +345,38 @@ void MachineFrameInfo::dump(const MachineFunction &MF) const {
|
||||
// MachineConstantPool implementation
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
/// getConstantPoolIndex - Create a new entry in the constant pool or return
|
||||
/// an existing one. User must specify an alignment in bytes for the object.
|
||||
///
|
||||
unsigned MachineConstantPool::getConstantPoolIndex(Constant *C,
|
||||
unsigned Alignment) {
|
||||
assert(Alignment && "Alignment must be specified!");
|
||||
if (Alignment > PoolAlignment) PoolAlignment = Alignment;
|
||||
|
||||
// Check to see if we already have this constant.
|
||||
//
|
||||
// FIXME, this could be made much more efficient for large constant pools.
|
||||
unsigned AlignMask = (1 << Alignment)-1;
|
||||
for (unsigned i = 0, e = Constants.size(); i != e; ++i)
|
||||
if (Constants[i].Val == C && (Constants[i].Offset & AlignMask) == 0)
|
||||
return i;
|
||||
|
||||
unsigned Offset = 0;
|
||||
if (!Constants.empty()) {
|
||||
Offset = Constants.back().Offset;
|
||||
Offset += TD.getTypeSize(Constants.back().Val->getType());
|
||||
Offset = (Offset+AlignMask)&~AlignMask;
|
||||
}
|
||||
|
||||
Constants.push_back(MachineConstantPoolEntry(C, Offset));
|
||||
return Constants.size()-1;
|
||||
}
|
||||
|
||||
|
||||
void MachineConstantPool::print(std::ostream &OS) const {
|
||||
for (unsigned i = 0, e = Constants.size(); i != e; ++i) {
|
||||
OS << " <cp #" << i << "> is" << *(Value*)Constants[i].Val;
|
||||
OS << " , align=" << Constants[i].Alignment;
|
||||
OS << " , offset=" << Constants[i].Offset;
|
||||
OS << "\n";
|
||||
}
|
||||
}
|
||||
|
@ -569,14 +569,17 @@ void JITEmitter::emitConstantPool(MachineConstantPool *MCP) {
|
||||
const std::vector<MachineConstantPoolEntry> &Constants = MCP->getConstants();
|
||||
if (Constants.empty()) return;
|
||||
|
||||
for (unsigned i = 0, e = Constants.size(); i != e; ++i) {
|
||||
const Type *Ty = Constants[i].Val->getType();
|
||||
unsigned Size = (unsigned)TheJIT->getTargetData().getTypeSize(Ty);
|
||||
unsigned Alignment = Constants[i].Alignment;
|
||||
unsigned Size = Constants.back().Offset;
|
||||
Size += TheJIT->getTargetData().getTypeSize(Constants.back().Val->getType());
|
||||
|
||||
void *Addr = MemMgr.allocateConstant(Size, Alignment);
|
||||
TheJIT->InitializeMemory(Constants[i].Val, Addr);
|
||||
ConstantPoolAddresses.push_back(Addr);
|
||||
void *Addr = MemMgr.allocateConstant(Size,
|
||||
1 << MCP->getConstantPoolAlignment());
|
||||
|
||||
// FIXME: Can eliminate ConstantPoolAddresses!
|
||||
for (unsigned i = 0, e = Constants.size(); i != e; ++i) {
|
||||
void *CAddr = (char*)Addr+Constants[i].Offset;
|
||||
TheJIT->InitializeMemory(Constants[i].Val, CAddr);
|
||||
ConstantPoolAddresses.push_back(CAddr);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -968,7 +968,7 @@ void SparcDAGToDAGISel::InstructionSelectBasicBlock(SelectionDAG &DAG) {
|
||||
}
|
||||
|
||||
bool SparcDAGToDAGISel::SelectADDRri(SDOperand Addr, SDOperand &Base,
|
||||
SDOperand &Offset) {
|
||||
SDOperand &Offset) {
|
||||
if (FrameIndexSDNode *FIN = dyn_cast<FrameIndexSDNode>(Addr)) {
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
|
@ -216,7 +216,8 @@ namespace {
|
||||
|
||||
if (Alignment == 0)
|
||||
Alignment = ConstantToAlignment(CV, TM);
|
||||
O << "\t.align\t" << Alignment << "\n";
|
||||
if (Alignment != 1)
|
||||
O << "\t.align\t" << Alignment << "\n";
|
||||
|
||||
// Print .size and .type only if it is not a string.
|
||||
if (const ConstantArray *CVA = dyn_cast<ConstantArray>(CV))
|
||||
@ -727,9 +728,18 @@ void SparcV9AsmPrinter::emitFunction(const Function &F) {
|
||||
const std::vector<MachineConstantPoolEntry> &CP = MCP->getConstants();
|
||||
|
||||
enterSection(ReadOnlyData);
|
||||
O << "\t.align\t" << (1 << MCP->getConstantPoolAlignment()) << "\n";
|
||||
for (unsigned i = 0, e = CP.size(); i != e; ++i) {
|
||||
std::string cpiName = ".CPI_" + CurrentFnName + "_" + utostr(i);
|
||||
printConstant(CP[i].Val, CP[i].Alignment, cpiName);
|
||||
printConstant(CP[i].Val, 1, cpiName);
|
||||
|
||||
if (i != e-1) {
|
||||
unsigned EntSize = TM.getTargetData().getTypeSize(CP[i].Val->getType());
|
||||
unsigned ValEnd = CP[i].Offset + EntSize;
|
||||
// Emit inter-object padding for alignment.
|
||||
for (unsigned NumZeros = CP[i+1].Offset-ValEnd; NumZeros; --NumZeros)
|
||||
O << "\t.byte 0\n";
|
||||
}
|
||||
}
|
||||
|
||||
enterSection(Text);
|
||||
|
Loading…
Reference in New Issue
Block a user