Commit f60d2728cc27cd1eb05ad1cde13dc41810963128
1 parent
d40c54d6
Fix smsw for x86_64 guest and bigendian host case
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6009 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
4 additions
and
0 deletions
target-i386/translate.c
... | ... | @@ -7078,7 +7078,11 @@ static target_ulong disas_insn(DisasContext *s, target_ulong pc_start) |
7078 | 7078 | break; |
7079 | 7079 | case 4: /* smsw */ |
7080 | 7080 | gen_svm_check_intercept(s, pc_start, SVM_EXIT_READ_CR0); |
7081 | +#if defined TARGET_X86_64 && defined WORDS_BIGENDIAN | |
7082 | + tcg_gen_ld32u_tl(cpu_T[0], cpu_env, offsetof(CPUX86State,cr[0]) + 4); | |
7083 | +#else | |
7081 | 7084 | tcg_gen_ld32u_tl(cpu_T[0], cpu_env, offsetof(CPUX86State,cr[0])); |
7085 | +#endif | |
7082 | 7086 | gen_ldst_modrm(s, modrm, OT_WORD, OR_TMP0, 1); |
7083 | 7087 | break; |
7084 | 7088 | case 6: /* lmsw */ | ... | ... |