Commit d3c617219b663c7cbcd443922c3ee070d16ee613
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 | 2915 | fpus = (env->fpus & ~0x3800) | (env->fpstt & 0x7) << 11; |
2916 | 2916 | fptag = 0; |
2917 | 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 | 2920 | stw(ptr, env->fpuc); |
2921 | 2921 | stw(ptr + 2, fpus); |
2922 | - stw(ptr + 4, fptag); | |
2922 | + stw(ptr + 4, fptag ^ 0xff); | |
2923 | 2923 | |
2924 | 2924 | addr = ptr + 0x20; |
2925 | 2925 | for(i = 0;i < 8; i++) { |
... | ... | @@ -2931,7 +2931,7 @@ void helper_fxsave(target_ulong ptr, int data64) |
2931 | 2931 | if (env->cr[4] & CR4_OSFXSR_MASK) { |
2932 | 2932 | /* XXX: finish it */ |
2933 | 2933 | stl(ptr + 0x18, env->mxcsr); /* mxcsr */ |
2934 | - stl(ptr + 0x1c, 0); /* mxcsr_mask */ | |
2934 | + stl(ptr + 0x1c, 0x0000ffff); /* mxcsr_mask */ | |
2935 | 2935 | nb_xmm_regs = 8 << data64; |
2936 | 2936 | addr = ptr + 0xa0; |
2937 | 2937 | for(i = 0; i < nb_xmm_regs; i++) { |
... | ... | @@ -2950,12 +2950,12 @@ void helper_fxrstor(target_ulong ptr, int data64) |
2950 | 2950 | |
2951 | 2951 | env->fpuc = lduw(ptr); |
2952 | 2952 | fpus = lduw(ptr + 2); |
2953 | - fptag = ldub(ptr + 4); | |
2953 | + fptag = lduw(ptr + 4); | |
2954 | 2954 | env->fpstt = (fpus >> 11) & 7; |
2955 | 2955 | env->fpus = fpus & ~0x3800; |
2956 | 2956 | fptag ^= 0xff; |
2957 | 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 | 2961 | addr = ptr + 0x20; | ... | ... |