mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-08 21:32:39 +00:00
Register list operands are not allowed to contain only a single register. Alternate encodings are used in that case.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@143552 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5a83264fa2
commit
e31b42a6f5
@ -1111,7 +1111,11 @@ static DecodeStatus DecodeRegListOperand(llvm::MCInst &Inst, unsigned Val,
|
||||
}
|
||||
|
||||
// Empty register lists are not allowed.
|
||||
if (CountPopulation_32(Val) == 0) return MCDisassembler::Fail;
|
||||
uint32_t popcnt = CountPopulation_32(Val);
|
||||
if (popcnt == 0) return MCDisassembler::Fail;
|
||||
// and one-register lists are unpredictable.
|
||||
else if (popcnt == 1) Check(S, MCDisassembler::SoftFail);
|
||||
|
||||
for (unsigned i = 0; i < 16; ++i) {
|
||||
if (Val & (1 << i)) {
|
||||
if (!Check(S, DecodeGPRRegisterClass(Inst, i, Address, Decoder)))
|
||||
|
Loading…
x
Reference in New Issue
Block a user