summaryrefslogtreecommitdiff
path: root/sys/miscfs/procfs/procfs_mem.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/miscfs/procfs/procfs_mem.c')
-rw-r--r--sys/miscfs/procfs/procfs_mem.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/sys/miscfs/procfs/procfs_mem.c b/sys/miscfs/procfs/procfs_mem.c
index 8953fe1b665..a54b44d7293 100644
--- a/sys/miscfs/procfs/procfs_mem.c
+++ b/sys/miscfs/procfs/procfs_mem.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: procfs_mem.c,v 1.8 1998/08/30 13:42:14 pefo Exp $ */
+/* $OpenBSD: procfs_mem.c,v 1.9 1999/02/26 03:46:25 art Exp $ */
/* $NetBSD: procfs_mem.c,v 1.8 1996/02/09 22:40:50 christos Exp $ */
/*
@@ -57,8 +57,13 @@
#include <vm/vm_kern.h>
#include <vm/vm_page.h>
+#if defined(UVM)
+#include <uvm/uvm_extern.h>
+#endif
+
#define ISSET(t, f) ((t) & (f))
+#if !defined(UVM)
static int procfs_rwmem __P((struct proc *, struct uio *));
static int
@@ -203,6 +208,7 @@ procfs_rwmem(p, uio)
return (error);
}
+#endif
/*
* Copy data in and out of the target process.
@@ -224,8 +230,22 @@ procfs_domem(curp, p, pfs, uio)
if ((error = procfs_checkioperm(curp, p)) != 0)
return (error);
+#if defined(UVM)
+ /* XXXCDC: how should locking work here? */
+ if ((p->p_flag & P_WEXIT) || (p->p_vmspace->vm_refcnt < 1))
+ return(EFAULT);
+ PHOLD(p);
+ p->p_vmspace->vm_refcnt++; /* XXX */
+ error = uvm_io(&p->p_vmspace->vm_map, uio);
+ PRELE(p);
+ uvmspace_free(p->p_vmspace);
+#else
+ PHOLD(p);
+ error = procfs_rwmem(p, uio);
+ PRELE(p);
+#endif
- return (procfs_rwmem(p, uio));
+ return error;
}
/*