mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-04 05:31:06 +00:00
expand PICLDR MC lowering to handle other PICLDR and PICSTR versions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114183 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
23bea41ec6
commit
a28abbe245
@ -1351,10 +1351,17 @@ void ARMAsmPrinter::printInstructionThroughMCStreamer(const MachineInstr *MI) {
|
|||||||
OutStreamer.EmitInstruction(AddInst);
|
OutStreamer.EmitInstruction(AddInst);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
case ARM::PICLDR: {
|
case ARM::PICSTR:
|
||||||
|
case ARM::PICSTRB:
|
||||||
|
case ARM::PICSTRH:
|
||||||
|
case ARM::PICLDR:
|
||||||
|
case ARM::PICLDRB:
|
||||||
|
case ARM::PICLDRH:
|
||||||
|
case ARM::PICLDRSB:
|
||||||
|
case ARM::PICLDRSH: {
|
||||||
// This is a pseudo op for a label + instruction sequence, which looks like:
|
// This is a pseudo op for a label + instruction sequence, which looks like:
|
||||||
// LPC0:
|
// LPC0:
|
||||||
// ldr r0, [pc, r0]
|
// OP r0, [pc, r0]
|
||||||
// The LCP0 label is referenced by a constant pool entry in order to get
|
// The LCP0 label is referenced by a constant pool entry in order to get
|
||||||
// a PC-relative address at the ldr instruction.
|
// a PC-relative address at the ldr instruction.
|
||||||
|
|
||||||
@ -1367,16 +1374,29 @@ void ARMAsmPrinter::printInstructionThroughMCStreamer(const MachineInstr *MI) {
|
|||||||
OutStreamer.EmitLabel(Label);
|
OutStreamer.EmitLabel(Label);
|
||||||
|
|
||||||
// Form and emit the load
|
// Form and emit the load
|
||||||
MCInst LdrInst;
|
unsigned Opcode;
|
||||||
LdrInst.setOpcode(ARM::LDR);
|
switch (MI->getOpcode()) {
|
||||||
LdrInst.addOperand(MCOperand::CreateReg(MI->getOperand(0).getReg()));
|
default:
|
||||||
LdrInst.addOperand(MCOperand::CreateReg(ARM::PC));
|
llvm_unreachable("Unexpected opcode!");
|
||||||
LdrInst.addOperand(MCOperand::CreateReg(MI->getOperand(1).getReg()));
|
case ARM::PICSTR: Opcode = ARM::STR; break;
|
||||||
LdrInst.addOperand(MCOperand::CreateImm(0));
|
case ARM::PICSTRB: Opcode = ARM::STRB; break;
|
||||||
|
case ARM::PICSTRH: Opcode = ARM::STRH; break;
|
||||||
|
case ARM::PICLDR: Opcode = ARM::LDR; break;
|
||||||
|
case ARM::PICLDRB: Opcode = ARM::LDRB; break;
|
||||||
|
case ARM::PICLDRH: Opcode = ARM::LDRH; break;
|
||||||
|
case ARM::PICLDRSB: Opcode = ARM::LDRSB; break;
|
||||||
|
case ARM::PICLDRSH: Opcode = ARM::LDRSH; break;
|
||||||
|
}
|
||||||
|
MCInst LdStInst;
|
||||||
|
LdStInst.setOpcode(Opcode);
|
||||||
|
LdStInst.addOperand(MCOperand::CreateReg(MI->getOperand(0).getReg()));
|
||||||
|
LdStInst.addOperand(MCOperand::CreateReg(ARM::PC));
|
||||||
|
LdStInst.addOperand(MCOperand::CreateReg(MI->getOperand(1).getReg()));
|
||||||
|
LdStInst.addOperand(MCOperand::CreateImm(0));
|
||||||
// Add predicate operands.
|
// Add predicate operands.
|
||||||
LdrInst.addOperand(MCOperand::CreateImm(MI->getOperand(3).getImm()));
|
LdStInst.addOperand(MCOperand::CreateImm(MI->getOperand(3).getImm()));
|
||||||
LdrInst.addOperand(MCOperand::CreateReg(MI->getOperand(4).getReg()));
|
LdStInst.addOperand(MCOperand::CreateReg(MI->getOperand(4).getReg()));
|
||||||
OutStreamer.EmitInstruction(LdrInst);
|
OutStreamer.EmitInstruction(LdStInst);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user