2025-04-13 04:13:44 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Adc;
|
2025-04-13 00:45:53 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Add;
|
2025-04-13 04:07:37 +03:00
|
|
|
using X86Disassembler.X86.Handlers.And;
|
2025-04-17 01:33:58 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Bit;
|
2025-04-12 22:18:46 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Call;
|
2025-04-13 00:38:38 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Cmp;
|
2025-04-13 00:41:36 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Dec;
|
2025-04-16 20:54:08 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Div;
|
2025-04-12 23:24:42 +03:00
|
|
|
using X86Disassembler.X86.Handlers.FloatingPoint;
|
2025-04-16 20:54:08 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Idiv;
|
|
|
|
using X86Disassembler.X86.Handlers.Imul;
|
2025-04-13 00:55:20 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Inc;
|
2025-04-12 21:34:16 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Jump;
|
2025-04-13 00:34:03 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Lea;
|
2025-04-12 22:34:02 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Mov;
|
2025-04-16 20:43:06 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Mul;
|
|
|
|
using X86Disassembler.X86.Handlers.Neg;
|
2025-04-13 18:00:26 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Nop;
|
2025-04-16 20:54:08 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Not;
|
2025-04-13 00:23:11 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Or;
|
2025-04-12 22:34:02 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Pop;
|
|
|
|
using X86Disassembler.X86.Handlers.Push;
|
2025-04-12 22:18:46 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Ret;
|
2025-04-13 04:13:44 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Sbb;
|
2025-04-13 02:16:12 +03:00
|
|
|
using X86Disassembler.X86.Handlers.String;
|
2025-04-13 04:13:44 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Sub;
|
2025-04-12 21:27:17 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Test;
|
2025-04-13 00:34:03 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Xchg;
|
2025-04-13 00:38:38 +03:00
|
|
|
using X86Disassembler.X86.Handlers.Xor;
|
2025-04-12 21:27:17 +03:00
|
|
|
|
2025-04-12 19:57:42 +03:00
|
|
|
namespace X86Disassembler.X86.Handlers;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Factory for creating instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
public class InstructionHandlerFactory
|
|
|
|
{
|
2025-04-12 23:40:48 +03:00
|
|
|
private readonly List<IInstructionHandler> _handlers = [];
|
2025-04-12 19:57:42 +03:00
|
|
|
private readonly byte[] _codeBuffer;
|
|
|
|
private readonly InstructionDecoder _decoder;
|
|
|
|
private readonly int _length;
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 19:57:42 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Initializes a new instance of the InstructionHandlerFactory class
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="codeBuffer">The buffer containing the code to decode</param>
|
|
|
|
/// <param name="decoder">The instruction decoder that owns this factory</param>
|
|
|
|
/// <param name="length">The length of the buffer</param>
|
|
|
|
public InstructionHandlerFactory(byte[] codeBuffer, InstructionDecoder decoder, int length)
|
|
|
|
{
|
|
|
|
_codeBuffer = codeBuffer;
|
|
|
|
_decoder = decoder;
|
|
|
|
_length = length;
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 02:16:12 +03:00
|
|
|
RegisterAllHandlers();
|
2025-04-12 19:57:42 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 19:57:42 +03:00
|
|
|
/// <summary>
|
2025-04-13 01:08:49 +03:00
|
|
|
/// Registers all handlers
|
2025-04-12 19:57:42 +03:00
|
|
|
/// </summary>
|
2025-04-13 02:16:12 +03:00
|
|
|
private void RegisterAllHandlers()
|
2025-04-12 19:57:42 +03:00
|
|
|
{
|
|
|
|
// Register specific instruction handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new Int3Handler(_decoder));
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 02:51:51 +03:00
|
|
|
// Register handlers in order of priority (most specific first)
|
2025-04-17 01:33:58 +03:00
|
|
|
RegisterSbbHandlers(); // SBB instructions
|
|
|
|
RegisterAdcHandlers(); // ADC instructions
|
2025-04-16 21:24:09 +03:00
|
|
|
RegisterAddHandlers(); // ADD instructions
|
|
|
|
RegisterAndHandlers(); // AND instructions
|
|
|
|
RegisterOrHandlers(); // OR instructions
|
|
|
|
RegisterXorHandlers(); // XOR instructions
|
|
|
|
RegisterCmpHandlers(); // CMP instructions
|
|
|
|
RegisterTestHandlers(); // TEST instructions
|
|
|
|
|
|
|
|
// Register arithmetic unary instructions
|
|
|
|
RegisterNotHandlers(); // NOT instructions
|
|
|
|
RegisterNegHandlers(); // NEG instructions
|
|
|
|
RegisterMulHandlers(); // MUL instructions
|
|
|
|
RegisterImulHandlers(); // IMUL instructions
|
|
|
|
RegisterDivHandlers(); // DIV instructions
|
|
|
|
RegisterIdivHandlers(); // IDIV instructions
|
2025-04-13 02:16:12 +03:00
|
|
|
RegisterDataTransferHandlers();
|
|
|
|
RegisterJumpHandlers();
|
|
|
|
RegisterCallHandlers();
|
|
|
|
RegisterReturnHandlers();
|
2025-04-13 00:41:36 +03:00
|
|
|
RegisterDecHandlers();
|
2025-04-13 02:51:51 +03:00
|
|
|
RegisterIncHandlers(); // INC/DEC handlers after Group 1 handlers
|
2025-04-13 02:16:12 +03:00
|
|
|
RegisterPushHandlers();
|
|
|
|
RegisterPopHandlers();
|
|
|
|
RegisterLeaHandlers();
|
2025-04-12 23:24:42 +03:00
|
|
|
RegisterFloatingPointHandlers();
|
2025-04-13 02:16:12 +03:00
|
|
|
RegisterStringHandlers();
|
|
|
|
RegisterMovHandlers();
|
2025-04-13 14:25:27 +03:00
|
|
|
RegisterSubHandlers(); // Register SUB handlers
|
2025-04-13 18:00:26 +03:00
|
|
|
RegisterNopHandlers(); // Register NOP handlers
|
2025-04-17 01:33:58 +03:00
|
|
|
RegisterBitHandlers(); // Register bit manipulation handlers
|
2025-04-12 19:57:42 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 20:13:01 +03:00
|
|
|
/// <summary>
|
2025-04-17 01:33:58 +03:00
|
|
|
/// Registers all SBB instruction handlers
|
2025-04-12 20:13:01 +03:00
|
|
|
/// </summary>
|
2025-04-17 01:33:58 +03:00
|
|
|
private void RegisterSbbHandlers()
|
2025-04-12 23:46:05 +03:00
|
|
|
{
|
2025-04-17 01:33:58 +03:00
|
|
|
// SBB immediate handlers
|
|
|
|
_handlers.Add(new SbbImmFromRm32Handler(_decoder)); // SBB r/m32, imm32 (opcode 81 /3)
|
|
|
|
_handlers.Add(new SbbImmFromRm32SignExtendedHandler(_decoder)); // SBB r/m32, imm8 (opcode 83 /3)
|
2025-04-12 23:46:05 +03:00
|
|
|
}
|
2025-04-17 01:33:58 +03:00
|
|
|
|
2025-04-12 23:46:05 +03:00
|
|
|
/// <summary>
|
2025-04-17 01:33:58 +03:00
|
|
|
/// Registers all ADC instruction handlers
|
2025-04-12 23:46:05 +03:00
|
|
|
/// </summary>
|
2025-04-17 01:33:58 +03:00
|
|
|
private void RegisterAdcHandlers()
|
2025-04-12 20:13:01 +03:00
|
|
|
{
|
2025-04-17 01:33:58 +03:00
|
|
|
// ADC immediate handlers
|
|
|
|
_handlers.Add(new AdcImmToRm8Handler(_decoder)); // ADC r/m8, imm8 (opcode 80 /2)
|
|
|
|
_handlers.Add(new AdcImmToRm16Handler(_decoder)); // ADC r/m16, imm16 (opcode 81 /2 with 0x66 prefix)
|
|
|
|
_handlers.Add(new AdcImmToRm16SignExtendedHandler(_decoder)); // ADC r/m16, imm8 (opcode 83 /2 with 0x66 prefix)
|
2025-04-16 21:24:09 +03:00
|
|
|
_handlers.Add(new AdcImmToRm32Handler(_decoder)); // ADC r/m32, imm32 (opcode 81 /2)
|
|
|
|
_handlers.Add(new AdcImmToRm32SignExtendedHandler(_decoder)); // ADC r/m32, imm8 (opcode 83 /2)
|
2025-04-17 01:33:58 +03:00
|
|
|
_handlers.Add(new AdcAlImmHandler(_decoder)); // ADC AL, imm8 (opcode 14)
|
|
|
|
_handlers.Add(new AdcAccumulatorImmHandler(_decoder)); // ADC AX/EAX, imm16/32 (opcode 15)
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-17 01:33:58 +03:00
|
|
|
// Register-to-register ADC handlers (8-bit)
|
|
|
|
_handlers.Add(new AdcR8Rm8Handler(_decoder)); // ADC r8, r/m8 (opcode 12)
|
|
|
|
_handlers.Add(new AdcRm8R8Handler(_decoder)); // ADC r/m8, r8 (opcode 10)
|
|
|
|
|
|
|
|
// Register-to-register ADC handlers (16-bit)
|
|
|
|
_handlers.Add(new AdcR16Rm16Handler(_decoder)); // ADC r16, r/m16 (opcode 13 with 0x66 prefix)
|
|
|
|
_handlers.Add(new AdcRm16R16Handler(_decoder)); // ADC r/m16, r16 (opcode 11 with 0x66 prefix)
|
|
|
|
|
|
|
|
// Register-to-register ADC handlers (32-bit)
|
|
|
|
_handlers.Add(new AdcR32Rm32Handler(_decoder)); // ADC r32, r/m32 (opcode 13)
|
|
|
|
_handlers.Add(new AdcRm32R32Handler(_decoder)); // ADC r/m32, r32 (opcode 11)
|
2025-04-12 20:13:01 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 19:57:42 +03:00
|
|
|
/// <summary>
|
2025-04-12 22:34:02 +03:00
|
|
|
/// Registers all Return instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterReturnHandlers()
|
|
|
|
{
|
|
|
|
// Add Return handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new RetHandler(_decoder));
|
|
|
|
_handlers.Add(new RetImmHandler(_decoder));
|
2025-04-12 22:34:02 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Call instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterCallHandlers()
|
|
|
|
{
|
|
|
|
// Add Call handlers
|
2025-04-16 21:44:02 +03:00
|
|
|
_handlers.Add(new CallRel32Handler(_decoder)); // CALL rel32 (opcode E8)
|
|
|
|
_handlers.Add(new CallRm32Handler(_decoder)); // CALL r/m32 (opcode FF /2)
|
|
|
|
_handlers.Add(new CallFarPtrHandler(_decoder)); // CALL m16:32 (opcode FF /3) - Far call
|
2025-04-12 22:34:02 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Jump instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterJumpHandlers()
|
|
|
|
{
|
2025-04-16 19:50:00 +03:00
|
|
|
// JMP handlers for relative jumps
|
|
|
|
_handlers.Add(new JmpRel32Handler(_decoder)); // JMP rel32 (opcode E9)
|
|
|
|
_handlers.Add(new JmpRel8Handler(_decoder)); // JMP rel8 (opcode EB)
|
|
|
|
|
|
|
|
// JMP handler for register/memory operands
|
|
|
|
_handlers.Add(new JmpRm32Handler(_decoder)); // JMP r/m32 (opcode FF /4)
|
|
|
|
|
|
|
|
// Conditional jump handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new JgeRel8Handler(_decoder));
|
|
|
|
_handlers.Add(new ConditionalJumpHandler(_decoder));
|
|
|
|
_handlers.Add(new TwoByteConditionalJumpHandler(_decoder));
|
2025-04-12 22:34:02 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Test instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterTestHandlers()
|
|
|
|
{
|
|
|
|
// TEST handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new TestImmWithRm32Handler(_decoder));
|
|
|
|
_handlers.Add(new TestImmWithRm8Handler(_decoder));
|
|
|
|
_handlers.Add(new TestRegMem8Handler(_decoder));
|
|
|
|
_handlers.Add(new TestRegMemHandler(_decoder));
|
|
|
|
_handlers.Add(new TestAlImmHandler(_decoder));
|
|
|
|
_handlers.Add(new TestEaxImmHandler(_decoder));
|
2025-04-12 22:34:02 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Xor instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterXorHandlers()
|
|
|
|
{
|
2025-04-13 19:28:56 +03:00
|
|
|
// 16-bit handlers
|
2025-04-16 21:25:46 +03:00
|
|
|
_handlers.Add(new XorRm16R16Handler(_decoder)); // XOR r/m16, r16 (opcode 31)
|
|
|
|
_handlers.Add(new XorR16Rm16Handler(_decoder)); // XOR r16, r/m16 (opcode 33)
|
|
|
|
_handlers.Add(new XorImmWithRm16Handler(_decoder)); // XOR r/m16, imm16 (opcode 81 /6)
|
|
|
|
_handlers.Add(new XorImmWithRm16SignExtendedHandler(_decoder)); // XOR r/m16, imm8 (opcode 83 /6)
|
2025-04-13 19:28:56 +03:00
|
|
|
|
2025-04-13 20:20:51 +03:00
|
|
|
// 32-bit handlers
|
2025-04-16 21:25:46 +03:00
|
|
|
_handlers.Add(new XorMemRegHandler(_decoder)); // XOR r/m32, r32 (opcode 31)
|
|
|
|
_handlers.Add(new XorRegMemHandler(_decoder)); // XOR r32, r/m32 (opcode 33)
|
|
|
|
_handlers.Add(new XorImmWithRm32Handler(_decoder)); // XOR r/m32, imm32 (opcode 81 /6)
|
|
|
|
_handlers.Add(new XorImmWithRm32SignExtendedHandler(_decoder)); // XOR r/m32, imm8 (opcode 83 /6)
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 19:28:56 +03:00
|
|
|
// 8-bit handlers
|
2025-04-16 21:25:46 +03:00
|
|
|
_handlers.Add(new XorRm8R8Handler(_decoder)); // XOR r/m8, r8 (opcode 30)
|
|
|
|
_handlers.Add(new XorR8Rm8Handler(_decoder)); // XOR r8, r/m8 (opcode 32)
|
|
|
|
_handlers.Add(new XorAlImmHandler(_decoder)); // XOR AL, imm8 (opcode 34)
|
|
|
|
_handlers.Add(new XorImmWithRm8Handler(_decoder)); // XOR r/m8, imm8 (opcode 80 /6)
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 19:55:13 +03:00
|
|
|
// special treatment with xor-ing eax
|
|
|
|
// precise handlers go first
|
2025-04-16 21:25:46 +03:00
|
|
|
_handlers.Add(new XorAxImm16Handler(_decoder)); // XOR AX, imm16 (opcode 35)
|
|
|
|
_handlers.Add(new XorEaxImmHandler(_decoder)); // XOR EAX, imm32 (opcode 35)
|
2025-04-12 22:34:02 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 00:23:11 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Or instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterOrHandlers()
|
|
|
|
{
|
2025-04-16 21:24:09 +03:00
|
|
|
// Add OR immediate handlers
|
|
|
|
_handlers.Add(new OrImmToRm8Handler(_decoder)); // OR r/m8, imm8 (opcode 80 /1)
|
|
|
|
_handlers.Add(new OrImmToRm32Handler(_decoder)); // OR r/m32, imm32 (opcode 81 /1)
|
|
|
|
_handlers.Add(new OrImmToRm32SignExtendedHandler(_decoder)); // OR r/m32, imm8 (opcode 83 /1)
|
|
|
|
|
|
|
|
// Add OR register handlers
|
|
|
|
_handlers.Add(new OrR8Rm8Handler(_decoder)); // OR r8, r/m8 (opcode 0A)
|
|
|
|
_handlers.Add(new OrRm8R8Handler(_decoder)); // OR r/m8, r8 (opcode 08)
|
|
|
|
_handlers.Add(new OrR32Rm32Handler(_decoder)); // OR r32, r/m32 (opcode 0B)
|
|
|
|
_handlers.Add(new OrRm32R32Handler(_decoder)); // OR r/m32, r32 (opcode 09)
|
|
|
|
|
|
|
|
// Add OR immediate with accumulator handlers
|
|
|
|
_handlers.Add(new OrAlImmHandler(_decoder)); // OR AL, imm8 (opcode 0C)
|
|
|
|
_handlers.Add(new OrEaxImmHandler(_decoder)); // OR EAX, imm32 (opcode 0D)
|
2025-04-13 00:23:11 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 00:34:03 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Lea instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterLeaHandlers()
|
|
|
|
{
|
|
|
|
// Add Lea handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new LeaR32MHandler(_decoder));
|
2025-04-13 00:34:03 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 00:38:38 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Cmp instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterCmpHandlers()
|
|
|
|
{
|
2025-04-16 19:43:03 +03:00
|
|
|
// Add Cmp handlers for 32-bit operands
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new CmpR32Rm32Handler(_decoder));
|
|
|
|
_handlers.Add(new CmpRm32R32Handler(_decoder));
|
2025-04-16 19:43:03 +03:00
|
|
|
|
|
|
|
// Add Cmp handlers for 8-bit operands
|
|
|
|
_handlers.Add(new CmpRm8R8Handler(_decoder)); // CMP r/m8, r8 (opcode 38)
|
|
|
|
_handlers.Add(new CmpR8Rm8Handler(_decoder)); // CMP r8, r/m8 (opcode 3A)
|
|
|
|
|
|
|
|
// Add Cmp handlers for immediate operands
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new CmpImmWithRm8Handler(_decoder));
|
2025-04-16 19:43:03 +03:00
|
|
|
_handlers.Add(new CmpAlImmHandler(_decoder)); // CMP AL, imm8 (opcode 3C)
|
|
|
|
_handlers.Add(new CmpEaxImmHandler(_decoder)); // CMP EAX, imm32 (opcode 3D)
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 01:30:42 +03:00
|
|
|
// Add CMP immediate handlers from ArithmeticImmediate namespace
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new CmpImmWithRm32Handler(_decoder));
|
|
|
|
_handlers.Add(new CmpImmWithRm32SignExtendedHandler(_decoder));
|
2025-04-13 00:38:38 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 00:41:36 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Dec instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterDecHandlers()
|
|
|
|
{
|
|
|
|
// Add Dec handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new DecRegHandler(_decoder));
|
2025-04-13 00:41:36 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 00:45:53 +03:00
|
|
|
/// <summary>
|
2025-04-13 00:55:20 +03:00
|
|
|
/// Registers all Inc instruction handlers
|
2025-04-13 00:45:53 +03:00
|
|
|
/// </summary>
|
2025-04-13 00:55:20 +03:00
|
|
|
private void RegisterIncHandlers()
|
2025-04-13 00:45:53 +03:00
|
|
|
{
|
2025-04-13 00:55:20 +03:00
|
|
|
// Add Inc handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new IncRegHandler(_decoder));
|
2025-04-13 00:45:53 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 00:45:53 +03:00
|
|
|
/// <summary>
|
2025-04-13 00:55:20 +03:00
|
|
|
/// Registers all Add instruction handlers
|
2025-04-13 00:45:53 +03:00
|
|
|
/// </summary>
|
2025-04-13 00:55:20 +03:00
|
|
|
private void RegisterAddHandlers()
|
2025-04-13 00:45:53 +03:00
|
|
|
{
|
2025-04-17 01:43:45 +03:00
|
|
|
// Add ADD register-to-register handlers (32-bit)
|
|
|
|
_handlers.Add(new AddR32Rm32Handler(_decoder)); // ADD r32, r/m32 (opcode 03)
|
|
|
|
_handlers.Add(new AddRm32R32Handler(_decoder)); // ADD r/m32, r32 (opcode 01)
|
|
|
|
_handlers.Add(new AddEaxImmHandler(_decoder)); // ADD EAX, imm32 (opcode 05)
|
2025-04-15 23:54:37 +03:00
|
|
|
|
2025-04-17 18:39:34 +03:00
|
|
|
// Add ADD register-to-register handlers (16-bit)
|
|
|
|
_handlers.Add(new AddR16Rm16Handler(_decoder)); // ADD r16, r/m16 (opcode 03 with 0x66 prefix)
|
|
|
|
_handlers.Add(new AddRm16R16Handler(_decoder)); // ADD r/m16, r16 (opcode 01 with 0x66 prefix)
|
|
|
|
|
2025-04-17 01:43:45 +03:00
|
|
|
// Add ADD register-to-register handlers (8-bit)
|
|
|
|
_handlers.Add(new AddRm8R8Handler(_decoder)); // ADD r/m8, r8 (opcode 00)
|
|
|
|
_handlers.Add(new AddR8Rm8Handler(_decoder)); // ADD r8, r/m8 (opcode 02)
|
|
|
|
_handlers.Add(new AddAlImmHandler(_decoder)); // ADD AL, imm8 (opcode 04)
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-17 01:43:45 +03:00
|
|
|
// Add ADD immediate handlers
|
|
|
|
_handlers.Add(new AddImmToRm8Handler(_decoder)); // ADD r/m8, imm8 (opcode 80 /0)
|
|
|
|
_handlers.Add(new AddImmToRm16Handler(_decoder)); // ADD r/m16, imm16 (opcode 81 /0 with 0x66 prefix)
|
|
|
|
_handlers.Add(new AddImmToRm16SignExtendedHandler(_decoder)); // ADD r/m16, imm8 (opcode 83 /0 with 0x66 prefix)
|
|
|
|
_handlers.Add(new AddImmToRm32Handler(_decoder)); // ADD r/m32, imm32 (opcode 81 /0)
|
|
|
|
_handlers.Add(new AddImmToRm32SignExtendedHandler(_decoder)); // ADD r/m32, imm8 (opcode 83 /0)
|
2025-04-13 00:45:53 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Data Transfer instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterDataTransferHandlers()
|
|
|
|
{
|
|
|
|
// Add MOV handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new MovRegMemHandler(_decoder));
|
|
|
|
_handlers.Add(new MovMemRegHandler(_decoder));
|
|
|
|
_handlers.Add(new MovRegImm32Handler(_decoder));
|
|
|
|
_handlers.Add(new MovRegImm8Handler(_decoder));
|
|
|
|
_handlers.Add(new MovEaxMoffsHandler(_decoder));
|
|
|
|
_handlers.Add(new MovMoffsEaxHandler(_decoder));
|
|
|
|
_handlers.Add(new MovRm32Imm32Handler(_decoder));
|
|
|
|
_handlers.Add(new MovRm8Imm8Handler(_decoder));
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
// Add XCHG handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new XchgEaxRegHandler(_decoder));
|
2025-04-12 22:34:02 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-12 23:24:42 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all Floating Point instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterFloatingPointHandlers()
|
|
|
|
{
|
|
|
|
// Add Floating Point handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new FnstswHandler(_decoder));
|
|
|
|
_handlers.Add(new Float32OperationHandler(_decoder));
|
|
|
|
_handlers.Add(new LoadStoreControlHandler(_decoder));
|
|
|
|
_handlers.Add(new Int32OperationHandler(_decoder));
|
|
|
|
_handlers.Add(new LoadStoreInt32Handler(_decoder));
|
|
|
|
_handlers.Add(new Float64OperationHandler(_decoder));
|
|
|
|
_handlers.Add(new LoadStoreFloat64Handler(_decoder));
|
|
|
|
_handlers.Add(new Int16OperationHandler(_decoder));
|
|
|
|
_handlers.Add(new LoadStoreInt16Handler(_decoder));
|
2025-04-12 23:24:42 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 02:16:12 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all String instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterStringHandlers()
|
|
|
|
{
|
2025-04-13 02:23:27 +03:00
|
|
|
// Add String instruction handler that handles both regular and REP/REPNE prefixed string instructions
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new StringInstructionHandler(_decoder));
|
2025-04-13 02:16:12 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 02:16:12 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all MOV instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterMovHandlers()
|
|
|
|
{
|
2025-04-16 21:24:09 +03:00
|
|
|
// Add MOV register/memory handlers
|
|
|
|
_handlers.Add(new MovRegMemHandler(_decoder)); // MOV r32, r/m32 (opcode 8B)
|
|
|
|
_handlers.Add(new MovMemRegHandler(_decoder)); // MOV r/m32, r32 (opcode 89)
|
|
|
|
|
|
|
|
// Add MOV immediate handlers
|
|
|
|
_handlers.Add(new MovRegImm32Handler(_decoder)); // MOV r32, imm32 (opcode B8+r)
|
|
|
|
_handlers.Add(new MovRegImm8Handler(_decoder)); // MOV r8, imm8 (opcode B0+r)
|
|
|
|
_handlers.Add(new MovRm32Imm32Handler(_decoder)); // MOV r/m32, imm32 (opcode C7 /0)
|
|
|
|
_handlers.Add(new MovRm8Imm8Handler(_decoder)); // MOV r/m8, imm8 (opcode C6 /0)
|
|
|
|
|
|
|
|
// Add MOV memory offset handlers
|
|
|
|
_handlers.Add(new MovEaxMoffsHandler(_decoder)); // MOV EAX, moffs32 (opcode A1)
|
|
|
|
_handlers.Add(new MovMoffsEaxHandler(_decoder)); // MOV moffs32, EAX (opcode A3)
|
2025-04-13 02:16:12 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 02:16:12 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all PUSH instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterPushHandlers()
|
|
|
|
{
|
2025-04-16 21:24:09 +03:00
|
|
|
// Add PUSH register handlers
|
|
|
|
_handlers.Add(new PushRegHandler(_decoder)); // PUSH r32 (opcode 50+r)
|
|
|
|
_handlers.Add(new PushRm32Handler(_decoder)); // PUSH r/m32 (opcode FF /6)
|
|
|
|
|
|
|
|
// Add PUSH immediate handlers
|
2025-04-16 21:46:08 +03:00
|
|
|
// Note: Order matters! PushImm16Handler must be registered before PushImm32Handler
|
|
|
|
// since both check for opcode 68h but PushImm16Handler also checks for operand size prefix
|
2025-04-16 21:44:02 +03:00
|
|
|
_handlers.Add(new PushImm16Handler(_decoder)); // PUSH imm16 with operand size prefix (0x66 0x68)
|
2025-04-16 21:46:08 +03:00
|
|
|
_handlers.Add(new PushImm32Handler(_decoder)); // PUSH imm32 (opcode 68)
|
2025-04-16 21:24:09 +03:00
|
|
|
_handlers.Add(new PushImm8Handler(_decoder)); // PUSH imm8 (opcode 6A)
|
2025-04-13 02:16:12 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 02:16:12 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all POP instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterPopHandlers()
|
|
|
|
{
|
2025-04-16 21:24:09 +03:00
|
|
|
// Add POP register handlers
|
|
|
|
_handlers.Add(new PopRegHandler(_decoder)); // POP r32 (opcode 58+r)
|
2025-04-17 01:33:58 +03:00
|
|
|
_handlers.Add(new PopRm32Handler(_decoder)); // POP r/m32 (opcode 8F /0)
|
2025-04-13 02:16:12 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 04:07:37 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all And instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterAndHandlers()
|
|
|
|
{
|
2025-04-16 21:24:09 +03:00
|
|
|
// Add AND immediate handlers
|
|
|
|
_handlers.Add(new AndImmToRm8Handler(_decoder)); // AND r/m8, imm8 (opcode 80 /4)
|
|
|
|
_handlers.Add(new AndImmToRm32Handler(_decoder)); // AND r/m32, imm32 (opcode 81 /4)
|
|
|
|
_handlers.Add(new AndImmToRm32SignExtendedHandler(_decoder)); // AND r/m32, imm8 (opcode 83 /4)
|
|
|
|
|
|
|
|
// Add AND register handlers
|
|
|
|
_handlers.Add(new AndR8Rm8Handler(_decoder)); // AND r8, r/m8 (opcode 22)
|
|
|
|
_handlers.Add(new AndRm8R8Handler(_decoder)); // AND r/m8, r8 (opcode 20)
|
|
|
|
_handlers.Add(new AndR32Rm32Handler(_decoder)); // AND r32, r/m32 (opcode 23)
|
|
|
|
_handlers.Add(new AndMemRegHandler(_decoder)); // AND r/m32, r32 (opcode 21)
|
|
|
|
|
|
|
|
// Add AND immediate with accumulator handlers
|
|
|
|
_handlers.Add(new AndAlImmHandler(_decoder)); // AND AL, imm8 (opcode 24)
|
|
|
|
_handlers.Add(new AndEaxImmHandler(_decoder)); // AND EAX, imm32 (opcode 25)
|
2025-04-13 04:07:37 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 14:25:27 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all SUB instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterSubHandlers()
|
|
|
|
{
|
2025-04-13 17:51:54 +03:00
|
|
|
// Register SUB handlers
|
2025-04-17 01:33:58 +03:00
|
|
|
|
|
|
|
// 16-bit handlers with operand size prefix (must come first)
|
|
|
|
_handlers.Add(new SubAxImm16Handler(_decoder));
|
|
|
|
_handlers.Add(new SubImmFromRm16Handler(_decoder));
|
|
|
|
_handlers.Add(new SubImmFromRm16SignExtendedHandler(_decoder));
|
|
|
|
_handlers.Add(new SubRm16R16Handler(_decoder));
|
|
|
|
_handlers.Add(new SubR16Rm16Handler(_decoder));
|
|
|
|
|
2025-04-13 17:51:54 +03:00
|
|
|
// 32-bit handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new SubRm32R32Handler(_decoder));
|
|
|
|
_handlers.Add(new SubR32Rm32Handler(_decoder));
|
|
|
|
_handlers.Add(new SubImmFromRm32Handler(_decoder));
|
|
|
|
_handlers.Add(new SubImmFromRm32SignExtendedHandler(_decoder));
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 17:51:54 +03:00
|
|
|
// 8-bit handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new SubRm8R8Handler(_decoder));
|
|
|
|
_handlers.Add(new SubR8Rm8Handler(_decoder));
|
|
|
|
_handlers.Add(new SubAlImm8Handler(_decoder));
|
|
|
|
_handlers.Add(new SubImmFromRm8Handler(_decoder));
|
2025-04-13 14:25:27 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-13 18:00:26 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all NOP instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterNopHandlers()
|
|
|
|
{
|
|
|
|
// Register NOP handlers
|
2025-04-14 22:08:50 +03:00
|
|
|
_handlers.Add(new NopHandler(_decoder));
|
|
|
|
_handlers.Add(new TwoByteNopHandler(_decoder));
|
|
|
|
_handlers.Add(new MultiByteNopHandler(_decoder));
|
2025-04-13 18:00:26 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
|
2025-04-17 01:33:58 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all bit manipulation instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterBitHandlers()
|
|
|
|
{
|
|
|
|
// BT (Bit Test) handlers
|
|
|
|
_handlers.Add(new BtR32Rm32Handler(_decoder)); // BT r32, r/m32 (0F A3)
|
|
|
|
_handlers.Add(new BtRm32ImmHandler(_decoder)); // BT r/m32, imm8 (0F BA /4)
|
|
|
|
|
|
|
|
// BTS (Bit Test and Set) handlers
|
|
|
|
_handlers.Add(new BtsR32Rm32Handler(_decoder)); // BTS r32, r/m32 (0F AB)
|
|
|
|
_handlers.Add(new BtsRm32ImmHandler(_decoder)); // BTS r/m32, imm8 (0F BA /5)
|
|
|
|
|
|
|
|
// BTR (Bit Test and Reset) handlers
|
|
|
|
_handlers.Add(new BtrR32Rm32Handler(_decoder)); // BTR r32, r/m32 (0F B3)
|
|
|
|
_handlers.Add(new BtrRm32ImmHandler(_decoder)); // BTR r/m32, imm8 (0F BA /6)
|
|
|
|
|
|
|
|
// BTC (Bit Test and Complement) handlers
|
|
|
|
_handlers.Add(new BtcR32Rm32Handler(_decoder)); // BTC r32, r/m32 (0F BB)
|
|
|
|
_handlers.Add(new BtcRm32ImmHandler(_decoder)); // BTC r/m32, imm8 (0F BA /7)
|
|
|
|
|
|
|
|
// BSF and BSR (Bit Scan) handlers
|
|
|
|
_handlers.Add(new BsfR32Rm32Handler(_decoder)); // BSF r32, r/m32 (0F BC)
|
|
|
|
_handlers.Add(new BsrR32Rm32Handler(_decoder)); // BSR r32, r/m32 (0F BD)
|
|
|
|
}
|
|
|
|
|
2025-04-16 20:43:06 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all NEG instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterNegHandlers()
|
|
|
|
{
|
|
|
|
// NEG r/m8 handler (F6 /3)
|
|
|
|
_handlers.Add(new NegRm8Handler(_decoder));
|
|
|
|
|
|
|
|
// NEG r/m32 handler (F7 /3)
|
|
|
|
_handlers.Add(new NegRm32Handler(_decoder));
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Registers all MUL instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterMulHandlers()
|
|
|
|
{
|
|
|
|
// MUL r/m8 handler (F6 /4)
|
|
|
|
_handlers.Add(new MulRm8Handler(_decoder));
|
|
|
|
|
|
|
|
// MUL r/m32 handler (F7 /4)
|
|
|
|
_handlers.Add(new MulRm32Handler(_decoder));
|
|
|
|
}
|
|
|
|
|
2025-04-16 20:54:08 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Registers all NOT instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterNotHandlers()
|
|
|
|
{
|
|
|
|
// NOT r/m8 handler (F6 /2)
|
|
|
|
_handlers.Add(new NotRm8Handler(_decoder));
|
|
|
|
|
|
|
|
// NOT r/m32 handler (F7 /2)
|
|
|
|
_handlers.Add(new NotRm32Handler(_decoder));
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Registers all IMUL instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterImulHandlers()
|
|
|
|
{
|
|
|
|
// IMUL r/m8 handler (F6 /5)
|
|
|
|
_handlers.Add(new ImulRm8Handler(_decoder));
|
|
|
|
|
|
|
|
// IMUL r/m32 handler (F7 /5)
|
|
|
|
_handlers.Add(new ImulRm32Handler(_decoder));
|
2025-04-16 21:20:40 +03:00
|
|
|
|
|
|
|
// IMUL r32, r/m32 handler (0F AF /r)
|
|
|
|
_handlers.Add(new ImulR32Rm32Handler(_decoder));
|
|
|
|
|
|
|
|
// IMUL r32, r/m32, imm8 handler (6B /r ib)
|
|
|
|
_handlers.Add(new ImulR32Rm32Imm8Handler(_decoder));
|
|
|
|
|
|
|
|
// IMUL r32, r/m32, imm32 handler (69 /r id)
|
|
|
|
_handlers.Add(new ImulR32Rm32Imm32Handler(_decoder));
|
2025-04-16 20:54:08 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Registers all DIV instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterDivHandlers()
|
|
|
|
{
|
|
|
|
// DIV r/m8 handler (F6 /6)
|
|
|
|
_handlers.Add(new DivRm8Handler(_decoder));
|
|
|
|
|
|
|
|
// DIV r/m32 handler (F7 /6)
|
|
|
|
_handlers.Add(new DivRm32Handler(_decoder));
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Registers all IDIV instruction handlers
|
|
|
|
/// </summary>
|
|
|
|
private void RegisterIdivHandlers()
|
|
|
|
{
|
|
|
|
// IDIV r/m8 handler (F6 /7)
|
|
|
|
_handlers.Add(new IdivRm8Handler(_decoder));
|
|
|
|
|
|
|
|
// IDIV r/m32 handler (F7 /7)
|
|
|
|
_handlers.Add(new IdivRm32Handler(_decoder));
|
|
|
|
}
|
|
|
|
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <summary>
|
|
|
|
/// Gets the handler that can decode the given opcode
|
2025-04-12 19:57:42 +03:00
|
|
|
/// </summary>
|
|
|
|
/// <param name="opcode">The opcode to decode</param>
|
2025-04-12 22:34:02 +03:00
|
|
|
/// <returns>The handler that can decode the opcode, or null if no handler can decode it</returns>
|
2025-04-12 19:57:42 +03:00
|
|
|
public IInstructionHandler? GetHandler(byte opcode)
|
|
|
|
{
|
2025-04-13 02:51:51 +03:00
|
|
|
// For all other opcodes, use the normal handler selection logic
|
2025-04-12 22:34:02 +03:00
|
|
|
return _handlers.FirstOrDefault(h => h.CanHandle(opcode));
|
2025-04-12 19:57:42 +03:00
|
|
|
}
|
2025-04-13 20:20:51 +03:00
|
|
|
}
|