mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
Added a missing error check for X86 assembly with mismatched base and index
registers not both being 64-bit or both being 32-bit registers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@152580 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a185362095
commit
84faf65912
@ -838,6 +838,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {
|
|||||||
// If we reached here, then we just ate the ( of the memory operand. Process
|
// If we reached here, then we just ate the ( of the memory operand. Process
|
||||||
// the rest of the memory operand.
|
// the rest of the memory operand.
|
||||||
unsigned BaseReg = 0, IndexReg = 0, Scale = 1;
|
unsigned BaseReg = 0, IndexReg = 0, Scale = 1;
|
||||||
|
SMLoc IndexLoc;
|
||||||
|
|
||||||
if (getLexer().is(AsmToken::Percent)) {
|
if (getLexer().is(AsmToken::Percent)) {
|
||||||
SMLoc StartLoc, EndLoc;
|
SMLoc StartLoc, EndLoc;
|
||||||
@ -851,6 +852,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {
|
|||||||
|
|
||||||
if (getLexer().is(AsmToken::Comma)) {
|
if (getLexer().is(AsmToken::Comma)) {
|
||||||
Parser.Lex(); // Eat the comma.
|
Parser.Lex(); // Eat the comma.
|
||||||
|
IndexLoc = Parser.getTok().getLoc();
|
||||||
|
|
||||||
// Following the comma we should have either an index register, or a scale
|
// Following the comma we should have either an index register, or a scale
|
||||||
// value. We don't support the later form, but we want to parse it
|
// value. We don't support the later form, but we want to parse it
|
||||||
@ -912,6 +914,23 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {
|
|||||||
SMLoc MemEnd = Parser.getTok().getLoc();
|
SMLoc MemEnd = Parser.getTok().getLoc();
|
||||||
Parser.Lex(); // Eat the ')'.
|
Parser.Lex(); // Eat the ')'.
|
||||||
|
|
||||||
|
// If we have both a base register and an index register make sure they are
|
||||||
|
// both 64-bit or 32-bit registers.
|
||||||
|
if (BaseReg != 0 && IndexReg != 0) {
|
||||||
|
if (X86MCRegisterClasses[X86::GR64RegClassID].contains(BaseReg) &&
|
||||||
|
!X86MCRegisterClasses[X86::GR64RegClassID].contains(IndexReg) &&
|
||||||
|
IndexReg != X86::RIZ) {
|
||||||
|
Error(IndexLoc, "index register is 32-bit, but base register is 64-bit");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (X86MCRegisterClasses[X86::GR32RegClassID].contains(BaseReg) &&
|
||||||
|
!X86MCRegisterClasses[X86::GR32RegClassID].contains(IndexReg) &&
|
||||||
|
IndexReg != X86::EIZ){
|
||||||
|
Error(IndexLoc, "index register is 64-bit, but base register is 32-bit");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return X86Operand::CreateMem(SegReg, Disp, BaseReg, IndexReg, Scale,
|
return X86Operand::CreateMem(SegReg, Disp, BaseReg, IndexReg, Scale,
|
||||||
MemStart, MemEnd);
|
MemStart, MemEnd);
|
||||||
}
|
}
|
||||||
|
@ -24,3 +24,7 @@ sysexitq
|
|||||||
// rdar://10710167
|
// rdar://10710167
|
||||||
// 64: error: expected scale expression
|
// 64: error: expected scale expression
|
||||||
lea (%rsp, %rbp, $4), %rax
|
lea (%rsp, %rbp, $4), %rax
|
||||||
|
|
||||||
|
// rdar://10423777
|
||||||
|
// 64: error: index register is 32-bit, but base register is 64-bit
|
||||||
|
movq (%rsi,%ecx),%xmm0
|
||||||
|
Loading…
Reference in New Issue
Block a user