Commit a52c757c9f98311c3ba22744d609caa767b899e1
1 parent
970a87a6
fixed case where SS != USER_DS (fixes dosemu DPMI emulation)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@256 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
14 additions
and
13 deletions
linux-user/signal.c
| ... | ... | @@ -517,10 +517,10 @@ setup_sigcontext(struct target_sigcontext *sc, struct target_fpstate *fpstate, |
| 517 | 517 | { |
| 518 | 518 | int err = 0; |
| 519 | 519 | |
| 520 | - err |= __put_user(env->segs[R_GS], (unsigned int *)&sc->gs); | |
| 521 | - err |= __put_user(env->segs[R_FS], (unsigned int *)&sc->fs); | |
| 522 | - err |= __put_user(env->segs[R_ES], (unsigned int *)&sc->es); | |
| 523 | - err |= __put_user(env->segs[R_DS], (unsigned int *)&sc->ds); | |
| 520 | + err |= __put_user(env->segs[R_GS].selector, (unsigned int *)&sc->gs); | |
| 521 | + err |= __put_user(env->segs[R_FS].selector, (unsigned int *)&sc->fs); | |
| 522 | + err |= __put_user(env->segs[R_ES].selector, (unsigned int *)&sc->es); | |
| 523 | + err |= __put_user(env->segs[R_DS].selector, (unsigned int *)&sc->ds); | |
| 524 | 524 | err |= __put_user(env->regs[R_EDI], &sc->edi); |
| 525 | 525 | err |= __put_user(env->regs[R_ESI], &sc->esi); |
| 526 | 526 | err |= __put_user(env->regs[R_EBP], &sc->ebp); |
| ... | ... | @@ -532,10 +532,10 @@ setup_sigcontext(struct target_sigcontext *sc, struct target_fpstate *fpstate, |
| 532 | 532 | err |= __put_user(env->exception_index, &sc->trapno); |
| 533 | 533 | err |= __put_user(env->error_code, &sc->err); |
| 534 | 534 | err |= __put_user(env->eip, &sc->eip); |
| 535 | - err |= __put_user(env->segs[R_CS], (unsigned int *)&sc->cs); | |
| 535 | + err |= __put_user(env->segs[R_CS].selector, (unsigned int *)&sc->cs); | |
| 536 | 536 | err |= __put_user(env->eflags, &sc->eflags); |
| 537 | 537 | err |= __put_user(env->regs[R_ESP], &sc->esp_at_signal); |
| 538 | - err |= __put_user(env->segs[R_SS], (unsigned int *)&sc->ss); | |
| 538 | + err |= __put_user(env->segs[R_SS].selector, (unsigned int *)&sc->ss); | |
| 539 | 539 | |
| 540 | 540 | cpu_x86_fsave(env, (void *)fpstate, 1); |
| 541 | 541 | fpstate->status = fpstate->sw; |
| ... | ... | @@ -544,7 +544,7 @@ setup_sigcontext(struct target_sigcontext *sc, struct target_fpstate *fpstate, |
| 544 | 544 | |
| 545 | 545 | /* non-iBCS2 extensions.. */ |
| 546 | 546 | err |= __put_user(mask, &sc->oldmask); |
| 547 | - err |= __put_user(env->cr2, &sc->cr2); | |
| 547 | + err |= __put_user(env->cr[2], &sc->cr2); | |
| 548 | 548 | return err; |
| 549 | 549 | } |
| 550 | 550 | |
| ... | ... | @@ -567,13 +567,14 @@ get_sigframe(struct emulated_sigaction *ka, CPUX86State *env, size_t frame_size) |
| 567 | 567 | } |
| 568 | 568 | |
| 569 | 569 | /* This is the legacy signal stack switching. */ |
| 570 | - else if ((regs->xss & 0xffff) != __USER_DS && | |
| 571 | - !(ka->sa.sa_flags & SA_RESTORER) && | |
| 572 | - ka->sa.sa_restorer) { | |
| 573 | - esp = (unsigned long) ka->sa.sa_restorer; | |
| 574 | - } | |
| 570 | + else | |
| 575 | 571 | #endif |
| 576 | - return (void *)((esp - frame_size) & -8ul); | |
| 572 | + if ((env->segs[R_SS].selector & 0xffff) != __USER_DS && | |
| 573 | + !(ka->sa.sa_flags & TARGET_SA_RESTORER) && | |
| 574 | + ka->sa.sa_restorer) { | |
| 575 | + esp = (unsigned long) ka->sa.sa_restorer; | |
| 576 | + } | |
| 577 | + return (void *)((esp - frame_size) & -8ul); | |
| 577 | 578 | } |
| 578 | 579 | |
| 579 | 580 | static void setup_frame(int sig, struct emulated_sigaction *ka, | ... | ... |