Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/usermode/target/i386 Use knowledge of mcontext for ...



details:   https://anonhg.NetBSD.org/src/rev/9ced36d1913d
branches:  trunk
changeset: 361913:9ced36d1913d
user:      reinoud <reinoud%NetBSD.org@localhost>
date:      Fri May 18 20:21:14 2018 +0000

description:
Use knowledge of mcontext for i386 support

diffstat:

 sys/arch/usermode/target/i386/cpu_i386.c |  29 ++++++++++++-----------------
 1 files changed, 12 insertions(+), 17 deletions(-)

diffs (115 lines):

diff -r 520830228268 -r 9ced36d1913d sys/arch/usermode/target/i386/cpu_i386.c
--- a/sys/arch/usermode/target/i386/cpu_i386.c  Fri May 18 20:11:48 2018 +0000
+++ b/sys/arch/usermode/target/i386/cpu_i386.c  Fri May 18 20:21:14 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu_i386.c,v 1.4 2012/03/03 21:15:16 reinoud Exp $ */
+/* $NetBSD: cpu_i386.c,v 1.5 2018/05/18 20:21:14 reinoud Exp $ */
 
 /*-
  * Copyright (c) 2011 Reinoud Zandijk <reinoud%netbsd.org@localhost>
@@ -27,14 +27,9 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 
-/*
- * Note that this machdep.c uses the `dummy' mcontext_t defined for usermode.
- * This is basicly a blob of PAGE_SIZE big. We might want to switch over to
- * non-generic mcontext_t's one day, but will this break non-NetBSD hosts?
- */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpu_i386.c,v 1.4 2012/03/03 21:15:16 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpu_i386.c,v 1.5 2018/05/18 20:21:14 reinoud Exp $");
 
 #include <sys/types.h>
 #include <sys/systm.h>
@@ -117,7 +112,7 @@
        KASSERT(mutex_owned(p->p_lock));
 
        ucp = &pcb->pcb_userret_ucp;
-       reg = (register_t *) &ucp->uc_mcontext;
+       reg = (register_t *) &ucp->uc_mcontext.__gregs;
 #if 0
        thunk_printf("%s: ", __func__);
        thunk_printf("flags %d, ", (int) ksi->ksi_flags);
@@ -198,7 +193,7 @@
 
        /* set up the user context */
        ucp = &pcb->pcb_userret_ucp;
-       reg = (int *) &ucp->uc_mcontext;
+       reg = (int *) &ucp->uc_mcontext.__gregs;
        for (i = 4; i < 11; i++)
                reg[i] = 0;
 
@@ -228,7 +223,7 @@
 void
 md_syscall_get_syscallnumber(ucontext_t *ucp, uint32_t *code)
 {
-       uint *reg = (int *) &ucp->uc_mcontext;
+       uint *reg = (int *) &ucp->uc_mcontext.__gregs;
        *code = reg[11];                        /* EAX */
 }
 
@@ -236,7 +231,7 @@
 md_syscall_getargs(lwp_t *l, ucontext_t *ucp, int nargs, int argsize,
        register_t *args)
 {
-       uint *reg = (int *) &ucp->uc_mcontext;
+       uint *reg = (int *) &ucp->uc_mcontext.__gregs;
        register_t *sp = (register_t *) reg[17];/* ESP */
        int ret;
 
@@ -250,7 +245,7 @@
 md_syscall_set_returnargs(lwp_t *l, ucontext_t *ucp,
        int error, register_t *rval)
 {
-       register_t *reg = (register_t *) &ucp->uc_mcontext;
+       register_t *reg = (register_t *) &ucp->uc_mcontext.__gregs;
 
        reg[16] &= ~PSL_C;              /* EFL */
        if (error > 0) {
@@ -270,7 +265,7 @@
 md_get_pc(ucontext_t *ucp)
 {
        KASSERT(ucp);
-       register_t *reg = (register_t *) &ucp->uc_mcontext;
+       register_t *reg = (register_t *) &ucp->uc_mcontext.__gregs;
 
        return reg[14];                 /* EIP */
 }
@@ -279,7 +274,7 @@
 md_get_sp(ucontext_t *ucp)
 {
        KASSERT(ucp);
-       register_t *reg = (register_t *) &ucp->uc_mcontext;
+       register_t *reg = (register_t *) &ucp->uc_mcontext.__gregs;
 
        return reg[17];                 /* ESP */
 }
@@ -307,7 +302,7 @@
 md_syscall_get_opcode(ucontext_t *ucp, uint32_t *opcode)
 {
        KASSERT(ucp);
-       register_t *reg = (register_t *) &ucp->uc_mcontext;
+       register_t *reg = (register_t *) &ucp->uc_mcontext.__gregs;
 //     uint8_t  *p8  = (uint8_t *) (reg[14]);
        uint16_t *p16 = (uint16_t*) (reg[14]);  /* EIP */
 
@@ -328,7 +323,7 @@
 md_syscall_inc_pc(ucontext_t *ucp, uint32_t opcode)
 {
        KASSERT(ucp);
-       uint *reg = (int *) &ucp->uc_mcontext;
+       uint *reg = (int *) &ucp->uc_mcontext.__gregs;
 
        /* advance program counter */
        switch (opcode) {
@@ -349,7 +344,7 @@
 md_syscall_dec_pc(ucontext_t *ucp, uint32_t opcode)
 {
        KASSERT(ucp);
-       uint *reg = (int *) &ucp->uc_mcontext;
+       uint *reg = (int *) &ucp->uc_mcontext.__gregs;
 
        switch (opcode) {
        case 0xff0f:    /* UD1      */



Home | Main Index | Thread Index | Old Index