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 fix copystr/copyinstr/copyoutstr t...
details: https://anonhg.NetBSD.org/src/rev/131a439e92be
branches: trunk
changeset: 758579:131a439e92be
user: pooka <pooka%NetBSD.org@localhost>
date: Tue Nov 09 15:22:47 2010 +0000
description:
fix copystr/copyinstr/copyoutstr to return ENAMETOOLONG where appropriate
diffstat:
sys/rump/librump/rumpkern/rumpcopy.c | 51 ++++++++++++++++++++++++++++-------
1 files changed, 40 insertions(+), 11 deletions(-)
diffs (93 lines):
diff -r adc017d83ce3 -r 131a439e92be sys/rump/librump/rumpkern/rumpcopy.c
--- a/sys/rump/librump/rumpkern/rumpcopy.c Tue Nov 09 15:06:08 2010 +0000
+++ b/sys/rump/librump/rumpkern/rumpcopy.c Tue Nov 09 15:22:47 2010 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rumpcopy.c,v 1.7 2010/10/29 15:27:50 pooka Exp $ */
+/* $NetBSD: rumpcopy.c,v 1.8 2010/11/09 15:22: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.7 2010/10/29 15:27:50 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rumpcopy.c,v 1.8 2010/11/09 15:22:47 pooka Exp $");
#include <sys/param.h>
#include <sys/lwp.h>
@@ -82,36 +82,65 @@
int
copystr(const void *kfaddr, void *kdaddr, size_t len, size_t *done)
{
+ uint8_t *to = kdaddr;
+ const uint8_t *from = kfaddr;
+ size_t actlen = 0;
- strlcpy(kdaddr, kfaddr, len);
+ while (len-- > 0 && (*to++ = *from++) != 0)
+ actlen++;
+
+ if (len+1 == 0 && *(to-1) != 0)
+ return ENAMETOOLONG;
+
if (done)
- *done = strlen(kdaddr)+1; /* includes termination */
+ *done = actlen+1; /* + '\0' */
return 0;
}
int
copyinstr(const void *uaddr, void *kaddr, size_t len, size_t *done)
{
+ uint8_t *to;
+ int rv;
if (curproc->p_vmspace == &vmspace0)
- strlcpy(kaddr, uaddr, len);
- else
- rumpuser_sp_copyin(uaddr, kaddr, len);
+ return copystr(uaddr, kaddr, len, done);
+
+ if ((rv = rumpuser_sp_copyin(uaddr, kaddr, len)) != 0)
+ return rv;
+
+ /* figure out if we got a terminate string or not */
+ to = (uint8_t *)kaddr + len;
+ while (to != kaddr) {
+ if (*to == 0)
+ goto found;
+ to--;
+ }
+ return ENAMETOOLONG;
+
+ found:
if (done)
*done = strlen(kaddr)+1; /* includes termination */
+
return 0;
}
int
copyoutstr(const void *kaddr, void *uaddr, size_t len, size_t *done)
{
+ size_t slen;
if (curproc->p_vmspace == &vmspace0)
- strlcpy(uaddr, kaddr, len);
- else
- rumpuser_sp_copyout(kaddr, uaddr, len);
+ return copystr(kaddr, uaddr, len, done);
+
+ slen = strlen(kaddr)+1;
+ if (slen > len)
+ return ENAMETOOLONG;
+
+ rumpuser_sp_copyout(kaddr, uaddr, slen);
if (done)
- *done = strlen(uaddr)+1; /* includes termination */
+ *done = slen;
+
return 0;
}
Home |
Main Index |
Thread Index |
Old Index