diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2005-01-23 20:45:23 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2005-01-23 20:45:23 +0000 |
commit | 4d6b6c0aec20e78c966b857c520fe0d242d64b30 (patch) | |
tree | f23dd8b8bb4ffbe44e0f371852e5983552e557e0 /target-i386 | |
parent | 79f91c27bad7cf39ff336f1b2ed418942f65bab6 (diff) | |
download | qemu-4d6b6c0aec20e78c966b857c520fe0d242d64b30.zip qemu-4d6b6c0aec20e78c966b857c520fe0d242d64b30.tar.gz qemu-4d6b6c0aec20e78c966b857c520fe0d242d64b30.tar.bz2 |
more fpu functions - x86_64 fixes
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1234 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'target-i386')
-rw-r--r-- | target-i386/helper.c | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/target-i386/helper.c b/target-i386/helper.c index d9c446f..ea2ef5e 100644 --- a/target-i386/helper.c +++ b/target-i386/helper.c @@ -1454,7 +1454,11 @@ void load_seg(int seg_reg, int selector) selector &= 0xffff; if ((selector & 0xfffc) == 0) { /* null selector case */ - if (seg_reg == R_SS) + if (seg_reg == R_SS +#ifdef TARGET_X86_64 + && !(env->hflags & HF_CS64_MASK) +#endif + ) raise_exception_err(EXCP0D_GPF, 0); cpu_x86_load_seg_cache(env, seg_reg, selector, 0, 0, 0); } else { @@ -2146,6 +2150,7 @@ void helper_sysexit(void) void helper_movl_crN_T0(int reg) { +#if !defined(CONFIG_USER_ONLY) switch(reg) { case 0: cpu_x86_update_cr0(env, T0); @@ -2156,10 +2161,14 @@ void helper_movl_crN_T0(int reg) case 4: cpu_x86_update_cr4(env, T0); break; + case 8: + cpu_set_apic_tpr(env, T0); + break; default: env->cr[reg] = T0; break; } +#endif } /* XXX: do more */ @@ -3227,6 +3236,25 @@ float approx_rcp(float a) return 1.0 / a; } +/* XXX: find a better solution */ +double helper_sqrt(double a) +{ + return sqrt(a); +} + +/* XXX: move that to another file */ +#if defined(__powerpc__) +/* better to call an helper on ppc */ +float int32_to_float32(int32_t a) +{ + return (float)a; +} + +double int32_to_float64(int32_t a) +{ + return (double)a; +} +#endif #if !defined(CONFIG_USER_ONLY) |