diff options
| author | Vikram S. Adve <vadve@cs.uiuc.edu> | 2002-07-10 21:41:21 +0000 | 
|---|---|---|
| committer | Vikram S. Adve <vadve@cs.uiuc.edu> | 2002-07-10 21:41:21 +0000 | 
| commit | 4e1ee14694fb8257ff8bd35f81226a6c21e1a825 (patch) | |
| tree | b28b5a79fc18e3c44bb767ccb8bdb52848d22c78 /llvm/lib/Target/Sparc | |
| parent | 58c904ace6ff7efc215b140fdce390c2615ee16f (diff) | |
| download | bcm5719-llvm-4e1ee14694fb8257ff8bd35f81226a6c21e1a825.tar.gz bcm5719-llvm-4e1ee14694fb8257ff8bd35f81226a6c21e1a825.zip | |
Add support to print %hh, %hm, %lm, or %lo in an operand field.
llvm-svn: 2857
Diffstat (limited to 'llvm/lib/Target/Sparc')
| -rw-r--r-- | llvm/lib/Target/Sparc/EmitAssembly.cpp | 44 | 
1 files changed, 30 insertions, 14 deletions
| diff --git a/llvm/lib/Target/Sparc/EmitAssembly.cpp b/llvm/lib/Target/Sparc/EmitAssembly.cpp index 881a67e788c..940b72205fe 100644 --- a/llvm/lib/Target/Sparc/EmitAssembly.cpp +++ b/llvm/lib/Target/Sparc/EmitAssembly.cpp @@ -259,47 +259,60 @@ SparcFunctionAsmPrinter::OpIsMemoryAddressBase(const MachineInstr *MI,  } -#define PrintOp1PlusOp2(Op1, Op2) \ -  printOneOperand(Op1); \ +#define PrintOp1PlusOp2(mop1, mop2) \ +  printOneOperand(mop1); \    toAsm << "+"; \ -  printOneOperand(Op2); +  printOneOperand(mop2);  unsigned int  SparcFunctionAsmPrinter::printOperands(const MachineInstr *MI,                                 unsigned int opNum)  { -  const MachineOperand& Op = MI->getOperand(opNum); +  const MachineOperand& mop = MI->getOperand(opNum);    if (OpIsBranchTargetLabel(MI, opNum))      { -      PrintOp1PlusOp2(Op, MI->getOperand(opNum+1)); +      PrintOp1PlusOp2(mop, MI->getOperand(opNum+1));        return 2;      }    else if (OpIsMemoryAddressBase(MI, opNum))      {        toAsm << "["; -      PrintOp1PlusOp2(Op, MI->getOperand(opNum+1)); +      PrintOp1PlusOp2(mop, MI->getOperand(opNum+1));        toAsm << "]";        return 2;      }    else      { -      printOneOperand(Op); +      printOneOperand(mop);        return 1;      }  }  void -SparcFunctionAsmPrinter::printOneOperand(const MachineOperand &op) +SparcFunctionAsmPrinter::printOneOperand(const MachineOperand &mop)  { -  switch (op.getOperandType()) +  bool needBitsFlag = true; +   +  if (mop.opHiBits32()) +    toAsm << "%lm("; +  else if (mop.opLoBits32()) +    toAsm << "%lo("; +  else if (mop.opHiBits64()) +    toAsm << "%hh("; +  else if (mop.opLoBits64()) +    toAsm << "%hm("; +  else +    needBitsFlag = false; +   +  switch (mop.getOperandType())      {      case MachineOperand::MO_VirtualRegister:      case MachineOperand::MO_CCRegister:      case MachineOperand::MO_MachineRegister:        { -        int RegNum = (int)op.getAllocatedRegNum(); +        int RegNum = (int)mop.getAllocatedRegNum();          // better to print code with NULL registers than to die          if (RegNum == Target.getRegInfo().getInvalidRegNum()) { @@ -312,7 +325,7 @@ SparcFunctionAsmPrinter::printOneOperand(const MachineOperand &op)      case MachineOperand::MO_PCRelativeDisp:        { -        const Value *Val = op.getVRegValue(); +        const Value *Val = mop.getVRegValue();          assert(Val && "\tNULL Value in SparcFunctionAsmPrinter");          if (const BasicBlock *BB = dyn_cast<const BasicBlock>(Val)) @@ -329,17 +342,20 @@ SparcFunctionAsmPrinter::printOneOperand(const MachineOperand &op)        }      case MachineOperand::MO_SignExtendedImmed: -      toAsm << op.getImmedValue(); +      toAsm << mop.getImmedValue();        break;      case MachineOperand::MO_UnextendedImmed: -      toAsm << (uint64_t) op.getImmedValue(); +      toAsm << (uint64_t) mop.getImmedValue();        break;      default: -      toAsm << op;      // use dump field +      toAsm << mop;      // use dump field        break;      } +   +  if (needBitsFlag) +    toAsm << ")";  } | 

