From 447c2cefcb6b52c659f474490377b2721ff6a00a Mon Sep 17 00:00:00 2001 From: bellard Date: Mon, 19 Jun 2006 22:06:13 +0000 Subject: [PATCH] switch_tss eflags restore fix (malc) git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1995 c046a42c-6fe2-441c-8c8c-71466251a162 --- target-i386/helper.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/target-i386/helper.c b/target-i386/helper.c index 123f510497..29185ceb97 100644 --- a/target-i386/helper.c +++ b/target-i386/helper.c @@ -1674,6 +1674,7 @@ void helper_ljmp_protected_T0_T1(int next_eip_addend) raise_exception_err(EXCP0D_GPF, new_cs & 0xfffc); next_eip = env->eip + next_eip_addend; switch_tss(new_cs, e1, e2, SWITCH_TSS_JMP, next_eip); + CC_OP = CC_OP_EFLAGS; break; case 4: /* 286 call gate */ case 12: /* 386 call gate */ @@ -1834,6 +1835,7 @@ void helper_lcall_protected_T0_T1(int shift, int next_eip_addend) if (dpl < cpl || dpl < rpl) raise_exception_err(EXCP0D_GPF, new_cs & 0xfffc); switch_tss(new_cs, e1, e2, SWITCH_TSS_CALL, next_eip); + CC_OP = CC_OP_EFLAGS; return; case 4: /* 286 call gate */ case 12: /* 386 call gate */