using X86Disassembler.X86.Operands; namespace X86Disassembler.X86.Handlers.Add; /// /// Handler for ADD EAX, imm32 instruction (0x05) /// public class AddEaxImmHandler : InstructionHandler { /// /// Initializes a new instance of the AddEaxImmHandler class /// /// The instruction decoder that owns this handler public AddEaxImmHandler(InstructionDecoder decoder) : base(decoder) { } /// /// Checks if this handler can decode the given opcode /// /// The opcode to check /// True if this handler can decode the opcode public override bool CanHandle(byte opcode) { // ADD EAX, imm32 is encoded as 0x05 without 0x66 prefix if (opcode != 0x05) { return false; } // Only handle when the operand size prefix is NOT present return !Decoder.HasOperandSizePrefix(); } /// /// Decodes an ADD EAX, imm32 instruction /// /// The opcode of the instruction /// The instruction object to populate /// True if the instruction was successfully decoded public override bool Decode(byte opcode, Instruction instruction) { instruction.Type = InstructionType.Add; if (!Decoder.CanReadUInt()) { return false; } // Read the 32-bit immediate value uint imm32 = Decoder.ReadUInt32(); instruction.StructuredOperands = [ OperandFactory.CreateRegisterOperand(RegisterIndex.A), OperandFactory.CreateImmediateOperand(imm32) ]; return true; } }