mirror of
https://github.com/sampletext32/ParkanPlayground.git
synced 2025-05-19 20:01:17 +03:00
71 lines
2.5 KiB
C#
71 lines
2.5 KiB
C#
namespace X86Disassembler.X86.Handlers;
|
|
|
|
/// <summary>
|
|
/// Abstract base class for instruction handlers
|
|
/// </summary>
|
|
public abstract class InstructionHandler : IInstructionHandler
|
|
{
|
|
// Buffer containing the code to decode
|
|
protected readonly byte[] CodeBuffer;
|
|
|
|
// The instruction decoder that owns this handler
|
|
protected readonly InstructionDecoder Decoder;
|
|
|
|
// Length of the buffer
|
|
protected readonly int Length;
|
|
|
|
// ModRM decoder for handling addressing modes
|
|
protected readonly ModRMDecoder ModRMDecoder;
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the InstructionHandler 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>
|
|
protected InstructionHandler(byte[] codeBuffer, InstructionDecoder decoder, int length)
|
|
{
|
|
CodeBuffer = codeBuffer;
|
|
Decoder = decoder;
|
|
Length = length;
|
|
ModRMDecoder = new ModRMDecoder(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 abstract bool CanHandle(byte opcode);
|
|
|
|
/// <summary>
|
|
/// Decodes an 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 abstract bool Decode(byte opcode, Instruction instruction);
|
|
|
|
/// <summary>
|
|
/// Gets the 32-bit register name for the given register index
|
|
/// </summary>
|
|
/// <param name="reg">The register index</param>
|
|
/// <returns>The register name</returns>
|
|
protected static string GetRegister32(byte reg)
|
|
{
|
|
string[] registerNames = { "eax", "ecx", "edx", "ebx", "esp", "ebp", "esi", "edi" };
|
|
return registerNames[reg & 0x07];
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the 8-bit register name for the given register index
|
|
/// </summary>
|
|
/// <param name="reg">The register index</param>
|
|
/// <returns>The register name</returns>
|
|
protected static string GetRegister8(byte reg)
|
|
{
|
|
string[] registerNames = { "al", "cl", "dl", "bl", "ah", "ch", "dh", "bh" };
|
|
return registerNames[reg & 0x07];
|
|
}
|
|
}
|