diff options
| author | Eric Christopher <echristo@apple.com> | 2012-05-10 21:48:22 +0000 |
|---|---|---|
| committer | Eric Christopher <echristo@apple.com> | 2012-05-10 21:48:22 +0000 |
| commit | ed51b9ec0bc3c3887f64b74793cd7997039fefe2 (patch) | |
| tree | 27dc4285c3ffb7a0798ea910dd0f4d00cab6a5c2 /llvm/lib/Target | |
| parent | c5d7008f2713e9034db5131ecb006d7ef88c9e3a (diff) | |
| download | bcm5719-llvm-ed51b9ec0bc3c3887f64b74793cd7997039fefe2.tar.gz bcm5719-llvm-ed51b9ec0bc3c3887f64b74793cd7997039fefe2.zip | |
Add support for the 'X' inline asm operand modifier.
Patch by Jack Carter.
llvm-svn: 156577
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/Mips/MipsAsmPrinter.cpp | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/llvm/lib/Target/Mips/MipsAsmPrinter.cpp b/llvm/lib/Target/Mips/MipsAsmPrinter.cpp index 33337383a0b..65dd6e95873 100644 --- a/llvm/lib/Target/Mips/MipsAsmPrinter.cpp +++ b/llvm/lib/Target/Mips/MipsAsmPrinter.cpp @@ -382,14 +382,26 @@ bool MipsAsmPrinter::isBlockOnlyReachableByFallthrough(const MachineBasicBlock* } // Print out an operand for an inline asm expression. -bool MipsAsmPrinter::PrintAsmOperand(const MachineInstr *MI, unsigned OpNo, +bool MipsAsmPrinter::PrintAsmOperand(const MachineInstr *MI, unsigned OpNum, unsigned AsmVariant,const char *ExtraCode, raw_ostream &O) { // Does this asm operand have a single letter operand modifier? - if (ExtraCode && ExtraCode[0]) - return true; // Unknown modifier. + if (ExtraCode && ExtraCode[0]) { + if (ExtraCode[1] != 0) return true; // Unknown modifier. + + const MachineOperand &MO = MI->getOperand(OpNum); + switch (ExtraCode[0]) { + default: + return true; // Unknown modifier. + case 'X': // hex const int + if ((MO.getType()) != MachineOperand::MO_Immediate) + return true; + O << "0x" << StringRef(utohexstr(MO.getImm())).lower(); + return false; + } + } - printOperand(MI, OpNo, O); + printOperand(MI, OpNum, O); return false; } |

