mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
Do not move any values into registers for a void return (there isn't anything).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14413 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1cbb3ee75f
commit
d47bbf7ce5
@ -1062,26 +1062,29 @@ void ISel::promote32(unsigned targetReg, const ValueRecord &VR) {
|
||||
/// visitReturnInst - implemented with BLR
|
||||
///
|
||||
void ISel::visitReturnInst(ReturnInst &I) {
|
||||
Value *RetVal = I.getOperand(0);
|
||||
switch (getClassB(RetVal->getType())) {
|
||||
case cByte: // integral return values: extend or move into r3 and return
|
||||
case cShort:
|
||||
case cInt:
|
||||
promote32(PPC32::R3, ValueRecord(RetVal));
|
||||
break;
|
||||
case cFP: { // Floats & Doubles: Return in f1
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::FMR, 1, PPC32::F1).addReg(RetReg);
|
||||
break;
|
||||
}
|
||||
case cLong: {
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R3).addReg(RetReg).addReg(RetReg);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R4).addReg(RetReg+1).addReg(RetReg+1);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
visitInstruction(I);
|
||||
// Only do the processing if this is a non-void return
|
||||
if (I.getNumOperands() > 0) {
|
||||
Value *RetVal = I.getOperand(0);
|
||||
switch (getClassB(RetVal->getType())) {
|
||||
case cByte: // integral return values: extend or move into r3 and return
|
||||
case cShort:
|
||||
case cInt:
|
||||
promote32(PPC32::R3, ValueRecord(RetVal));
|
||||
break;
|
||||
case cFP: { // Floats & Doubles: Return in f1
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::FMR, 1, PPC32::F1).addReg(RetReg);
|
||||
break;
|
||||
}
|
||||
case cLong: {
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R3).addReg(RetReg).addReg(RetReg);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R4).addReg(RetReg+1).addReg(RetReg+1);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
visitInstruction(I);
|
||||
}
|
||||
}
|
||||
BuildMI(BB, PPC32::BLR, 1).addImm(0);
|
||||
}
|
||||
|
@ -1062,26 +1062,29 @@ void ISel::promote32(unsigned targetReg, const ValueRecord &VR) {
|
||||
/// visitReturnInst - implemented with BLR
|
||||
///
|
||||
void ISel::visitReturnInst(ReturnInst &I) {
|
||||
Value *RetVal = I.getOperand(0);
|
||||
switch (getClassB(RetVal->getType())) {
|
||||
case cByte: // integral return values: extend or move into r3 and return
|
||||
case cShort:
|
||||
case cInt:
|
||||
promote32(PPC32::R3, ValueRecord(RetVal));
|
||||
break;
|
||||
case cFP: { // Floats & Doubles: Return in f1
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::FMR, 1, PPC32::F1).addReg(RetReg);
|
||||
break;
|
||||
}
|
||||
case cLong: {
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R3).addReg(RetReg).addReg(RetReg);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R4).addReg(RetReg+1).addReg(RetReg+1);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
visitInstruction(I);
|
||||
// Only do the processing if this is a non-void return
|
||||
if (I.getNumOperands() > 0) {
|
||||
Value *RetVal = I.getOperand(0);
|
||||
switch (getClassB(RetVal->getType())) {
|
||||
case cByte: // integral return values: extend or move into r3 and return
|
||||
case cShort:
|
||||
case cInt:
|
||||
promote32(PPC32::R3, ValueRecord(RetVal));
|
||||
break;
|
||||
case cFP: { // Floats & Doubles: Return in f1
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::FMR, 1, PPC32::F1).addReg(RetReg);
|
||||
break;
|
||||
}
|
||||
case cLong: {
|
||||
unsigned RetReg = getReg(RetVal);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R3).addReg(RetReg).addReg(RetReg);
|
||||
BuildMI(BB, PPC32::OR, 2, PPC32::R4).addReg(RetReg+1).addReg(RetReg+1);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
visitInstruction(I);
|
||||
}
|
||||
}
|
||||
BuildMI(BB, PPC32::BLR, 1).addImm(0);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user