Module Name: src
Committed By: jym
Date: Sun Oct 23 21:41:23 UTC 2011
Modified Files:
src/sys/kern: subr_workqueue.c
Log Message:
Turn a workqueue(9) name into an array in the struct workqueue, rather
than a const char *. This avoids keeping a reference to a string
owned by caller (string could be allocated on stack).
To generate a diff of this commit:
cvs rdiff -u -r1.31 -r1.32 src/sys/kern/subr_workqueue.c
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/subr_workqueue.c
diff -u src/sys/kern/subr_workqueue.c:1.31 src/sys/kern/subr_workqueue.c:1.32
--- src/sys/kern/subr_workqueue.c:1.31 Wed Jul 27 14:35:34 2011
+++ src/sys/kern/subr_workqueue.c Sun Oct 23 21:41:23 2011
@@ -1,4 +1,4 @@
-/* $NetBSD: subr_workqueue.c,v 1.31 2011/07/27 14:35:34 uebayasi Exp $ */
+/* $NetBSD: subr_workqueue.c,v 1.32 2011/10/23 21:41:23 jym Exp $ */
/*-
* Copyright (c)2002, 2005, 2006, 2007 YAMAMOTO Takashi,
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_workqueue.c,v 1.31 2011/07/27 14:35:34 uebayasi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_workqueue.c,v 1.32 2011/10/23 21:41:23 jym Exp $");
#include <sys/param.h>
#include <sys/cpu.h>
@@ -58,7 +58,7 @@ struct workqueue {
void *wq_arg;
int wq_flags;
- const char *wq_name;
+ char wq_name[MAXCOMLEN];
pri_t wq_prio;
void *wq_ptr;
};
@@ -142,8 +142,9 @@ workqueue_init(struct workqueue *wq, con
pri_t prio, int ipl)
{
+ strncpy(wq->wq_name, name, sizeof(wq->wq_name));
+
wq->wq_prio = prio;
- wq->wq_name = name;
wq->wq_func = callback_func;
wq->wq_arg = callback_arg;
}