mirror of
https://github.com/sampletext32/ParkanPlayground.git
synced 2025-06-19 16:08:02 +03:00
Added support for INC r32 instructions (0x40-0x47) with tests
This commit is contained in:
49
X86Disassembler/X86/Handlers/Inc/IncRegHandler.cs
Normal file
49
X86Disassembler/X86/Handlers/Inc/IncRegHandler.cs
Normal file
@ -0,0 +1,49 @@
|
||||
namespace X86Disassembler.X86.Handlers.Inc;
|
||||
|
||||
/// <summary>
|
||||
/// Handler for INC r32 instructions (0x40-0x47)
|
||||
/// </summary>
|
||||
public class IncRegHandler : InstructionHandler
|
||||
{
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the IncRegHandler class
|
||||
/// </summary>
|
||||
/// <param name="codeBuffer">The buffer containing the code to decode</param>
|
||||
/// <param name="decoder">The instruction decoder that owns this handler</param>
|
||||
/// <param name="length">The length of the buffer</param>
|
||||
public IncRegHandler(byte[] codeBuffer, InstructionDecoder decoder, int length)
|
||||
: base(codeBuffer, decoder, length)
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Checks if this handler can decode the given opcode
|
||||
/// </summary>
|
||||
/// <param name="opcode">The opcode to check</param>
|
||||
/// <returns>True if this handler can decode the opcode</returns>
|
||||
public override bool CanHandle(byte opcode)
|
||||
{
|
||||
// INC EAX = 0x40, INC ECX = 0x41, ..., INC EDI = 0x47
|
||||
return opcode >= 0x40 && opcode <= 0x47;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Decodes an INC r32 instruction
|
||||
/// </summary>
|
||||
/// <param name="opcode">The opcode of the instruction</param>
|
||||
/// <param name="instruction">The instruction object to populate</param>
|
||||
/// <returns>True if the instruction was successfully decoded</returns>
|
||||
public override bool Decode(byte opcode, Instruction instruction)
|
||||
{
|
||||
// Calculate the register index (0 for EAX, 1 for ECX, etc.)
|
||||
byte reg = (byte)(opcode - 0x40);
|
||||
|
||||
// Set the mnemonic
|
||||
instruction.Mnemonic = "inc";
|
||||
|
||||
// Set the operand (register name)
|
||||
instruction.Operands = GetRegister32(reg);
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
@ -5,7 +5,7 @@ using X86Disassembler.X86.Handlers.Call;
|
||||
using X86Disassembler.X86.Handlers.Cmp;
|
||||
using X86Disassembler.X86.Handlers.Dec;
|
||||
using X86Disassembler.X86.Handlers.FloatingPoint;
|
||||
using X86Disassembler.X86.Handlers.Group5;
|
||||
using X86Disassembler.X86.Handlers.Inc;
|
||||
using X86Disassembler.X86.Handlers.Jump;
|
||||
using X86Disassembler.X86.Handlers.Lea;
|
||||
using X86Disassembler.X86.Handlers.Mov;
|
||||
@ -83,12 +83,12 @@ public class InstructionHandlerFactory
|
||||
// Register Dec handlers
|
||||
RegisterDecHandlers();
|
||||
|
||||
// Register Inc handlers
|
||||
RegisterIncHandlers();
|
||||
|
||||
// Register Add handlers
|
||||
RegisterAddHandlers();
|
||||
|
||||
// Register Group5 handlers
|
||||
RegisterGroup5Handlers();
|
||||
|
||||
// Register Data Transfer handlers
|
||||
RegisterDataTransferHandlers();
|
||||
|
||||
@ -172,6 +172,7 @@ public class InstructionHandlerFactory
|
||||
{
|
||||
// Add Call handlers
|
||||
_handlers.Add(new CallRel32Handler(_codeBuffer, _decoder, _length));
|
||||
_handlers.Add(new CallRm32Handler(_codeBuffer, _decoder, _length));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -259,25 +260,25 @@ public class InstructionHandlerFactory
|
||||
_handlers.Add(new DecRegHandler(_codeBuffer, _decoder, _length));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Registers all Inc instruction handlers
|
||||
/// </summary>
|
||||
private void RegisterIncHandlers()
|
||||
{
|
||||
// Add Inc handlers
|
||||
_handlers.Add(new IncRegHandler(_codeBuffer, _decoder, _length));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Registers all Add instruction handlers
|
||||
/// </summary>
|
||||
private void RegisterAddHandlers()
|
||||
{
|
||||
// Add Add handlers
|
||||
// Add ADD handlers
|
||||
_handlers.Add(new AddR32Rm32Handler(_codeBuffer, _decoder, _length));
|
||||
_handlers.Add(new AddRm32R32Handler(_codeBuffer, _decoder, _length));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Registers all Group5 instruction handlers
|
||||
/// </summary>
|
||||
private void RegisterGroup5Handlers()
|
||||
{
|
||||
// Add Group5 handlers
|
||||
_handlers.Add(new CallRm32Handler(_codeBuffer, _decoder, _length));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Registers all Data Transfer instruction handlers
|
||||
/// </summary>
|
||||
|
@ -72,6 +72,16 @@ public static class OpcodeMap
|
||||
OneByteOpcodes[0x4E] = "dec"; // DEC ESI
|
||||
OneByteOpcodes[0x4F] = "dec"; // DEC EDI
|
||||
|
||||
// INC instructions
|
||||
OneByteOpcodes[0x40] = "inc"; // INC EAX
|
||||
OneByteOpcodes[0x41] = "inc"; // INC ECX
|
||||
OneByteOpcodes[0x42] = "inc"; // INC EDX
|
||||
OneByteOpcodes[0x43] = "inc"; // INC EBX
|
||||
OneByteOpcodes[0x44] = "inc"; // INC ESP
|
||||
OneByteOpcodes[0x45] = "inc"; // INC EBP
|
||||
OneByteOpcodes[0x46] = "inc"; // INC ESI
|
||||
OneByteOpcodes[0x47] = "inc"; // INC EDI
|
||||
|
||||
// ADD instructions
|
||||
OneByteOpcodes[0x00] = "add"; // ADD r/m8, r8
|
||||
OneByteOpcodes[0x01] = "add"; // ADD r/m32, r32
|
||||
|
Reference in New Issue
Block a user