0
mirror of https://github.com/sampletext32/ParkanPlayground.git synced 2025-05-19 11:51:17 +03:00
ParkanPlayground/X86Disassembler/X86/Handlers/InstructionHandlerFactory.cs

475 lines
16 KiB
C#
Raw Normal View History

2025-04-13 04:13:44 +03:00
using X86Disassembler.X86.Handlers.Adc;
using X86Disassembler.X86.Handlers.Add;
using X86Disassembler.X86.Handlers.And;
using X86Disassembler.X86.Handlers.ArithmeticUnary;
2025-04-12 22:18:46 +03:00
using X86Disassembler.X86.Handlers.Call;
using X86Disassembler.X86.Handlers.Cmp;
using X86Disassembler.X86.Handlers.Dec;
2025-04-12 23:24:42 +03:00
using X86Disassembler.X86.Handlers.FloatingPoint;
using X86Disassembler.X86.Handlers.Inc;
2025-04-12 21:34:16 +03:00
using X86Disassembler.X86.Handlers.Jump;
using X86Disassembler.X86.Handlers.Lea;
using X86Disassembler.X86.Handlers.Mov;
using X86Disassembler.X86.Handlers.Mul;
using X86Disassembler.X86.Handlers.Neg;
using X86Disassembler.X86.Handlers.Nop;
using X86Disassembler.X86.Handlers.Or;
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;
using X86Disassembler.X86.Handlers.String;
2025-04-13 04:13:44 +03:00
using X86Disassembler.X86.Handlers.Sub;
using X86Disassembler.X86.Handlers.Test;
using X86Disassembler.X86.Handlers.Xchg;
using X86Disassembler.X86.Handlers.Xor;
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 = [];
private readonly byte[] _codeBuffer;
private readonly InstructionDecoder _decoder;
private readonly int _length;
2025-04-13 20:20:51 +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
RegisterAllHandlers();
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all handlers
/// </summary>
private void RegisterAllHandlers()
{
// Register specific instruction handlers
_handlers.Add(new Int3Handler(_decoder));
2025-04-13 20:20:51 +03:00
// Register handlers in order of priority (most specific first)
RegisterArithmeticImmediateHandlers(); // Group 1 instructions (including 0x83)
RegisterAddHandlers();
RegisterAndHandlers();
RegisterArithmeticUnaryHandlers();
RegisterNegHandlers(); // Register NEG handlers
RegisterMulHandlers(); // Register MUL handlers
RegisterCmpHandlers();
RegisterXorHandlers();
RegisterOrHandlers();
RegisterTestHandlers();
RegisterDataTransferHandlers();
RegisterJumpHandlers();
RegisterCallHandlers();
RegisterReturnHandlers();
RegisterDecHandlers();
RegisterIncHandlers(); // INC/DEC handlers after Group 1 handlers
RegisterPushHandlers();
RegisterPopHandlers();
RegisterLeaHandlers();
2025-04-12 23:24:42 +03:00
RegisterFloatingPointHandlers();
RegisterStringHandlers();
RegisterMovHandlers();
RegisterSubHandlers(); // Register SUB handlers
RegisterNopHandlers(); // Register NOP handlers
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all ArithmeticUnary instruction handlers
/// </summary>
private void RegisterArithmeticUnaryHandlers()
{
// NOT handler
_handlers.Add(new NotRm32Handler(_decoder));
2025-04-13 20:20:51 +03:00
// IMUL handler
_handlers.Add(new ImulRm32Handler(_decoder));
2025-04-13 20:20:51 +03:00
// DIV handler
_handlers.Add(new DivRm32Handler(_decoder));
2025-04-13 20:20:51 +03:00
// IDIV handler
_handlers.Add(new IdivRm32Handler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all ArithmeticImmediate instruction handlers
/// </summary>
private void RegisterArithmeticImmediateHandlers()
{
// ADC handlers
_handlers.Add(new AdcImmToRm32Handler(_decoder));
_handlers.Add(new AdcImmToRm32SignExtendedHandler(_decoder));
2025-04-13 20:20:51 +03:00
// SBB handlers
_handlers.Add(new SbbImmFromRm32Handler(_decoder));
_handlers.Add(new SbbImmFromRm32SignExtendedHandler(_decoder));
2025-04-13 20:20:51 +03:00
// SUB handlers
_handlers.Add(new SubImmFromRm32Handler(_decoder));
_handlers.Add(new SubImmFromRm32SignExtendedHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Return instruction handlers
/// </summary>
private void RegisterReturnHandlers()
{
// Add Return handlers
_handlers.Add(new RetHandler(_decoder));
_handlers.Add(new RetImmHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Call instruction handlers
/// </summary>
private void RegisterCallHandlers()
{
// Add Call handlers
_handlers.Add(new CallRel32Handler(_decoder));
_handlers.Add(new CallRm32Handler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Jump instruction handlers
/// </summary>
private void RegisterJumpHandlers()
{
// 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
_handlers.Add(new JgeRel8Handler(_decoder));
_handlers.Add(new ConditionalJumpHandler(_decoder));
_handlers.Add(new TwoByteConditionalJumpHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Test instruction handlers
/// </summary>
private void RegisterTestHandlers()
{
// TEST handlers
_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-13 20:20:51 +03:00
/// <summary>
/// Registers all Xor instruction handlers
/// </summary>
private void RegisterXorHandlers()
{
// 16-bit handlers
_handlers.Add(new XorRm16R16Handler(_decoder));
_handlers.Add(new XorR16Rm16Handler(_decoder));
_handlers.Add(new XorImmWithRm16Handler(_decoder));
_handlers.Add(new XorImmWithRm16SignExtendedHandler(_decoder));
2025-04-13 20:20:51 +03:00
// 32-bit handlers
_handlers.Add(new XorMemRegHandler(_decoder));
_handlers.Add(new XorRegMemHandler(_decoder));
_handlers.Add(new XorImmWithRm32Handler(_decoder));
_handlers.Add(new XorImmWithRm32SignExtendedHandler(_decoder));
2025-04-13 20:20:51 +03:00
// 8-bit handlers
_handlers.Add(new XorRm8R8Handler(_decoder));
_handlers.Add(new XorR8Rm8Handler(_decoder));
_handlers.Add(new XorAlImmHandler(_decoder));
_handlers.Add(new XorImmWithRm8Handler(_decoder));
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
_handlers.Add(new XorAxImm16Handler(_decoder));
_handlers.Add(new XorEaxImmHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Or instruction handlers
/// </summary>
private void RegisterOrHandlers()
{
// Add OR handlers
_handlers.Add(new OrImmToRm8Handler(_decoder));
_handlers.Add(new OrImmToRm32Handler(_decoder));
_handlers.Add(new OrImmToRm32SignExtendedHandler(_decoder));
_handlers.Add(new OrR8Rm8Handler(_decoder));
_handlers.Add(new OrRm8R8Handler(_decoder));
_handlers.Add(new OrR32Rm32Handler(_decoder));
_handlers.Add(new OrAlImmHandler(_decoder));
_handlers.Add(new OrEaxImmHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Lea instruction handlers
/// </summary>
private void RegisterLeaHandlers()
{
// Add Lea handlers
_handlers.Add(new LeaR32MHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Cmp instruction handlers
/// </summary>
private void RegisterCmpHandlers()
{
// Add Cmp handlers for 32-bit operands
_handlers.Add(new CmpR32Rm32Handler(_decoder));
_handlers.Add(new CmpRm32R32Handler(_decoder));
// 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
_handlers.Add(new CmpImmWithRm8Handler(_decoder));
_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
// Add CMP immediate handlers from ArithmeticImmediate namespace
_handlers.Add(new CmpImmWithRm32Handler(_decoder));
_handlers.Add(new CmpImmWithRm32SignExtendedHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Dec instruction handlers
/// </summary>
private void RegisterDecHandlers()
{
// Add Dec handlers
_handlers.Add(new DecRegHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Inc instruction handlers
/// </summary>
private void RegisterIncHandlers()
{
// Add Inc handlers
_handlers.Add(new IncRegHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Add instruction handlers
/// </summary>
private void RegisterAddHandlers()
{
// Add ADD handlers
_handlers.Add(new AddR32Rm32Handler(_decoder));
_handlers.Add(new AddRm32R32Handler(_decoder));
_handlers.Add(new AddEaxImmHandler(_decoder));
2025-04-15 23:54:37 +03:00
// Add 8-bit ADD handlers
_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
// Add ADD immediate handlers from ArithmeticImmediate namespace
_handlers.Add(new AddImmToRm8Handler(_decoder));
_handlers.Add(new AddImmToRm32Handler(_decoder));
_handlers.Add(new AddImmToRm32SignExtendedHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all Data Transfer instruction handlers
/// </summary>
private void RegisterDataTransferHandlers()
{
// Add MOV handlers
_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
// Add PUSH handlers
_handlers.Add(new PushRegHandler(_decoder));
_handlers.Add(new PushImm32Handler(_decoder));
_handlers.Add(new PushImm8Handler(_decoder));
2025-04-13 20:20:51 +03:00
// Add POP handlers
_handlers.Add(new PopRegHandler(_decoder));
2025-04-13 20:20:51 +03:00
// Add XCHG handlers
_handlers.Add(new XchgEaxRegHandler(_decoder));
}
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
_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
/// <summary>
/// Registers all String instruction handlers
/// </summary>
private void RegisterStringHandlers()
{
// Add String instruction handler that handles both regular and REP/REPNE prefixed string instructions
_handlers.Add(new StringInstructionHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all MOV instruction handlers
/// </summary>
private void RegisterMovHandlers()
{
// Add MOV handlers
_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
/// <summary>
/// Registers all PUSH instruction handlers
/// </summary>
private void RegisterPushHandlers()
{
// Add PUSH handlers
_handlers.Add(new PushRegHandler(_decoder));
_handlers.Add(new PushImm32Handler(_decoder));
_handlers.Add(new PushImm8Handler(_decoder));
_handlers.Add(new PushRm32Handler(_decoder)); // Add handler for PUSH r/m32 (FF /6)
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all POP instruction handlers
/// </summary>
private void RegisterPopHandlers()
{
// Add POP handlers
_handlers.Add(new PopRegHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all And instruction handlers
/// </summary>
private void RegisterAndHandlers()
{
// Add AND handlers
_handlers.Add(new AndImmToRm8Handler(_decoder));
_handlers.Add(new AndImmWithRm32Handler(_decoder));
_handlers.Add(new AndImmToRm32Handler(_decoder));
_handlers.Add(new AndImmToRm32SignExtendedHandler(_decoder));
_handlers.Add(new AndR8Rm8Handler(_decoder));
_handlers.Add(new AndRm8R8Handler(_decoder));
_handlers.Add(new AndR32Rm32Handler(_decoder));
_handlers.Add(new AndMemRegHandler(_decoder));
_handlers.Add(new AndAlImmHandler(_decoder));
_handlers.Add(new AndEaxImmHandler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all SUB instruction handlers
/// </summary>
private void RegisterSubHandlers()
{
// Register SUB handlers
2025-04-13 20:20:51 +03:00
// 32-bit handlers
_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
// 16-bit handlers
_handlers.Add(new SubRm16R16Handler(_decoder));
_handlers.Add(new SubR16Rm16Handler(_decoder));
_handlers.Add(new SubAxImm16Handler(_decoder));
_handlers.Add(new SubImmFromRm16Handler(_decoder));
_handlers.Add(new SubImmFromRm16SignExtendedHandler(_decoder));
2025-04-13 20:20:51 +03:00
// 8-bit handlers
_handlers.Add(new SubRm8R8Handler(_decoder));
_handlers.Add(new SubR8Rm8Handler(_decoder));
_handlers.Add(new SubAlImm8Handler(_decoder));
_handlers.Add(new SubImmFromRm8Handler(_decoder));
}
2025-04-13 20:20:51 +03:00
/// <summary>
/// Registers all NOP instruction handlers
/// </summary>
private void RegisterNopHandlers()
{
// Register NOP handlers
_handlers.Add(new NopHandler(_decoder));
_handlers.Add(new TwoByteNopHandler(_decoder));
_handlers.Add(new MultiByteNopHandler(_decoder));
}
2025-04-13 20:20:51 +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));
}
/// <summary>
/// Gets the handler that can decode the given opcode
/// </summary>
/// <param name="opcode">The opcode to decode</param>
/// <returns>The handler that can decode the opcode, or null if no handler can decode it</returns>
public IInstructionHandler? GetHandler(byte opcode)
{
// For all other opcodes, use the normal handler selection logic
return _handlers.FirstOrDefault(h => h.CanHandle(opcode));
}
2025-04-13 20:20:51 +03:00
}