mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-20 08:54:08 +00:00
Added support for condition code loading/stroing in methods cpReg2Reg etc.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@911 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
97b8b4410a
commit
735d6e3ee2
@ -42,7 +42,7 @@ void SparcIntRegClass::colorIGNode(IGNode * Node, bool IsColorUsedArr[]) const
|
|||||||
LR->setColor( LR->getSuggestedColor() );
|
LR->setColor( LR->getSuggestedColor() );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else { // can't allocate the suggested col
|
else if ( DEBUG_RA ) { // can't allocate the suggested col
|
||||||
cerr << " Could NOT allocate the suggested color for LR ";
|
cerr << " Could NOT allocate the suggested color for LR ";
|
||||||
LR->printSet(); cerr << endl;
|
LR->printSet(); cerr << endl;
|
||||||
}
|
}
|
||||||
@ -192,7 +192,7 @@ void SparcFloatRegClass::colorIGNode(IGNode * Node,bool IsColorUsedArr[]) const
|
|||||||
LR->setColor( LR->getSuggestedColor() );
|
LR->setColor( LR->getSuggestedColor() );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else { // can't allocate the suggested col
|
else if (DEBUG_RA) { // can't allocate the suggested col
|
||||||
cerr << " Could NOT allocate the suggested color for LR ";
|
cerr << " Could NOT allocate the suggested color for LR ";
|
||||||
LR->printSet(); cerr << endl;
|
LR->printSet(); cerr << endl;
|
||||||
}
|
}
|
||||||
|
@ -621,6 +621,8 @@ MachineInstr * UltraSparcRegInfo::cpReg2RegMI(const unsigned SrcReg,
|
|||||||
switch( RegType ) {
|
switch( RegType ) {
|
||||||
|
|
||||||
case IntRegType:
|
case IntRegType:
|
||||||
|
case IntCCRegType:
|
||||||
|
case FloatCCRegType:
|
||||||
MI = new MachineInstr(ADD, 3);
|
MI = new MachineInstr(ADD, 3);
|
||||||
MI->SetMachineOperand(0, SrcReg, false);
|
MI->SetMachineOperand(0, SrcReg, false);
|
||||||
MI->SetMachineOperand(1, SparcIntRegOrder::g0, false);
|
MI->SetMachineOperand(1, SparcIntRegOrder::g0, false);
|
||||||
@ -664,6 +666,8 @@ MachineInstr * UltraSparcRegInfo::cpReg2MemMI(const unsigned SrcReg,
|
|||||||
switch( RegType ) {
|
switch( RegType ) {
|
||||||
|
|
||||||
case IntRegType:
|
case IntRegType:
|
||||||
|
case IntCCRegType:
|
||||||
|
case FloatCCRegType:
|
||||||
MI = new MachineInstr(STX, 3);
|
MI = new MachineInstr(STX, 3);
|
||||||
MI->SetMachineOperand(0, DestPtrReg, false);
|
MI->SetMachineOperand(0, DestPtrReg, false);
|
||||||
MI->SetMachineOperand(1, SrcReg, false);
|
MI->SetMachineOperand(1, SrcReg, false);
|
||||||
@ -711,6 +715,8 @@ MachineInstr * UltraSparcRegInfo::cpMem2RegMI(const unsigned SrcPtrReg,
|
|||||||
switch( RegType ) {
|
switch( RegType ) {
|
||||||
|
|
||||||
case IntRegType:
|
case IntRegType:
|
||||||
|
case IntCCRegType:
|
||||||
|
case FloatCCRegType:
|
||||||
MI = new MachineInstr(LDX, 3);
|
MI = new MachineInstr(LDX, 3);
|
||||||
MI->SetMachineOperand(0, SrcPtrReg, false);
|
MI->SetMachineOperand(0, SrcPtrReg, false);
|
||||||
MI->SetMachineOperand(1, MachineOperand:: MO_SignExtendedImmed,
|
MI->SetMachineOperand(1, MachineOperand:: MO_SignExtendedImmed,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user