Module Name:    src
Committed By:   pooka
Date:           Wed Nov  4 17:01:45 UTC 2009

Modified Files:
        src/sys/rump/librump/rumpkern: Makefile.rumpkern emul.c
Added Files:
        src/sys/rump/librump/rumpkern: rumpcopy.c

Log Message:
move copy-related routines to their own module


To generate a diff of this commit:
cvs rdiff -u -r1.58 -r1.59 src/sys/rump/librump/rumpkern/Makefile.rumpkern
cvs rdiff -u -r1.105 -r1.106 src/sys/rump/librump/rumpkern/emul.c
cvs rdiff -u -r0 -r1.1 src/sys/rump/librump/rumpkern/rumpcopy.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/librump/rumpkern/Makefile.rumpkern
diff -u src/sys/rump/librump/rumpkern/Makefile.rumpkern:1.58 src/sys/rump/librump/rumpkern/Makefile.rumpkern:1.59
--- src/sys/rump/librump/rumpkern/Makefile.rumpkern:1.58	Wed Nov  4 16:55:20 2009
+++ src/sys/rump/librump/rumpkern/Makefile.rumpkern	Wed Nov  4 17:01:45 2009
@@ -1,4 +1,4 @@
-#	$NetBSD: Makefile.rumpkern,v 1.58 2009/11/04 16:55:20 pooka Exp $
+#	$NetBSD: Makefile.rumpkern,v 1.59 2009/11/04 17:01:45 pooka Exp $
 #
 
 .include "${RUMPTOP}/Makefile.rump"
@@ -15,8 +15,9 @@
 #
 # Source modules, first the ones specifically implemented for librump.
 # 
-SRCS=	rump.c emul.c intr.c locks.c ltsleep.c percpu.c pool.c	\
-	scheduler.c sleepq.c sysproxy_socket.c vm.c
+SRCS=	rump.c rumpcopy.c emul.c intr.c locks.c ltsleep.c	\
+	percpu.c pool.c scheduler.c sleepq.c sysproxy_socket.c	\
+	vm.c
 
 # stubs
 #

Index: src/sys/rump/librump/rumpkern/emul.c
diff -u src/sys/rump/librump/rumpkern/emul.c:1.105 src/sys/rump/librump/rumpkern/emul.c:1.106
--- src/sys/rump/librump/rumpkern/emul.c:1.105	Wed Nov  4 16:55:20 2009
+++ src/sys/rump/librump/rumpkern/emul.c	Wed Nov  4 17:01:45 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: emul.c,v 1.105 2009/11/04 16:55:20 pooka Exp $	*/
+/*	$NetBSD: emul.c,v 1.106 2009/11/04 17:01:45 pooka Exp $	*/
 
 /*
  * Copyright (c) 2007 Antti Kantee.  All Rights Reserved.
@@ -28,7 +28,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: emul.c,v 1.105 2009/11/04 16:55:20 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: emul.c,v 1.106 2009/11/04 17:01:45 pooka Exp $");
 
 #include <sys/param.h>
 #include <sys/malloc.h>
@@ -117,80 +117,6 @@
 
 kmutex_t tty_lock;
 
-int
-copyin(const void *uaddr, void *kaddr, size_t len)
-{
-
-	if (curproc->p_vmspace == &rump_vmspace)
-		memcpy(kaddr, uaddr, len);
-	else
-		rump_sysproxy_copyin(uaddr, kaddr, len);
-	return 0;
-}
-
-int
-copyout(const void *kaddr, void *uaddr, size_t len)
-{
-
-	if (curproc->p_vmspace == &rump_vmspace)
-		memcpy(uaddr, kaddr, len);
-	else
-		rump_sysproxy_copyout(kaddr, uaddr, len);
-	return 0;
-}
-
-int
-subyte(void *uaddr, int byte)
-{
-
-	if (curproc->p_vmspace == &rump_vmspace)
-		*(char *)uaddr = byte;
-	else
-		rump_sysproxy_copyout(&byte, uaddr, 1);
-	return 0;
-}
-
-int
-copystr(const void *kfaddr, void *kdaddr, size_t len, size_t *done)
-{
-
-	return copyinstr(kfaddr, kdaddr, len, done);
-}
-
-int
-copyinstr(const void *uaddr, void *kaddr, size_t len, size_t *done)
-{
-
-	if (curproc->p_vmspace == &rump_vmspace)
-		strlcpy(kaddr, uaddr, len);
-	else
-		rump_sysproxy_copyin(uaddr, kaddr, len);
-	if (done)
-		*done = strlen(kaddr)+1; /* includes termination */
-	return 0;
-}
-
-int
-copyoutstr(const void *kaddr, void *uaddr, size_t len, size_t *done)
-{
-
-	if (curproc->p_vmspace == &rump_vmspace)
-		strlcpy(uaddr, kaddr, len);
-	else
-		rump_sysproxy_copyout(kaddr, uaddr, len);
-	if (done)
-		*done = strlen(uaddr)+1; /* includes termination */
-	return 0;
-}
-
-int
-kcopy(const void *src, void *dst, size_t len)
-{
-
-	memcpy(dst, src, len);
-	return 0;
-}
-
 devclass_t
 device_class(device_t dev)
 {

Added files:

Index: src/sys/rump/librump/rumpkern/rumpcopy.c
diff -u /dev/null src/sys/rump/librump/rumpkern/rumpcopy.c:1.1
--- /dev/null	Wed Nov  4 17:01:45 2009
+++ src/sys/rump/librump/rumpkern/rumpcopy.c	Wed Nov  4 17:01:45 2009
@@ -0,0 +1,112 @@
+/*	$NetBSD: rumpcopy.c,v 1.1 2009/11/04 17:01:45 pooka Exp $	*/
+
+/*
+ * Copyright (c) 2009 Antti Kantee.  All Rights Reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
+ * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: rumpcopy.c,v 1.1 2009/11/04 17:01:45 pooka Exp $");
+
+#include <sys/param.h>
+#include <sys/lwp.h>
+#include <sys/systm.h>
+
+#include <rump/rump.h>
+
+#include "rump_private.h"
+
+int
+copyin(const void *uaddr, void *kaddr, size_t len)
+{
+
+	if (curproc->p_vmspace == &rump_vmspace)
+		memcpy(kaddr, uaddr, len);
+	else
+		rump_sysproxy_copyin(uaddr, kaddr, len);
+	return 0;
+}
+
+int
+copyout(const void *kaddr, void *uaddr, size_t len)
+{
+
+	if (curproc->p_vmspace == &rump_vmspace)
+		memcpy(uaddr, kaddr, len);
+	else
+		rump_sysproxy_copyout(kaddr, uaddr, len);
+	return 0;
+}
+
+int
+subyte(void *uaddr, int byte)
+{
+
+	if (curproc->p_vmspace == &rump_vmspace)
+		*(char *)uaddr = byte;
+	else
+		rump_sysproxy_copyout(&byte, uaddr, 1);
+	return 0;
+}
+
+int
+copystr(const void *kfaddr, void *kdaddr, size_t len, size_t *done)
+{
+
+	return copyinstr(kfaddr, kdaddr, len, done);
+}
+
+int
+copyinstr(const void *uaddr, void *kaddr, size_t len, size_t *done)
+{
+
+	if (curproc->p_vmspace == &rump_vmspace)
+		strlcpy(kaddr, uaddr, len);
+	else
+		rump_sysproxy_copyin(uaddr, kaddr, len);
+	if (done)
+		*done = strlen(kaddr)+1; /* includes termination */
+	return 0;
+}
+
+int
+copyoutstr(const void *kaddr, void *uaddr, size_t len, size_t *done)
+{
+
+	if (curproc->p_vmspace == &rump_vmspace)
+		strlcpy(uaddr, kaddr, len);
+	else
+		rump_sysproxy_copyout(kaddr, uaddr, len);
+	if (done)
+		*done = strlen(uaddr)+1; /* includes termination */
+	return 0;
+}
+
+int
+kcopy(const void *src, void *dst, size_t len)
+{
+
+	memcpy(dst, src, len);
+	return 0;
+}
+

Reply via email to