mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Doxygenify some comments.
Clean up cpReg2MemMI and cpMem2RegMI, and doxygenify comments. Get rid of their uses of SETSW, which is a pseudoinstruction. We can't JIT-compile pseudoinstructions at the moment. This was blowing up 252.eon/jit, which has some HUGE stack frames. Reduce the uses of constantFitsInImmedField(). Consolidate some assertions. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15899 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
883342c1e5
commit
66149920c6
@ -744,82 +744,80 @@ SparcV9RegInfo::cpReg2RegMI(std::vector<MachineInstr*>& mvec,
|
|||||||
mvec.push_back(MI);
|
mvec.push_back(MI);
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
/// cpReg2MemMI - Generate SparcV9 MachineInstrs to store a register
|
||||||
// Copy from a register to memory (i.e., Store). Register number must
|
/// (SrcReg) to memory, at [PtrReg + Offset]. Register numbers must be the
|
||||||
// be the unified register number
|
/// unified register numbers. RegType must be the SparcV9 register type
|
||||||
//---------------------------------------------------------------------------
|
/// of SrcReg. When SrcReg is %ccr, scratchReg must be the
|
||||||
|
/// number of a free integer register. The newly-generated MachineInstrs
|
||||||
|
/// are appended to mvec.
|
||||||
|
///
|
||||||
|
void SparcV9RegInfo::cpReg2MemMI(std::vector<MachineInstr*>& mvec,
|
||||||
|
unsigned SrcReg, unsigned PtrReg, int Offset,
|
||||||
|
int RegType, int scratchReg) const {
|
||||||
|
unsigned OffReg = SparcV9::g4; // Use register g4 for holding large offsets
|
||||||
|
bool useImmediateOffset = true;
|
||||||
|
|
||||||
|
// If the Offset will not fit in the signed-immediate field, we put it in
|
||||||
void
|
// register g4. This takes advantage of the fact that all the opcodes
|
||||||
SparcV9RegInfo::cpReg2MemMI(std::vector<MachineInstr*>& mvec,
|
// used below have the same size immed. field.
|
||||||
unsigned SrcReg,
|
if (RegType != IntCCRegType
|
||||||
unsigned PtrReg,
|
&& !target.getInstrInfo()->constantFitsInImmedField(V9::LDXi, Offset)) {
|
||||||
int Offset, int RegType,
|
// Put the offset into a register. We could do this in fewer steps,
|
||||||
int scratchReg) const {
|
// in some cases (see CreateSETSWConst()) but we're being lazy.
|
||||||
MachineInstr * MI = NULL;
|
MachineInstr *MI = BuildMI(V9::SETHI, 2).addZImm(Offset).addMReg(OffReg,
|
||||||
int OffReg = -1;
|
MachineOperand::Def);
|
||||||
|
MI->getOperand(0).markHi32();
|
||||||
// If the Offset will not fit in the signed-immediate field, find an
|
mvec.push_back(MI);
|
||||||
// unused register to hold the offset value. This takes advantage of
|
MI = BuildMI(V9::ORi,3).addMReg(OffReg).addZImm(Offset).addMReg(OffReg,
|
||||||
// the fact that all the opcodes used below have the same size immed. field.
|
MachineOperand::Def);
|
||||||
// Use the register allocator, PRA, to find an unused reg. at this MI.
|
MI->getOperand(1).markLo32();
|
||||||
//
|
mvec.push_back(MI);
|
||||||
if (RegType != IntCCRegType) // does not use offset below
|
MI = BuildMI(V9::SRAi5,3).addMReg(OffReg).addZImm(0).addMReg(OffReg,
|
||||||
if (! target.getInstrInfo()->constantFitsInImmedField(V9::LDXi, Offset)) {
|
MachineOperand::Def);
|
||||||
#ifdef CAN_FIND_FREE_REGISTER_TRANSPARENTLY
|
mvec.push_back(MI);
|
||||||
RegClass* RC = PRA.getRegClassByID(this->getRegClassIDOfRegType(RegType));
|
useImmediateOffset = false;
|
||||||
OffReg = PRA.getUnusedUniRegAtMI(RC, RegType, MInst, LVSetBef);
|
|
||||||
#else
|
|
||||||
// Default to using register g4 for holding large offsets
|
|
||||||
OffReg = getUnifiedRegNum(SparcV9RegInfo::IntRegClassID,
|
|
||||||
SparcV9IntRegClass::g4);
|
|
||||||
#endif
|
|
||||||
assert(OffReg >= 0 && "FIXME: cpReg2MemMI cannot find an unused reg.");
|
|
||||||
mvec.push_back(BuildMI(V9::SETSW, 2).addZImm(Offset).addReg(OffReg));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MachineInstr *MI = 0;
|
||||||
switch (RegType) {
|
switch (RegType) {
|
||||||
case IntRegType:
|
case IntRegType:
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::STXi, Offset))
|
if (useImmediateOffset)
|
||||||
MI = BuildMI(V9::STXi,3).addMReg(SrcReg).addMReg(PtrReg).addSImm(Offset);
|
MI = BuildMI(V9::STXi,3).addMReg(SrcReg).addMReg(PtrReg).addSImm(Offset);
|
||||||
else
|
else
|
||||||
MI = BuildMI(V9::STXr,3).addMReg(SrcReg).addMReg(PtrReg).addMReg(OffReg);
|
MI = BuildMI(V9::STXr,3).addMReg(SrcReg).addMReg(PtrReg).addMReg(OffReg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FPSingleRegType:
|
case FPSingleRegType:
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::STFi, Offset))
|
if (useImmediateOffset)
|
||||||
MI = BuildMI(V9::STFi, 3).addMReg(SrcReg).addMReg(PtrReg).addSImm(Offset);
|
MI = BuildMI(V9::STFi, 3).addMReg(SrcReg).addMReg(PtrReg).addSImm(Offset);
|
||||||
else
|
else
|
||||||
MI = BuildMI(V9::STFr, 3).addMReg(SrcReg).addMReg(PtrReg).addMReg(OffReg);
|
MI = BuildMI(V9::STFr, 3).addMReg(SrcReg).addMReg(PtrReg).addMReg(OffReg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FPDoubleRegType:
|
case FPDoubleRegType:
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::STDFi, Offset))
|
if (useImmediateOffset)
|
||||||
MI = BuildMI(V9::STDFi,3).addMReg(SrcReg).addMReg(PtrReg).addSImm(Offset);
|
MI = BuildMI(V9::STDFi,3).addMReg(SrcReg).addMReg(PtrReg).addSImm(Offset);
|
||||||
else
|
else
|
||||||
MI = BuildMI(V9::STDFr,3).addMReg(SrcReg).addMReg(PtrReg).addSImm(OffReg);
|
MI = BuildMI(V9::STDFr,3).addMReg(SrcReg).addMReg(PtrReg).addSImm(OffReg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case IntCCRegType:
|
case IntCCRegType:
|
||||||
assert(scratchReg >= 0 && "Need scratch reg to store %ccr to memory");
|
assert(scratchReg >= 0 && getRegType(scratchReg) == IntRegType
|
||||||
assert(getRegType(scratchReg) ==IntRegType && "Invalid scratch reg");
|
&& "Need a scratch reg of integer type to load or store %ccr");
|
||||||
MI = (BuildMI(V9::RDCCR, 2)
|
MI = BuildMI(V9::RDCCR, 2).addMReg(SparcV9::ccr)
|
||||||
.addMReg(getUnifiedRegNum(SparcV9RegInfo::IntCCRegClassID,
|
.addMReg(scratchReg, MachineOperand::Def);
|
||||||
SparcV9IntCCRegClass::ccr))
|
|
||||||
.addMReg(scratchReg, MachineOperand::Def));
|
|
||||||
mvec.push_back(MI);
|
mvec.push_back(MI);
|
||||||
|
|
||||||
cpReg2MemMI(mvec, scratchReg, PtrReg, Offset, IntRegType);
|
cpReg2MemMI(mvec, scratchReg, PtrReg, Offset, IntRegType);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case SpecialRegType: // used only for %fsr itself.
|
case SpecialRegType: // used only for %fsr itself.
|
||||||
case FloatCCRegType: {
|
case FloatCCRegType: {
|
||||||
unsigned fsrReg = getUnifiedRegNum(SparcV9RegInfo::SpecialRegClassID,
|
if (useImmediateOffset)
|
||||||
SparcV9SpecialRegClass::fsr);
|
MI = BuildMI(V9::STXFSRi,3).addMReg(SparcV9::fsr).addMReg(PtrReg)
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::STXFSRi, Offset))
|
.addSImm(Offset);
|
||||||
MI=BuildMI(V9::STXFSRi,3).addMReg(fsrReg).addMReg(PtrReg).addSImm(Offset);
|
|
||||||
else
|
else
|
||||||
MI=BuildMI(V9::STXFSRr,3).addMReg(fsrReg).addMReg(PtrReg).addMReg(OffReg);
|
MI = BuildMI(V9::STXFSRr,3).addMReg(SparcV9::fsr).addMReg(PtrReg)
|
||||||
|
.addMReg(OffReg);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
@ -828,45 +826,42 @@ SparcV9RegInfo::cpReg2MemMI(std::vector<MachineInstr*>& mvec,
|
|||||||
mvec.push_back(MI);
|
mvec.push_back(MI);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// cpMem2RegMI - Generate SparcV9 MachineInstrs to load a register
|
||||||
|
/// (DestReg) from memory, at [PtrReg + Offset]. Register numbers must be the
|
||||||
|
/// unified register numbers. RegType must be the SparcV9 register type
|
||||||
|
/// of DestReg. When DestReg is %ccr, scratchReg must be the
|
||||||
|
/// number of a free integer register. The newly-generated MachineInstrs
|
||||||
|
/// are appended to mvec.
|
||||||
|
///
|
||||||
|
void SparcV9RegInfo::cpMem2RegMI(std::vector<MachineInstr*>& mvec,
|
||||||
|
unsigned PtrReg, int Offset, unsigned DestReg,
|
||||||
|
int RegType, int scratchReg) const {
|
||||||
|
unsigned OffReg = SparcV9::g4; // Use register g4 for holding large offsets
|
||||||
|
bool useImmediateOffset = true;
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
// If the Offset will not fit in the signed-immediate field, we put it in
|
||||||
// Copy from memory to a reg (i.e., Load) Register number must be the unified
|
// register g4. This takes advantage of the fact that all the opcodes
|
||||||
// register number
|
// used below have the same size immed. field.
|
||||||
//---------------------------------------------------------------------------
|
if (RegType != IntCCRegType
|
||||||
|
&& !target.getInstrInfo()->constantFitsInImmedField(V9::LDXi, Offset)) {
|
||||||
|
MachineInstr *MI = BuildMI(V9::SETHI, 2).addZImm(Offset).addMReg(OffReg,
|
||||||
void
|
MachineOperand::Def);
|
||||||
SparcV9RegInfo::cpMem2RegMI(std::vector<MachineInstr*>& mvec,
|
MI->getOperand(0).markHi32();
|
||||||
unsigned PtrReg,
|
mvec.push_back(MI);
|
||||||
int Offset,
|
MI = BuildMI(V9::ORi,3).addMReg(OffReg).addZImm(Offset).addMReg(OffReg,
|
||||||
unsigned DestReg,
|
MachineOperand::Def);
|
||||||
int RegType,
|
MI->getOperand(1).markLo32();
|
||||||
int scratchReg) const {
|
mvec.push_back(MI);
|
||||||
MachineInstr * MI = NULL;
|
MI = BuildMI(V9::SRAi5,3).addMReg(OffReg).addZImm(0).addMReg(OffReg,
|
||||||
int OffReg = -1;
|
MachineOperand::Def);
|
||||||
|
mvec.push_back(MI);
|
||||||
// If the Offset will not fit in the signed-immediate field, find an
|
useImmediateOffset = false;
|
||||||
// unused register to hold the offset value. This takes advantage of
|
|
||||||
// the fact that all the opcodes used below have the same size immed. field.
|
|
||||||
// Use the register allocator, PRA, to find an unused reg. at this MI.
|
|
||||||
//
|
|
||||||
if (RegType != IntCCRegType) // does not use offset below
|
|
||||||
if (! target.getInstrInfo()->constantFitsInImmedField(V9::LDXi, Offset)) {
|
|
||||||
#ifdef CAN_FIND_FREE_REGISTER_TRANSPARENTLY
|
|
||||||
RegClass* RC = PRA.getRegClassByID(this->getRegClassIDOfRegType(RegType));
|
|
||||||
OffReg = PRA.getUnusedUniRegAtMI(RC, RegType, MInst, LVSetBef);
|
|
||||||
#else
|
|
||||||
// Default to using register g4 for holding large offsets
|
|
||||||
OffReg = getUnifiedRegNum(SparcV9RegInfo::IntRegClassID,
|
|
||||||
SparcV9IntRegClass::g4);
|
|
||||||
#endif
|
|
||||||
assert(OffReg >= 0 && "FIXME: cpReg2MemMI cannot find an unused reg.");
|
|
||||||
mvec.push_back(BuildMI(V9::SETSW, 2).addZImm(Offset).addReg(OffReg));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MachineInstr *MI = 0;
|
||||||
switch (RegType) {
|
switch (RegType) {
|
||||||
case IntRegType:
|
case IntRegType:
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::LDXi, Offset))
|
if (useImmediateOffset)
|
||||||
MI = BuildMI(V9::LDXi, 3).addMReg(PtrReg).addSImm(Offset)
|
MI = BuildMI(V9::LDXi, 3).addMReg(PtrReg).addSImm(Offset)
|
||||||
.addMReg(DestReg, MachineOperand::Def);
|
.addMReg(DestReg, MachineOperand::Def);
|
||||||
else
|
else
|
||||||
@ -875,7 +870,7 @@ SparcV9RegInfo::cpMem2RegMI(std::vector<MachineInstr*>& mvec,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case FPSingleRegType:
|
case FPSingleRegType:
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::LDFi, Offset))
|
if (useImmediateOffset)
|
||||||
MI = BuildMI(V9::LDFi, 3).addMReg(PtrReg).addSImm(Offset)
|
MI = BuildMI(V9::LDFi, 3).addMReg(PtrReg).addSImm(Offset)
|
||||||
.addMReg(DestReg, MachineOperand::Def);
|
.addMReg(DestReg, MachineOperand::Def);
|
||||||
else
|
else
|
||||||
@ -884,7 +879,7 @@ SparcV9RegInfo::cpMem2RegMI(std::vector<MachineInstr*>& mvec,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case FPDoubleRegType:
|
case FPDoubleRegType:
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::LDDFi, Offset))
|
if (useImmediateOffset)
|
||||||
MI= BuildMI(V9::LDDFi, 3).addMReg(PtrReg).addSImm(Offset)
|
MI= BuildMI(V9::LDDFi, 3).addMReg(PtrReg).addSImm(Offset)
|
||||||
.addMReg(DestReg, MachineOperand::Def);
|
.addMReg(DestReg, MachineOperand::Def);
|
||||||
else
|
else
|
||||||
@ -893,26 +888,21 @@ SparcV9RegInfo::cpMem2RegMI(std::vector<MachineInstr*>& mvec,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case IntCCRegType:
|
case IntCCRegType:
|
||||||
assert(scratchReg >= 0 && "Need scratch reg to load %ccr from memory");
|
assert(scratchReg >= 0 && getRegType(scratchReg) == IntRegType
|
||||||
assert(getRegType(scratchReg) ==IntRegType && "Invalid scratch reg");
|
&& "Need a scratch reg of integer type to load or store %ccr");
|
||||||
cpMem2RegMI(mvec, PtrReg, Offset, scratchReg, IntRegType);
|
cpMem2RegMI(mvec, PtrReg, Offset, scratchReg, IntRegType);
|
||||||
MI = (BuildMI(V9::WRCCRr, 3)
|
MI = BuildMI(V9::WRCCRr, 3).addMReg(scratchReg).addMReg(SparcV9::g0)
|
||||||
.addMReg(scratchReg)
|
.addMReg(SparcV9::ccr, MachineOperand::Def);
|
||||||
.addMReg(SparcV9IntRegClass::g0)
|
|
||||||
.addMReg(getUnifiedRegNum(SparcV9RegInfo::IntCCRegClassID,
|
|
||||||
SparcV9IntCCRegClass::ccr), MachineOperand::Def));
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SpecialRegType: // used only for %fsr itself
|
case SpecialRegType: // used only for %fsr itself
|
||||||
case FloatCCRegType: {
|
case FloatCCRegType: {
|
||||||
unsigned fsrRegNum = getUnifiedRegNum(SparcV9RegInfo::SpecialRegClassID,
|
if (useImmediateOffset)
|
||||||
SparcV9SpecialRegClass::fsr);
|
|
||||||
if (target.getInstrInfo()->constantFitsInImmedField(V9::LDXFSRi, Offset))
|
|
||||||
MI = BuildMI(V9::LDXFSRi, 3).addMReg(PtrReg).addSImm(Offset)
|
MI = BuildMI(V9::LDXFSRi, 3).addMReg(PtrReg).addSImm(Offset)
|
||||||
.addMReg(fsrRegNum, MachineOperand::UseAndDef);
|
.addMReg(SparcV9::fsr, MachineOperand::Def);
|
||||||
else
|
else
|
||||||
MI = BuildMI(V9::LDXFSRr, 3).addMReg(PtrReg).addMReg(OffReg)
|
MI = BuildMI(V9::LDXFSRr, 3).addMReg(PtrReg).addMReg(OffReg)
|
||||||
.addMReg(fsrRegNum, MachineOperand::UseAndDef);
|
.addMReg(SparcV9::fsr, MachineOperand::Def);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user