mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 01:31:05 +00:00
Deal with call return values.
Don't put NOPs in delay slots at all. We'll have a fix-up pass later. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12725 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
94f0c5286b
commit
ea8494bb89
@ -229,8 +229,22 @@ bool V8ISel::runOnFunction(Function &Fn) {
|
||||
|
||||
void V8ISel::visitCallInst(CallInst &I) {
|
||||
assert (I.getNumOperands () == 1 && "Can't handle call args yet");
|
||||
unsigned DestReg = getReg (I);
|
||||
BuildMI (BB, V8::CALL, 1).addPCDisp (I.getOperand (0));
|
||||
BuildMI (BB, V8::NOP, 0); // NOP in delay slot
|
||||
if (I.getType ()->getPrimitiveID () == Type::VoidTyID)
|
||||
return;
|
||||
// Deal w/ return value
|
||||
switch (getClass (I.getType ())) {
|
||||
case cByte:
|
||||
case cShort:
|
||||
case cInt:
|
||||
// Schlep it over into the destination register
|
||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg(V8::G0).addReg(V8::O0);
|
||||
break;
|
||||
default:
|
||||
visitInstruction (I);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
void V8ISel::visitReturnInst(ReturnInst &I) {
|
||||
|
@ -229,8 +229,22 @@ bool V8ISel::runOnFunction(Function &Fn) {
|
||||
|
||||
void V8ISel::visitCallInst(CallInst &I) {
|
||||
assert (I.getNumOperands () == 1 && "Can't handle call args yet");
|
||||
unsigned DestReg = getReg (I);
|
||||
BuildMI (BB, V8::CALL, 1).addPCDisp (I.getOperand (0));
|
||||
BuildMI (BB, V8::NOP, 0); // NOP in delay slot
|
||||
if (I.getType ()->getPrimitiveID () == Type::VoidTyID)
|
||||
return;
|
||||
// Deal w/ return value
|
||||
switch (getClass (I.getType ())) {
|
||||
case cByte:
|
||||
case cShort:
|
||||
case cInt:
|
||||
// Schlep it over into the destination register
|
||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg(V8::G0).addReg(V8::O0);
|
||||
break;
|
||||
default:
|
||||
visitInstruction (I);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
void V8ISel::visitReturnInst(ReturnInst &I) {
|
||||
|
@ -229,8 +229,22 @@ bool V8ISel::runOnFunction(Function &Fn) {
|
||||
|
||||
void V8ISel::visitCallInst(CallInst &I) {
|
||||
assert (I.getNumOperands () == 1 && "Can't handle call args yet");
|
||||
unsigned DestReg = getReg (I);
|
||||
BuildMI (BB, V8::CALL, 1).addPCDisp (I.getOperand (0));
|
||||
BuildMI (BB, V8::NOP, 0); // NOP in delay slot
|
||||
if (I.getType ()->getPrimitiveID () == Type::VoidTyID)
|
||||
return;
|
||||
// Deal w/ return value
|
||||
switch (getClass (I.getType ())) {
|
||||
case cByte:
|
||||
case cShort:
|
||||
case cInt:
|
||||
// Schlep it over into the destination register
|
||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg(V8::G0).addReg(V8::O0);
|
||||
break;
|
||||
default:
|
||||
visitInstruction (I);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
void V8ISel::visitReturnInst(ReturnInst &I) {
|
||||
|
@ -229,8 +229,22 @@ bool V8ISel::runOnFunction(Function &Fn) {
|
||||
|
||||
void V8ISel::visitCallInst(CallInst &I) {
|
||||
assert (I.getNumOperands () == 1 && "Can't handle call args yet");
|
||||
unsigned DestReg = getReg (I);
|
||||
BuildMI (BB, V8::CALL, 1).addPCDisp (I.getOperand (0));
|
||||
BuildMI (BB, V8::NOP, 0); // NOP in delay slot
|
||||
if (I.getType ()->getPrimitiveID () == Type::VoidTyID)
|
||||
return;
|
||||
// Deal w/ return value
|
||||
switch (getClass (I.getType ())) {
|
||||
case cByte:
|
||||
case cShort:
|
||||
case cInt:
|
||||
// Schlep it over into the destination register
|
||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg(V8::G0).addReg(V8::O0);
|
||||
break;
|
||||
default:
|
||||
visitInstruction (I);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
void V8ISel::visitReturnInst(ReturnInst &I) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user