Intel Syntax: Parse mem operand with seg reg. QWORD PTR FS:[320]
llvm-svn: 149142
This commit is contained in:
parent
9620f466af
commit
63fe5697f4
|
@ -610,7 +610,6 @@ X86Operand *X86AsmParser::ParseIntelBracExpression(unsigned SegReg,
|
|||
// Parse BaseReg
|
||||
if (ParseRegister(BaseReg, Start, End)) {
|
||||
// Handle '[' 'symbol' ']'
|
||||
const MCExpr *Disp = MCConstantExpr::Create(0, getParser().getContext());
|
||||
if (getParser().ParseExpression(Disp, End)) return 0;
|
||||
if (getLexer().isNot(AsmToken::RBrac))
|
||||
return ErrorOperand(Start, "Expected ']' token!");
|
||||
|
@ -624,8 +623,11 @@ X86Operand *X86AsmParser::ParseIntelBracExpression(unsigned SegReg,
|
|||
if (getLexer().is(AsmToken::RBrac)) {
|
||||
// Handle '[' number ']'
|
||||
Parser.Lex();
|
||||
return X86Operand::CreateMem(MCConstantExpr::Create(Val, getContext()),
|
||||
Start, End, Size);
|
||||
const MCExpr *Disp = MCConstantExpr::Create(Val, getContext());
|
||||
if (SegReg)
|
||||
return X86Operand::CreateMem(SegReg, Disp, 0, 0, Scale,
|
||||
Start, End, Size);
|
||||
return X86Operand::CreateMem(Disp, Start, End, Size);
|
||||
} else if (getLexer().is(AsmToken::Star)) {
|
||||
// Handle '[' Scale*IndexReg ']'
|
||||
Parser.Lex();
|
||||
|
|
|
@ -61,4 +61,6 @@ _main:
|
|||
lea R8D, DWORD PTR [4*RDI]
|
||||
// CHECK: movl _fnan(,%ecx,4), %ecx
|
||||
mov ECX, DWORD PTR [4*ECX + _fnan]
|
||||
// CHECK: movq %fs:320, %rax
|
||||
mov RAX, QWORD PTR FS:[320]
|
||||
ret
|
||||
|
|
Loading…
Reference in New Issue