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:
Brian Gaeke 2004-08-18 17:44:14 +00:00
parent 883342c1e5
commit 66149920c6

View File

@ -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: