diff options
author | Brian Gaeke <gaeke@uiuc.edu> | 2004-03-05 08:39:09 +0000 |
---|---|---|
committer | Brian Gaeke <gaeke@uiuc.edu> | 2004-03-05 08:39:09 +0000 |
commit | 62aa28aef392ccde76888dbb444c567d3f95ef8a (patch) | |
tree | 8dba0ff66211ecb7b1ecc8f34abbbfdffc66d3cd /lib/Target/SparcV8 | |
parent | 4ab483c6ad5695e189cc3e9ae7283173b323046b (diff) | |
download | external_llvm-62aa28aef392ccde76888dbb444c567d3f95ef8a.zip external_llvm-62aa28aef392ccde76888dbb444c567d3f95ef8a.tar.gz external_llvm-62aa28aef392ccde76888dbb444c567d3f95ef8a.tar.bz2 |
Asm output is looking a lot better; not correct for all operands yet though.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12143 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/SparcV8')
-rw-r--r-- | lib/Target/SparcV8/SparcV8AsmPrinter.cpp | 63 |
1 files changed, 62 insertions, 1 deletions
diff --git a/lib/Target/SparcV8/SparcV8AsmPrinter.cpp b/lib/Target/SparcV8/SparcV8AsmPrinter.cpp index 9adb0e7..e9752842 100644 --- a/lib/Target/SparcV8/SparcV8AsmPrinter.cpp +++ b/lib/Target/SparcV8/SparcV8AsmPrinter.cpp @@ -67,6 +67,7 @@ namespace { void emitConstantValueOnly(const Constant *CV); void emitGlobalConstant(const Constant *CV); void printConstantPool(MachineConstantPool *MCP); + void printOperand(const MachineOperand &MI); void printMachineInstruction(const MachineInstr *MI); bool runOnMachineFunction(MachineFunction &F); bool doInitialization(Module &M); @@ -364,6 +365,44 @@ bool V8Printer::runOnMachineFunction(MachineFunction &MF) { return false; } +void V8Printer::printOperand(const MachineOperand &MO) { + const MRegisterInfo &RI = *TM.getRegisterInfo(); + switch (MO.getType()) { + case MachineOperand::MO_VirtualRegister: + if (Value *V = MO.getVRegValueOrNull()) { + O << "<" << V->getName() << ">"; + return; + } + // FALLTHROUGH + case MachineOperand::MO_MachineRegister: + if (MRegisterInfo::isPhysicalRegister(MO.getReg())) + O << "%" << RI.get(MO.getReg()).Name; + else + O << "%reg" << MO.getReg(); + return; + + case MachineOperand::MO_SignExtendedImmed: + case MachineOperand::MO_UnextendedImmed: + O << (int)MO.getImmedValue(); + return; + case MachineOperand::MO_PCRelativeDisp: { + ValueMapTy::const_iterator i = NumberForBB.find(MO.getVRegValue()); + assert (i != NumberForBB.end() + && "Could not find a BB in the NumberForBB map!"); + O << ".LBB" << i->second << " # PC rel: " << MO.getVRegValue()->getName(); + return; + } + case MachineOperand::MO_GlobalAddress: + O << Mang->getValueName(MO.getGlobal()); + return; + case MachineOperand::MO_ExternalSymbol: + O << MO.getSymbolName(); + return; + default: + O << "<unknown operand type>"; return; + } +} + /// printMachineInstruction -- Print out a single SparcV8 LLVM instruction /// MI in GAS syntax to the current output stream. /// @@ -371,7 +410,29 @@ void V8Printer::printMachineInstruction(const MachineInstr *MI) { unsigned Opcode = MI->getOpcode(); const TargetInstrInfo &TII = TM.getInstrInfo(); const TargetInstrDescriptor &Desc = TII.get(Opcode); - O << Desc.Name << "\n"; // not yet done + O << Desc.Name << " "; + + // print non-immediate, non-register-def operands + // then print immediate operands + // then print register-def operands. + std::vector<MachineOperand> print_order; + for (unsigned i = 0; i < MI->getNumOperands (); ++i) + if (!(MI->getOperand (i).isImmediate () + || (MI->getOperand (i).isRegister () + && MI->getOperand (i).isDef ()))) + print_order.push_back (MI->getOperand (i)); + for (unsigned i = 0; i < MI->getNumOperands (); ++i) + if (MI->getOperand (i).isImmediate ()) + print_order.push_back (MI->getOperand (i)); + for (unsigned i = 0; i < MI->getNumOperands (); ++i) + if (MI->getOperand (i).isRegister () && MI->getOperand (i).isDef ()) + print_order.push_back (MI->getOperand (i)); + for (unsigned i = 0, e = print_order.size (); i != e; ++i) { + printOperand (print_order[i]); + if (i != (print_order.size () - 1)) + O << ", "; + } + O << "\n"; } bool V8Printer::doInitialization(Module &M) { |