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 Implement poor man's (or woman's) ...



details:   https://anonhg.NetBSD.org/src/rev/d1bb11ff1553
branches:  trunk
changeset: 756327:d1bb11ff1553
user:      pooka <pooka%NetBSD.org@localhost>
date:      Mon Jul 12 21:00:47 2010 +0000

description:
Implement poor man's (or woman's) fault handler (or handlim).

from Stan (or Loretta)

diffstat:

 sys/rump/librump/rumpkern/rumpcopy.c |  18 ++++++++++++------
 1 files changed, 12 insertions(+), 6 deletions(-)

diffs (50 lines):

diff -r 6329e2671937 -r d1bb11ff1553 sys/rump/librump/rumpkern/rumpcopy.c
--- a/sys/rump/librump/rumpkern/rumpcopy.c      Mon Jul 12 16:08:52 2010 +0000
+++ b/sys/rump/librump/rumpkern/rumpcopy.c      Mon Jul 12 21:00:47 2010 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rumpcopy.c,v 1.3 2010/06/10 21:40:42 pooka Exp $       */
+/*     $NetBSD: rumpcopy.c,v 1.4 2010/07/12 21:00:47 pooka Exp $       */
 
 /*
  * Copyright (c) 2009 Antti Kantee.  All Rights Reserved.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rumpcopy.c,v 1.3 2010/06/10 21:40:42 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rumpcopy.c,v 1.4 2010/07/12 21:00:47 pooka Exp $");
 
 #include <sys/param.h>
 #include <sys/lwp.h>
@@ -40,10 +40,13 @@
 copyin(const void *uaddr, void *kaddr, size_t len)
 {
 
-       if (curproc->p_vmspace == &vmspace0)
+       if (curproc->p_vmspace == &vmspace0) {
+               if (uaddr == NULL)
+                       return EFAULT;
                memcpy(kaddr, uaddr, len);
-       else
+       } else {
                rump_sysproxy_copyin(uaddr, kaddr, len);
+       }
        return 0;
 }
 
@@ -51,10 +54,13 @@
 copyout(const void *kaddr, void *uaddr, size_t len)
 {
 
-       if (curproc->p_vmspace == &vmspace0)
+       if (curproc->p_vmspace == &vmspace0) {
+               if (uaddr == NULL)
+                       return EFAULT;
                memcpy(uaddr, kaddr, len);
-       else
+       } else {
                rump_sysproxy_copyout(kaddr, uaddr, len);
+       }
        return 0;
 }
 



Home | Main Index | Thread Index | Old Index