Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/usermode/usermode Add skeleton for possible system ...



details:   https://anonhg.NetBSD.org/src/rev/9db1e4319343
branches:  trunk
changeset: 769373:9db1e4319343
user:      reinoud <reinoud%NetBSD.org@localhost>
date:      Wed Sep 07 14:03:49 2011 +0000

description:
Add skeleton for possible system call implementation

diffstat:

 sys/arch/usermode/usermode/trap.c |  26 +++++++++++++++++++++-----
 1 files changed, 21 insertions(+), 5 deletions(-)

diffs (54 lines):

diff -r 262e6552a129 -r 9db1e4319343 sys/arch/usermode/usermode/trap.c
--- a/sys/arch/usermode/usermode/trap.c Wed Sep 07 13:37:49 2011 +0000
+++ b/sys/arch/usermode/usermode/trap.c Wed Sep 07 14:03:49 2011 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: trap.c,v 1.32 2011/09/07 10:19:40 reinoud Exp $ */
+/* $NetBSD: trap.c,v 1.33 2011/09/07 14:03:49 reinoud Exp $ */
 
 /*-
  * Copyright (c) 2011 Reinoud Zandijk <reinoud%netbsd.org@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.32 2011/09/07 10:19:40 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.33 2011/09/07 14:03:49 reinoud Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
@@ -43,6 +43,9 @@
 #include <machine/pmap.h>
 #include <machine/thunk.h>
 
+#include <sys/syscallvar.h>
+#include <sys/syscallargs.h>
+
 //#include <machine/ctlreg.h>
 //#include <machine/trap.h>
 //#include <machine/instr.h>
@@ -281,9 +284,22 @@
                printf("\n");
 #endif
 
-               /* TODO MD syscall pre-fixup  */
-               /* TODO system call issueing  */
-               /* TODO MD syscall post-fixup */
+#if 0
+               /* MD syscall pre-fixup: extract `trapframe' from the MD ctx */
+               syscall_pre_fixup(info->si_addr, ctx, &pcb->pcb_tf);
+
+printf("retrieved opcode %"PRIiPTR"\n", opcode);
+
+               /* system call issueing  */
+               curcpu()->ci_data.cpu_nsyscall++;
+
+               /* XXX do we want do do emulation? */
+               LWP_CACHE_CREDS(l, l->l_proc);
+               syscall(l, &pcb->pcb_tf);
+
+               /* MD syscall post-fixup : convert `trapframe' back to MD ctx */
+               syscall_post_fixup(info->si_addr, ctx, &pcb->pcb_tf);
+#endif
 
                panic("illegal instruction encountered\n");
        }



Home | Main Index | Thread Index | Old Index