diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2003-08-21 23:25:21 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2003-08-21 23:25:21 +0000 |
commit | 2e255c6b9f05f78a7effc4d1246c8a420680b810 (patch) | |
tree | d625e0135002840792a12df47189d5193209d800 /vl.c | |
parent | 3f3373166227b13e762e20d2fb51eadfa6a2d653 (diff) | |
download | qemu-2e255c6b9f05f78a7effc4d1246c8a420680b810.zip qemu-2e255c6b9f05f78a7effc4d1246c8a420680b810.tar.gz qemu-2e255c6b9f05f78a7effc4d1246c8a420680b810.tar.bz2 |
faster and more accurate segment handling
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@373 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'vl.c')
-rw-r--r-- | vl.c | 24 |
1 files changed, 12 insertions, 12 deletions
@@ -3590,12 +3590,12 @@ int main(int argc, char **argv) env->gdt.base = (void *)params->gdt_table; env->gdt.limit = sizeof(params->gdt_table) - 1; - cpu_x86_load_seg(env, R_CS, KERNEL_CS); - cpu_x86_load_seg(env, R_DS, KERNEL_DS); - cpu_x86_load_seg(env, R_ES, KERNEL_DS); - cpu_x86_load_seg(env, R_SS, KERNEL_DS); - cpu_x86_load_seg(env, R_FS, KERNEL_DS); - cpu_x86_load_seg(env, R_GS, KERNEL_DS); + cpu_x86_load_seg_cache(env, R_CS, KERNEL_CS, NULL, 0xffffffff, 0x00cf9a00); + cpu_x86_load_seg_cache(env, R_DS, KERNEL_DS, NULL, 0xffffffff, 0x00cf9200); + cpu_x86_load_seg_cache(env, R_ES, KERNEL_DS, NULL, 0xffffffff, 0x00cf9200); + cpu_x86_load_seg_cache(env, R_SS, KERNEL_DS, NULL, 0xffffffff, 0x00cf9200); + cpu_x86_load_seg_cache(env, R_FS, KERNEL_DS, NULL, 0xffffffff, 0x00cf9200); + cpu_x86_load_seg_cache(env, R_GS, KERNEL_DS, NULL, 0xffffffff, 0x00cf9200); env->eip = KERNEL_LOAD_ADDR; env->regs[R_ESI] = KERNEL_PARAMS_ADDR; @@ -3627,12 +3627,12 @@ int main(int argc, char **argv) env->ldt.limit = 0xffff; /* not correct (CS base=0xffff0000) */ - cpu_x86_load_seg(env, R_CS, 0xf000); - cpu_x86_load_seg(env, R_DS, 0); - cpu_x86_load_seg(env, R_ES, 0); - cpu_x86_load_seg(env, R_SS, 0); - cpu_x86_load_seg(env, R_FS, 0); - cpu_x86_load_seg(env, R_GS, 0); + cpu_x86_load_seg_cache(env, R_CS, 0xf000, (uint8_t *)0x000f0000, 0xffff, 0); + cpu_x86_load_seg_cache(env, R_DS, 0, NULL, 0xffff, 0); + cpu_x86_load_seg_cache(env, R_ES, 0, NULL, 0xffff, 0); + cpu_x86_load_seg_cache(env, R_SS, 0, NULL, 0xffff, 0); + cpu_x86_load_seg_cache(env, R_FS, 0, NULL, 0xffff, 0); + cpu_x86_load_seg_cache(env, R_GS, 0, NULL, 0xffff, 0); env->eip = 0xfff0; env->regs[R_EDX] = 0x600; /* indicate P6 processor */ |