Commit f60d2728cc27cd1eb05ad1cde13dc41810963128

Authored by malc
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,7 +7078,11 @@ static target_ulong disas_insn(DisasContext *s, target_ulong pc_start)
7078 break; 7078 break;
7079 case 4: /* smsw */ 7079 case 4: /* smsw */
7080 gen_svm_check_intercept(s, pc_start, SVM_EXIT_READ_CR0); 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 tcg_gen_ld32u_tl(cpu_T[0], cpu_env, offsetof(CPUX86State,cr[0])); 7084 tcg_gen_ld32u_tl(cpu_T[0], cpu_env, offsetof(CPUX86State,cr[0]));
  7085 +#endif
7082 gen_ldst_modrm(s, modrm, OT_WORD, OR_TMP0, 1); 7086 gen_ldst_modrm(s, modrm, OT_WORD, OR_TMP0, 1);
7083 break; 7087 break;
7084 case 6: /* lmsw */ 7088 case 6: /* lmsw */