mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-15 05:24:01 +00:00
Add special code to make printing SSA form machine instructions nicer
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@4446 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -266,9 +266,20 @@ static void print(const MachineOperand &MO, std::ostream &OS,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void MachineInstr::print(std::ostream &OS, const TargetMachine &TM) {
|
void MachineInstr::print(std::ostream &OS, const TargetMachine &TM) {
|
||||||
|
unsigned StartOp = 0;
|
||||||
|
|
||||||
|
// Specialize printing if op#0 is definition
|
||||||
|
if (getNumOperands() && operandIsDefined(0)) {
|
||||||
|
::print(getOperand(0), OS, TM);
|
||||||
|
OS << " = ";
|
||||||
|
++StartOp; // Don't print this operand again!
|
||||||
|
}
|
||||||
OS << TM.getInstrInfo().getName(getOpcode());
|
OS << TM.getInstrInfo().getName(getOpcode());
|
||||||
for (unsigned i = 0, e = getNumOperands(); i != e; ++i) {
|
|
||||||
OS << "\t";
|
for (unsigned i = StartOp, e = getNumOperands(); i != e; ++i) {
|
||||||
|
if (i != StartOp)
|
||||||
|
OS << ",";
|
||||||
|
OS << " ";
|
||||||
::print(getOperand(i), OS, TM);
|
::print(getOperand(i), OS, TM);
|
||||||
|
|
||||||
if (operandIsDefinedAndUsed(i))
|
if (operandIsDefinedAndUsed(i))
|
||||||
|
Reference in New Issue
Block a user