| 
									
										
										
										
											2025-04-12 21:34:16 +03:00
										 |  |  | namespace X86Disassembler.X86.Handlers.Jump; | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-15 02:42:47 +03:00
										 |  |  | using Operands; | 
					
						
							| 
									
										
										
										
											2025-04-14 22:08:50 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  | /// <summary> | 
					
						
							|  |  |  | /// Handler for JMP rel32 instruction (0xE9) | 
					
						
							|  |  |  | /// </summary> | 
					
						
							|  |  |  | public class JmpRel32Handler : InstructionHandler | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /// <summary> | 
					
						
							|  |  |  |     /// Initializes a new instance of the JmpRel32Handler class | 
					
						
							|  |  |  |     /// </summary> | 
					
						
							|  |  |  |     /// <param name="decoder">The instruction decoder that owns this handler</param> | 
					
						
							| 
									
										
										
										
											2025-04-14 22:08:50 +03:00
										 |  |  |     public JmpRel32Handler(InstructionDecoder decoder)  | 
					
						
							|  |  |  |         : base(decoder) | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-14 00:30:53 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |     /// <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 override bool CanHandle(byte opcode) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2025-04-17 01:33:58 +03:00
										 |  |  |         // Only handle opcode 0xE9 when the operand size prefix is NOT present | 
					
						
							|  |  |  |         // This ensures 16-bit handlers get priority when the prefix is present | 
					
						
							|  |  |  |         return opcode == 0xE9 && !Decoder.HasOperandSizePrefix(); | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-14 00:30:53 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |     /// <summary> | 
					
						
							|  |  |  |     /// Decodes a JMP rel32 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 override bool Decode(byte opcode, Instruction instruction) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2025-04-14 22:08:50 +03:00
										 |  |  |         // Set the instruction type | 
					
						
							|  |  |  |         instruction.Type = InstructionType.Jmp; | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2025-04-14 00:30:53 +03:00
										 |  |  |         // Check if we have enough bytes for the offset (4 bytes) | 
					
						
							| 
									
										
										
										
											2025-04-14 02:07:17 +03:00
										 |  |  |         if (!Decoder.CanReadUInt()) | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |         { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2025-04-14 00:11:55 +03:00
										 |  |  |         // Read the offset and calculate target address | 
					
						
							| 
									
										
										
										
											2025-04-14 00:30:53 +03:00
										 |  |  |         uint offset = Decoder.ReadUInt32(); | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2025-04-14 00:11:55 +03:00
										 |  |  |         // Calculate target address (instruction address + instruction length + offset) | 
					
						
							|  |  |  |         // For JMP rel32, the instruction is 5 bytes: opcode (1 byte) + offset (4 bytes) | 
					
						
							|  |  |  |         uint targetAddress = (uint)(instruction.Address + 5 + offset); | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2025-04-14 22:08:50 +03:00
										 |  |  |         // Create the target address operand | 
					
						
							|  |  |  |         var targetOperand = OperandFactory.CreateRelativeOffsetOperand(targetAddress); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         // Set the structured operands | 
					
						
							|  |  |  |         instruction.StructuredOperands =  | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             targetOperand | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2025-04-12 19:57:42 +03:00
										 |  |  |          | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |