diff options
author | Devang Patel <dpatel@apple.com> | 2012-01-17 21:25:10 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2012-01-17 21:25:10 +0000 |
commit | a7143b6a2b3e51b575935c3d9ea577aa6e0e7bab (patch) | |
tree | c0cf4ca7af9ae9da6c3962ff24ceaa7919db680a | |
parent | 4ef685becf2bca9db12e31ace0e79ffd428a5e64 (diff) | |
download | bcm5719-llvm-a7143b6a2b3e51b575935c3d9ea577aa6e0e7bab.tar.gz bcm5719-llvm-a7143b6a2b3e51b575935c3d9ea577aa6e0e7bab.zip |
Intel syntax: Parse "BYTE PTR [RDX + RCX]"
llvm-svn: 148334
-rw-r--r-- | llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp | 4 | ||||
-rw-r--r-- | llvm/test/MC/X86/intel-syntax.s | 2 |
2 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp b/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp index b31993c0f20..75e286625b8 100644 --- a/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp +++ b/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp @@ -637,6 +637,10 @@ X86Operand *X86AsmParser::ParseIntelBracExpression(unsigned Size) { Disp = isPlus ? ValExpr : MCUnaryExpr::CreateMinus(ValExpr, getContext()); } else return ErrorOperand(PlusLoc, "unexpected token after +"); + } else if (getLexer().is(AsmToken::Identifier)) { + IndexReg = getIntelRegisterOperand(Tok.getString()); + if (IndexReg) + Parser.Lex(); } } diff --git a/llvm/test/MC/X86/intel-syntax.s b/llvm/test/MC/X86/intel-syntax.s index 2966dd7822d..42638f26854 100644 --- a/llvm/test/MC/X86/intel-syntax.s +++ b/llvm/test/MC/X86/intel-syntax.s @@ -23,6 +23,8 @@ _main: mov RCX, QWORD PTR [0] // CHECK: movl -24(%rsp,%rax,4), %eax mov EAX, DWORD PTR [RSP + 4*RAX - 24] +// CHECK: movb %dil, (%rdx,%rcx) + mov BYTE PTR [RDX + RCX], DIL // CHECK: callq _test call _test ret |