mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
Remove the code that emits MIPS' .cprestore directive.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157493 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
65d5629065
commit
6a1a2b1395
@ -112,28 +112,6 @@ void MipsAsmPrinter::EmitInstruction(const MachineInstr *MI) {
|
||||
|
||||
return;
|
||||
}
|
||||
case Mips::CPRESTORE: {
|
||||
const MachineOperand &MO = MI->getOperand(0);
|
||||
assert(MO.isImm() && "CPRESTORE's operand must be an immediate.");
|
||||
int64_t Offset = MO.getImm();
|
||||
|
||||
if (OutStreamer.hasRawTextSupport()) {
|
||||
if (!isInt<16>(Offset)) {
|
||||
EmitInstrWithMacroNoAT(MI);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
MCInstLowering.LowerCPRESTORE(Offset, MCInsts);
|
||||
|
||||
for (SmallVector<MCInst, 4>::iterator I = MCInsts.begin();
|
||||
I != MCInsts.end(); ++I)
|
||||
OutStreamer.EmitInstruction(*I);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@ -140,33 +140,6 @@ void MipsMCInstLower::LowerCPLOAD(SmallVector<MCInst, 4>& MCInsts) {
|
||||
CreateMCInst(MCInsts[2], Mips::ADDu, GPReg, GPReg, T9Reg);
|
||||
}
|
||||
|
||||
// Lower ".cprestore offset" to "sw $gp, offset($sp)".
|
||||
void MipsMCInstLower::LowerCPRESTORE(int64_t Offset,
|
||||
SmallVector<MCInst, 4>& MCInsts) {
|
||||
assert(isInt<32>(Offset) && (Offset >= 0) &&
|
||||
"Imm operand of .cprestore must be a non-negative 32-bit value.");
|
||||
|
||||
MCOperand SPReg = MCOperand::CreateReg(Mips::SP), BaseReg = SPReg;
|
||||
MCOperand GPReg = MCOperand::CreateReg(Mips::GP);
|
||||
|
||||
if (!isInt<16>(Offset)) {
|
||||
unsigned Hi = ((Offset + 0x8000) >> 16) & 0xffff;
|
||||
Offset &= 0xffff;
|
||||
MCOperand ATReg = MCOperand::CreateReg(Mips::AT);
|
||||
BaseReg = ATReg;
|
||||
|
||||
// lui at,hi
|
||||
// addu at,at,sp
|
||||
MCInsts.resize(2);
|
||||
CreateMCInst(MCInsts[0], Mips::LUi, ATReg, MCOperand::CreateImm(Hi));
|
||||
CreateMCInst(MCInsts[1], Mips::ADDu, ATReg, ATReg, SPReg);
|
||||
}
|
||||
|
||||
MCInst Sw;
|
||||
CreateMCInst(Sw, Mips::SW, GPReg, BaseReg, MCOperand::CreateImm(Offset));
|
||||
MCInsts.push_back(Sw);
|
||||
}
|
||||
|
||||
MCOperand MipsMCInstLower::LowerOperand(const MachineOperand& MO,
|
||||
unsigned offset) const {
|
||||
MachineOperandType MOTy = MO.getType();
|
||||
|
@ -34,7 +34,6 @@ public:
|
||||
void Initialize(Mangler *mang, MCContext* C);
|
||||
void Lower(const MachineInstr *MI, MCInst &OutMI) const;
|
||||
void LowerCPLOAD(SmallVector<MCInst, 4>& MCInsts);
|
||||
void LowerCPRESTORE(int64_t Offset, SmallVector<MCInst, 4>& MCInsts);
|
||||
void LowerUnalignedLoadStore(const MachineInstr *MI,
|
||||
SmallVector<MCInst, 4>& MCInsts);
|
||||
void LowerSETGP01(SmallVector<MCInst, 4>& MCInsts);
|
||||
|
Loading…
x
Reference in New Issue
Block a user