mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
Implement spill and fill of I64Regs.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182228 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
900622e099
commit
5e5b78ca36
@ -40,6 +40,7 @@ SparcInstrInfo::SparcInstrInfo(SparcSubtarget &ST)
|
|||||||
unsigned SparcInstrInfo::isLoadFromStackSlot(const MachineInstr *MI,
|
unsigned SparcInstrInfo::isLoadFromStackSlot(const MachineInstr *MI,
|
||||||
int &FrameIndex) const {
|
int &FrameIndex) const {
|
||||||
if (MI->getOpcode() == SP::LDri ||
|
if (MI->getOpcode() == SP::LDri ||
|
||||||
|
MI->getOpcode() == SP::LDXri ||
|
||||||
MI->getOpcode() == SP::LDFri ||
|
MI->getOpcode() == SP::LDFri ||
|
||||||
MI->getOpcode() == SP::LDDFri) {
|
MI->getOpcode() == SP::LDDFri) {
|
||||||
if (MI->getOperand(1).isFI() && MI->getOperand(2).isImm() &&
|
if (MI->getOperand(1).isFI() && MI->getOperand(2).isImm() &&
|
||||||
@ -59,6 +60,7 @@ unsigned SparcInstrInfo::isLoadFromStackSlot(const MachineInstr *MI,
|
|||||||
unsigned SparcInstrInfo::isStoreToStackSlot(const MachineInstr *MI,
|
unsigned SparcInstrInfo::isStoreToStackSlot(const MachineInstr *MI,
|
||||||
int &FrameIndex) const {
|
int &FrameIndex) const {
|
||||||
if (MI->getOpcode() == SP::STri ||
|
if (MI->getOpcode() == SP::STri ||
|
||||||
|
MI->getOpcode() == SP::STXri ||
|
||||||
MI->getOpcode() == SP::STFri ||
|
MI->getOpcode() == SP::STFri ||
|
||||||
MI->getOpcode() == SP::STDFri) {
|
MI->getOpcode() == SP::STDFri) {
|
||||||
if (MI->getOperand(0).isFI() && MI->getOperand(1).isImm() &&
|
if (MI->getOperand(0).isFI() && MI->getOperand(1).isImm() &&
|
||||||
@ -303,7 +305,10 @@ storeRegToStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator I,
|
|||||||
if (I != MBB.end()) DL = I->getDebugLoc();
|
if (I != MBB.end()) DL = I->getDebugLoc();
|
||||||
|
|
||||||
// On the order of operands here: think "[FrameIdx + 0] = SrcReg".
|
// On the order of operands here: think "[FrameIdx + 0] = SrcReg".
|
||||||
if (RC == &SP::IntRegsRegClass)
|
if (RC == &SP::I64RegsRegClass)
|
||||||
|
BuildMI(MBB, I, DL, get(SP::STXri)).addFrameIndex(FI).addImm(0)
|
||||||
|
.addReg(SrcReg, getKillRegState(isKill));
|
||||||
|
else if (RC == &SP::IntRegsRegClass)
|
||||||
BuildMI(MBB, I, DL, get(SP::STri)).addFrameIndex(FI).addImm(0)
|
BuildMI(MBB, I, DL, get(SP::STri)).addFrameIndex(FI).addImm(0)
|
||||||
.addReg(SrcReg, getKillRegState(isKill));
|
.addReg(SrcReg, getKillRegState(isKill));
|
||||||
else if (RC == &SP::FPRegsRegClass)
|
else if (RC == &SP::FPRegsRegClass)
|
||||||
@ -324,7 +329,9 @@ loadRegFromStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator I,
|
|||||||
DebugLoc DL;
|
DebugLoc DL;
|
||||||
if (I != MBB.end()) DL = I->getDebugLoc();
|
if (I != MBB.end()) DL = I->getDebugLoc();
|
||||||
|
|
||||||
if (RC == &SP::IntRegsRegClass)
|
if (RC == &SP::I64RegsRegClass)
|
||||||
|
BuildMI(MBB, I, DL, get(SP::LDXri), DestReg).addFrameIndex(FI).addImm(0);
|
||||||
|
else if (RC == &SP::IntRegsRegClass)
|
||||||
BuildMI(MBB, I, DL, get(SP::LDri), DestReg).addFrameIndex(FI).addImm(0);
|
BuildMI(MBB, I, DL, get(SP::LDri), DestReg).addFrameIndex(FI).addImm(0);
|
||||||
else if (RC == &SP::FPRegsRegClass)
|
else if (RC == &SP::FPRegsRegClass)
|
||||||
BuildMI(MBB, I, DL, get(SP::LDFri), DestReg).addFrameIndex(FI).addImm(0);
|
BuildMI(MBB, I, DL, get(SP::LDFri), DestReg).addFrameIndex(FI).addImm(0);
|
||||||
|
@ -201,3 +201,11 @@ define i32 @expand_setcc(i64 %a) {
|
|||||||
%RV = sub i32 1, %cast2
|
%RV = sub i32 1, %cast2
|
||||||
ret i32 %RV
|
ret i32 %RV
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; CHECK: spill_i64
|
||||||
|
; CHECK: stx
|
||||||
|
; CHECK: ldx
|
||||||
|
define i64 @spill_i64(i64 %x) {
|
||||||
|
call void asm sideeffect "", "~{i0},~{i1},~{i2},~{i3},~{i4},~{i5},~{o0},~{o1},~{o2},~{o3},~{o4},~{o5},~{o7},~{l0},~{l1},~{l2},~{l3},~{l4},~{l5},~{l6},~{l7},~{g1},~{g2},~{g3},~{g4},~{g5},~{g6},~{g7}"()
|
||||||
|
ret i64 %x
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user