Source-Changes-HG archive

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

[src/trunk]: src/sys/rump/librump/rumpkern move copy-related routines to thei...



details:   https://anonhg.NetBSD.org/src/rev/3463187a7de3
branches:  trunk
changeset: 748750:3463187a7de3
user:      pooka <pooka%NetBSD.org@localhost>
date:      Wed Nov 04 17:01:45 2009 +0000

description:
move copy-related routines to their own module

diffstat:

 sys/rump/librump/rumpkern/Makefile.rumpkern |    7 +-
 sys/rump/librump/rumpkern/emul.c            |   78 +-------------------
 sys/rump/librump/rumpkern/rumpcopy.c        |  112 ++++++++++++++++++++++++++++
 3 files changed, 118 insertions(+), 79 deletions(-)

diffs (236 lines):

diff -r 1c3f6c114b7d -r 3463187a7de3 sys/rump/librump/rumpkern/Makefile.rumpkern
--- a/sys/rump/librump/rumpkern/Makefile.rumpkern       Wed Nov 04 16:55:20 2009 +0000
+++ b/sys/rump/librump/rumpkern/Makefile.rumpkern       Wed Nov 04 17:01:45 2009 +0000
@@ -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
 #
diff -r 1c3f6c114b7d -r 3463187a7de3 sys/rump/librump/rumpkern/emul.c
--- a/sys/rump/librump/rumpkern/emul.c  Wed Nov 04 16:55:20 2009 +0000
+++ b/sys/rump/librump/rumpkern/emul.c  Wed Nov 04 17:01:45 2009 +0000
@@ -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)
 {
diff -r 1c3f6c114b7d -r 3463187a7de3 sys/rump/librump/rumpkern/rumpcopy.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/rump/librump/rumpkern/rumpcopy.c      Wed Nov 04 17:01:45 2009 +0000
@@ -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;
+}
+



Home | Main Index | Thread Index | Old Index