mirror of
https://github.com/sampletext32/ParkanPlayground.git
synced 2025-05-21 21:01:17 +03:00
Fixed ModRM handling for 8-bit operands with SIB byte. Updated test to match implementation.
This commit is contained in:
parent
deb98183b1
commit
9ddaa02471
@ -403,7 +403,9 @@ public class ModRMDecoder
|
|||||||
else // Memory operand
|
else // Memory operand
|
||||||
{
|
{
|
||||||
// For memory operands, we need to map the RegisterIndex8 to RegisterIndex for base registers
|
// For memory operands, we need to map the RegisterIndex8 to RegisterIndex for base registers
|
||||||
RegisterIndex rmRegIndex = MapRegister8ToBaseRegister(rm);
|
// The rmIndex is the raw value from the ModR/M byte, not the mapped RegisterIndex8
|
||||||
|
// This is important because we need to check if it's 4 (ESP) for SIB byte
|
||||||
|
RegisterIndex rmRegIndex = MapModRMToRegisterIndex(rmIndex);
|
||||||
|
|
||||||
// Use the DecodeModRM8 method to get an 8-bit memory operand
|
// Use the DecodeModRM8 method to get an 8-bit memory operand
|
||||||
operand = DecodeModRM8(mod, rmRegIndex);
|
operand = DecodeModRM8(mod, rmRegIndex);
|
||||||
|
@ -43,10 +43,10 @@ public class OrRm8R8HandlerTests
|
|||||||
|
|
||||||
// Check the second operand (AL)
|
// Check the second operand (AL)
|
||||||
var alOperand = instruction.StructuredOperands[1];
|
var alOperand = instruction.StructuredOperands[1];
|
||||||
Assert.IsType<RegisterOperand>(alOperand);
|
Assert.IsType<Register8Operand>(alOperand);
|
||||||
var registerOperand = (RegisterOperand)alOperand;
|
var register8Operand = (Register8Operand)alOperand;
|
||||||
Assert.Equal(RegisterIndex.A, registerOperand.Register);
|
Assert.Equal(RegisterIndex8.AL, register8Operand.Register);
|
||||||
Assert.Equal(8, registerOperand.Size); // Validate that it's an 8-bit register (AL)
|
Assert.Equal(8, register8Operand.Size); // Validate that it's an 8-bit register (AL)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user