From e4d737dadf3d24dc439db444e7c338d234478b46 Mon Sep 17 00:00:00 2001 From: tuz358 Date: Mon, 5 Mar 2018 18:00:06 +0900 Subject: [PATCH] Add mov_esi_imm32(0xbe) instruction --- include/instructions.h | 2 ++ instructions.cpp | 10 ++++++++++ 2 files changed, 12 insertions(+) diff --git a/include/instructions.h b/include/instructions.h index bb83add..3c0bd35 100644 --- a/include/instructions.h +++ b/include/instructions.h @@ -39,6 +39,8 @@ public: void mov_edx_imm32(); // 0xba void mov_ebx_imm32(); // 0xbb void mov_esp_imm32(); // 0xbc + void mov_ebp_imm32(); // 0xbd + void mov_esi_imm32(); // 0xbe void jmp_imm8(); // 0xeb void hlt(); // 0xf4 void opcode_ff(); // 0xff diff --git a/instructions.cpp b/instructions.cpp index bcc2fc6..958dcf0 100644 --- a/instructions.cpp +++ b/instructions.cpp @@ -33,6 +33,7 @@ void Instructions::init_instructions(){ this->instructions[0xbb] = &Instructions::mov_ebx_imm32; this->instructions[0xbc] = &Instructions::mov_esp_imm32; this->instructions[0xbd] = &Instructions::mov_ebp_imm32; + this->instructions[0xbe] = &Instructions::mov_esi_imm32; this->instructions[0xeb] = &Instructions::jmp_imm8; this->instructions[0xf4] = &Instructions::hlt; this->instructions[0xff] = &Instructions::opcode_ff; @@ -290,6 +291,15 @@ void Instructions::mov_ebp_imm32(){ this->eip += 4; } +void Instructions::mov_esi_imm32(){ + //printf("mov_esi_imm32 called.\n"); + + uint32_t imm32 = memory.read_uint32(this->eip); + imm32 = swap_endian32(imm32); + this->registers[6] = imm32; + this->eip += 4; +} + void Instructions::jmp_imm8() { //printf("jmp_imm8 called.\n");