Module Name: src Committed By: christos Date: Tue Nov 7 18:35:57 UTC 2017
Modified Files: src/sys/kern: kern_event.c kern_veriexec.c subr_devsw.c subr_kmem.c src/sys/sys: kmem.h Log Message: Add two utility functions to help use kmem with strings: kmem_strdupsize, kmem_strfree. To generate a diff of this commit: cvs rdiff -u -r1.96 -r1.97 src/sys/kern/kern_event.c cvs rdiff -u -r1.17 -r1.18 src/sys/kern/kern_veriexec.c cvs rdiff -u -r1.37 -r1.38 src/sys/kern/subr_devsw.c cvs rdiff -u -r1.63 -r1.64 src/sys/kern/subr_kmem.c cvs rdiff -u -r1.9 -r1.10 src/sys/sys/kmem.h Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/kern/kern_event.c diff -u src/sys/kern/kern_event.c:1.96 src/sys/kern/kern_event.c:1.97 --- src/sys/kern/kern_event.c:1.96 Wed Oct 25 04:12:39 2017 +++ src/sys/kern/kern_event.c Tue Nov 7 13:35:57 2017 @@ -1,4 +1,4 @@ -/* $NetBSD: kern_event.c,v 1.96 2017/10/25 08:12:39 maya Exp $ */ +/* $NetBSD: kern_event.c,v 1.97 2017/11/07 18:35:57 christos Exp $ */ /*- * Copyright (c) 2008, 2009 The NetBSD Foundation, Inc. @@ -58,7 +58,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: kern_event.c,v 1.96 2017/10/25 08:12:39 maya Exp $"); +__KERNEL_RCSID(0, "$NetBSD: kern_event.c,v 1.97 2017/11/07 18:35:57 christos Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -370,9 +370,7 @@ kfilter_register(const char *name, const /* Adding new slot */ kfilter = &user_kfilters[user_kfilterc++]; reuse: - kfilter->namelen = strlen(name) + 1; - kfilter->name = kmem_alloc(kfilter->namelen, KM_SLEEP); - memcpy(__UNCONST(kfilter->name), name, kfilter->namelen); + kfilter->name = kmem_strdupsize(name, &kfilter->namelen, KM_SLEEP); kfilter->filter = (kfilter - user_kfilters) + EVFILT_SYSCOUNT; Index: src/sys/kern/kern_veriexec.c diff -u src/sys/kern/kern_veriexec.c:1.17 src/sys/kern/kern_veriexec.c:1.18 --- src/sys/kern/kern_veriexec.c:1.17 Wed Sep 13 18:24:46 2017 +++ src/sys/kern/kern_veriexec.c Tue Nov 7 13:35:57 2017 @@ -1,4 +1,4 @@ -/* $NetBSD: kern_veriexec.c,v 1.17 2017/09/13 22:24:46 sevan Exp $ */ +/* $NetBSD: kern_veriexec.c,v 1.18 2017/11/07 18:35:57 christos Exp $ */ /*- * Copyright (c) 2005, 2006 Elad Efrat <e...@netbsd.org> @@ -29,7 +29,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: kern_veriexec.c,v 1.17 2017/09/13 22:24:46 sevan Exp $"); +__KERNEL_RCSID(0, "$NetBSD: kern_veriexec.c,v 1.18 2017/11/07 18:35:57 christos Exp $"); #include "opt_veriexec.h" @@ -1104,9 +1104,8 @@ veriexec_file_add(struct lwp *l, prop_di vfe->status = FINGERPRINT_NOTEVAL; if (prop_bool_true(prop_dictionary_get(dict, "keep-filename"))) { - vfe->filename_len = strlen(file) + 1; - vfe->filename = kmem_alloc(vfe->filename_len, KM_SLEEP); - strlcpy(vfe->filename, file, vfe->filename_len); + vfe->filename = kmem_strdupsize(file, &vfe->filename_len, + KM_SLEEP); } else vfe->filename = NULL; Index: src/sys/kern/subr_devsw.c diff -u src/sys/kern/subr_devsw.c:1.37 src/sys/kern/subr_devsw.c:1.38 --- src/sys/kern/subr_devsw.c:1.37 Tue Apr 25 04:46:38 2017 +++ src/sys/kern/subr_devsw.c Tue Nov 7 13:35:57 2017 @@ -1,4 +1,4 @@ -/* $NetBSD: subr_devsw.c,v 1.37 2017/04/25 08:46:38 pgoyette Exp $ */ +/* $NetBSD: subr_devsw.c,v 1.38 2017/11/07 18:35:57 christos Exp $ */ /*- * Copyright (c) 2001, 2002, 2007, 2008 The NetBSD Foundation, Inc. @@ -69,7 +69,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: subr_devsw.c,v 1.37 2017/04/25 08:46:38 pgoyette Exp $"); +__KERNEL_RCSID(0, "$NetBSD: subr_devsw.c,v 1.38 2017/11/07 18:35:57 christos Exp $"); #ifdef _KERNEL_OPT #include "opt_dtrace.h" @@ -128,7 +128,6 @@ devsw_attach(const char *devname, struct devsw_conv *conv; char *name; int error, i; - size_t len; if (devname == NULL || cdev == NULL) return (EINVAL); @@ -204,14 +203,12 @@ devsw_attach(const char *devname, max_devsw_convs = new_convs; } - len = strlen(devname) + 1; - name = kmem_alloc(len, KM_NOSLEEP); + name = kmem_strdupsize(devname, NULL, KM_NOSLEEP); if (name == NULL) { devsw_detach_locked(bdev, cdev); error = ENOMEM; goto fail; } - strlcpy(name, devname, len); devsw_conv[i].d_name = name; devsw_conv[i].d_bmajor = *bmajor; Index: src/sys/kern/subr_kmem.c diff -u src/sys/kern/subr_kmem.c:1.63 src/sys/kern/subr_kmem.c:1.64 --- src/sys/kern/subr_kmem.c:1.63 Wed Apr 12 16:05:54 2017 +++ src/sys/kern/subr_kmem.c Tue Nov 7 13:35:57 2017 @@ -1,4 +1,4 @@ -/* $NetBSD: subr_kmem.c,v 1.63 2017/04/12 20:05:54 christos Exp $ */ +/* $NetBSD: subr_kmem.c,v 1.64 2017/11/07 18:35:57 christos Exp $ */ /*- * Copyright (c) 2009-2015 The NetBSD Foundation, Inc. @@ -100,7 +100,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: subr_kmem.c,v 1.63 2017/04/12 20:05:54 christos Exp $"); +__KERNEL_RCSID(0, "$NetBSD: subr_kmem.c,v 1.64 2017/11/07 18:35:57 christos Exp $"); #ifdef _KERNEL_OPT #include "opt_kmem.h" @@ -527,6 +527,29 @@ kmem_asprintf(const char *fmt, ...) return str; } +char * +kmem_strdupsize(const char *str, size_t *lenp, km_flag_t flags) +{ + size_t len = strlen(str) + 1; + char *ptr = kmem_alloc(len, flags); + if (ptr == NULL) + return NULL; + + if (lenp) + *lenp = len; + memcpy(ptr, str, len); + return ptr; +} + +void +kmem_strfree(char *str) +{ + if (str == NULL) + return; + + kmem_free(str, strlen(str) + 1); +} + /* ------------------ DEBUG / DIAGNOSTIC ------------------ */ #if defined(KMEM_POISON) || defined(KMEM_REDZONE) Index: src/sys/sys/kmem.h diff -u src/sys/sys/kmem.h:1.9 src/sys/sys/kmem.h:1.10 --- src/sys/sys/kmem.h:1.9 Sat Feb 4 22:40:08 2012 +++ src/sys/sys/kmem.h Tue Nov 7 13:35:57 2017 @@ -1,4 +1,4 @@ -/* $NetBSD: kmem.h,v 1.9 2012/02/05 03:40:08 rmind Exp $ */ +/* $NetBSD: kmem.h,v 1.10 2017/11/07 18:35:57 christos Exp $ */ /*- * Copyright (c)2006 YAMAMOTO Takashi, @@ -46,6 +46,9 @@ void kmem_intr_free(void *, size_t); char * kmem_asprintf(const char *, ...) __printflike(1, 2); +char * kmem_strdupsize(const char *, size_t *, km_flag_t); +void kmem_strfree(char *); + /* * km_flag_t values: */