summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2009-08-19 22:44:41 +0000
committerDale Johannesen <dalej@apple.com>2009-08-19 22:44:41 +0000
commit1d764f61ef15514a58078a51603b05d969efcbeb (patch)
tree5a3f0ada0e97c2f167d9e427e22591800183d8ad /llvm/lib
parentd72b091840d12143f4a81cb7637911b7271cbf9e (diff)
downloadbcm5719-llvm-1d764f61ef15514a58078a51603b05d969efcbeb.tar.gz
bcm5719-llvm-1d764f61ef15514a58078a51603b05d969efcbeb.zip
Handle 'a' modifier in X86 asms. PR 4742.
llvm-svn: 79484
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/X86/AsmPrinter/X86ATTAsmPrinter.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/AsmPrinter/X86ATTAsmPrinter.cpp b/llvm/lib/Target/X86/AsmPrinter/X86ATTAsmPrinter.cpp
index 1e2a6de572a..c37ae9919ce 100644
--- a/llvm/lib/Target/X86/AsmPrinter/X86ATTAsmPrinter.cpp
+++ b/llvm/lib/Target/X86/AsmPrinter/X86ATTAsmPrinter.cpp
@@ -620,6 +620,18 @@ bool X86ATTAsmPrinter::PrintAsmOperand(const MachineInstr *MI, unsigned OpNo,
switch (ExtraCode[0]) {
default: return true; // Unknown modifier.
+ case 'a': // This is an address. Currently only 'i' and 'r' are expected.
+ if (MO.isImm()) {
+ O << MO.getImm();
+ return false;
+ } else if (MO.isReg()) {
+ O << '(';
+ printOperand(MI, OpNo);
+ O << ')';
+ return false;
+ }
+ return true;
+
case 'c': // Don't print "$" before a global var name or constant.
if (MO.isImm())
O << MO.getImm();
OpenPOWER on IntegriCloud