Fix initial state of segment registers (#751)

* Remove glib from samples makefile

* changes to 16 bit segment registers needs to update segment base as well as segment selector

* change how x86 segment registers are set in 16-bit mode

* more appropriate solution to initial state of x86 segment registers in 16-bit mode

* remove commented lines
This commit is contained in:
Chris Eagle 2017-02-09 07:49:54 -08:00 committed by Nguyen Anh Quynh
parent f05984961b
commit a03e908611

View file

@ -11,9 +11,10 @@
#include <unicorn/x86.h> /* needed for uc_x86_mmr */ #include <unicorn/x86.h> /* needed for uc_x86_mmr */
#include "uc_priv.h" #include "uc_priv.h"
#define X86_NON_CS_FLAGS (DESC_P_MASK | DESC_S_MASK | DESC_W_MASK | DESC_A_MASK)
static void load_seg_16_helper(CPUX86State *env, int seg, uint32_t selector) static void load_seg_16_helper(CPUX86State *env, int seg, uint32_t selector)
{ {
cpu_x86_load_seg_cache(env, seg, selector, (selector << 4), 0xffff, 0); cpu_x86_load_seg_cache(env, seg, selector, (selector << 4), 0xffff, X86_NON_CS_FLAGS);
} }
const int X86_REGS_STORAGE_SIZE = offsetof(CPUX86State, tlb_table); const int X86_REGS_STORAGE_SIZE = offsetof(CPUX86State, tlb_table);
@ -130,6 +131,18 @@ void x86_reg_reset(struct uc_struct *uc)
case UC_MODE_16: case UC_MODE_16:
env->hflags = 0; env->hflags = 0;
env->cr[0] = 0; env->cr[0] = 0;
//undo the damage done by the memset of env->segs above
//for R_CS, not quite the same as x86_cpu_reset
cpu_x86_load_seg_cache(env, R_CS, 0, 0, 0xffff,
DESC_P_MASK | DESC_S_MASK | DESC_CS_MASK |
DESC_R_MASK | DESC_A_MASK);
//remainder yields same state as x86_cpu_reset
load_seg_16_helper(env, R_DS, 0);
load_seg_16_helper(env, R_ES, 0);
load_seg_16_helper(env, R_SS, 0);
load_seg_16_helper(env, R_FS, 0);
load_seg_16_helper(env, R_GS, 0);
break; break;
case UC_MODE_32: case UC_MODE_32:
env->hflags |= HF_CS32_MASK | HF_SS32_MASK | HF_OSFXSR_MASK; env->hflags |= HF_CS32_MASK | HF_SS32_MASK | HF_OSFXSR_MASK;