Module Name: src
Committed By: pooka
Date: Wed Nov 17 21:48:08 UTC 2010
Modified Files:
src/sys/rump/include/rump: rump_syscalls.h
src/sys/rump/librump/rumpkern: rump_syscalls.c
Log Message:
regen: optimize local syscall path a bit
To generate a diff of this commit:
cvs rdiff -u -r1.33 -r1.34 src/sys/rump/include/rump/rump_syscalls.h
cvs rdiff -u -r1.54 -r1.55 src/sys/rump/librump/rumpkern/rump_syscalls.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/rump/include/rump/rump_syscalls.h
diff -u src/sys/rump/include/rump/rump_syscalls.h:1.33 src/sys/rump/include/rump/rump_syscalls.h:1.34
--- src/sys/rump/include/rump/rump_syscalls.h:1.33 Thu Nov 11 14:48:13 2010
+++ src/sys/rump/include/rump/rump_syscalls.h Wed Nov 17 21:48:07 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: rump_syscalls.h,v 1.33 2010/11/11 14:48:13 pooka Exp $ */
+/* $NetBSD: rump_syscalls.h,v 1.34 2010/11/17 21:48:07 pooka Exp $ */
/*
* System call protos in rump namespace.
Index: src/sys/rump/librump/rumpkern/rump_syscalls.c
diff -u src/sys/rump/librump/rumpkern/rump_syscalls.c:1.54 src/sys/rump/librump/rumpkern/rump_syscalls.c:1.55
--- src/sys/rump/librump/rumpkern/rump_syscalls.c:1.54 Thu Nov 11 14:48:14 2010
+++ src/sys/rump/librump/rumpkern/rump_syscalls.c Wed Nov 17 21:48:07 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: rump_syscalls.c,v 1.54 2010/11/11 14:48:14 pooka Exp $ */
+/* $NetBSD: rump_syscalls.c,v 1.55 2010/11/17 21:48:07 pooka Exp $ */
/*
* System call vector and marshalling for rump.
@@ -8,7 +8,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rump_syscalls.c,v 1.54 2010/11/11 14:48:14 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rump_syscalls.c,v 1.55 2010/11/17 21:48:07 pooka Exp $");
#include <sys/param.h>
#include <sys/fstypes.h>
@@ -25,16 +25,21 @@
#define rsys_seterrno(error) errno = error
#define rsys_alias(a,b)
#else
+#include <sys/syscallvar.h>
+
#include <rump/rumpuser.h>
#include "rump_private.h"
static int
rsys_syscall(int num, void *data, size_t dlen, register_t *retval)
{
+ struct sysent *callp = rump_sysent + num;
int rv;
+ KASSERT(num > 0 && num < SYS_NSYSENT);
+
rump_schedule();
- rv = rump_syscall(num, data, retval);
+ rv = sy_call(callp, curlwp, data, retval);
rump_unschedule();
return rv;