Commit d3c617219b663c7cbcd443922c3ee070d16ee613

Authored by bellard
1 parent 735a8fd3

fxsr fixes


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1219 c046a42c-6fe2-441c-8c8c-71466251a162
Showing 1 changed file with 5 additions and 5 deletions
target-i386/helper.c
@@ -2915,11 +2915,11 @@ void helper_fxsave(target_ulong ptr, int data64) @@ -2915,11 +2915,11 @@ void helper_fxsave(target_ulong ptr, int data64)
2915 fpus = (env->fpus & ~0x3800) | (env->fpstt & 0x7) << 11; 2915 fpus = (env->fpus & ~0x3800) | (env->fpstt & 0x7) << 11;
2916 fptag = 0; 2916 fptag = 0;
2917 for(i = 0; i < 8; i++) { 2917 for(i = 0; i < 8; i++) {
2918 - fptag |= ((!env->fptags[(env->fpstt + i) & 7]) << i); 2918 + fptag |= (env->fptags[i] << i);
2919 } 2919 }
2920 stw(ptr, env->fpuc); 2920 stw(ptr, env->fpuc);
2921 stw(ptr + 2, fpus); 2921 stw(ptr + 2, fpus);
2922 - stw(ptr + 4, fptag); 2922 + stw(ptr + 4, fptag ^ 0xff);
2923 2923
2924 addr = ptr + 0x20; 2924 addr = ptr + 0x20;
2925 for(i = 0;i < 8; i++) { 2925 for(i = 0;i < 8; i++) {
@@ -2931,7 +2931,7 @@ void helper_fxsave(target_ulong ptr, int data64) @@ -2931,7 +2931,7 @@ void helper_fxsave(target_ulong ptr, int data64)
2931 if (env->cr[4] & CR4_OSFXSR_MASK) { 2931 if (env->cr[4] & CR4_OSFXSR_MASK) {
2932 /* XXX: finish it */ 2932 /* XXX: finish it */
2933 stl(ptr + 0x18, env->mxcsr); /* mxcsr */ 2933 stl(ptr + 0x18, env->mxcsr); /* mxcsr */
2934 - stl(ptr + 0x1c, 0); /* mxcsr_mask */ 2934 + stl(ptr + 0x1c, 0x0000ffff); /* mxcsr_mask */
2935 nb_xmm_regs = 8 << data64; 2935 nb_xmm_regs = 8 << data64;
2936 addr = ptr + 0xa0; 2936 addr = ptr + 0xa0;
2937 for(i = 0; i < nb_xmm_regs; i++) { 2937 for(i = 0; i < nb_xmm_regs; i++) {
@@ -2950,12 +2950,12 @@ void helper_fxrstor(target_ulong ptr, int data64) @@ -2950,12 +2950,12 @@ void helper_fxrstor(target_ulong ptr, int data64)
2950 2950
2951 env->fpuc = lduw(ptr); 2951 env->fpuc = lduw(ptr);
2952 fpus = lduw(ptr + 2); 2952 fpus = lduw(ptr + 2);
2953 - fptag = ldub(ptr + 4); 2953 + fptag = lduw(ptr + 4);
2954 env->fpstt = (fpus >> 11) & 7; 2954 env->fpstt = (fpus >> 11) & 7;
2955 env->fpus = fpus & ~0x3800; 2955 env->fpus = fpus & ~0x3800;
2956 fptag ^= 0xff; 2956 fptag ^= 0xff;
2957 for(i = 0;i < 8; i++) { 2957 for(i = 0;i < 8; i++) {
2958 - env->fptags[(env->fpstt + i) & 7] = ((fptag >> i) & 1); 2958 + env->fptags[i] = ((fptag >> i) & 1);
2959 } 2959 }
2960 2960
2961 addr = ptr + 0x20; 2961 addr = ptr + 0x20;