namespace X86Disassembler.X86.Handlers.Jump; /// /// Handler for JGE rel8 instruction (0x7D) /// public class JgeRel8Handler : InstructionHandler { /// /// Initializes a new instance of the JgeRel8Handler class /// /// The buffer containing the code to decode /// The instruction decoder that owns this handler /// The length of the buffer public JgeRel8Handler(byte[] codeBuffer, InstructionDecoder decoder, int length) : base(codeBuffer, decoder, length) { } /// /// 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) { return opcode == 0x7D; } /// /// Decodes a JGE rel8 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) { // Save the original position for raw bytes calculation int startPosition = Decoder.GetPosition(); // Set the mnemonic instruction.Mnemonic = "jge"; if (startPosition >= Length) { instruction.Operands = "??"; instruction.RawBytes = new byte[] { opcode }; return true; } // Read the relative offset sbyte offset = (sbyte)CodeBuffer[startPosition]; Decoder.SetPosition(startPosition + 1); // Calculate the target address // The target is calculated from the address of the next instruction (EIP + 2) // EIP + 2 + offset uint targetAddress = (uint)(instruction.Address + offset + 2); // Set the operands instruction.Operands = $"0x{targetAddress:X8}"; // Set the raw bytes instruction.RawBytes = new byte[] { opcode, (byte)offset }; return true; } }