Module Name: src Committed By: bouyer Date: Wed Mar 22 22:33:32 UTC 2017
Modified Files: src/sys/arch/xen/xenbus: xenbus_dev.c Log Message: On second through, it may be possible to have a NULL kfs_v in read and write (if we're not the LWP which did the open). Add the appropriate locks and checks. To generate a diff of this commit: cvs rdiff -u -r1.11 -r1.12 src/sys/arch/xen/xenbus/xenbus_dev.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/arch/xen/xenbus/xenbus_dev.c diff -u src/sys/arch/xen/xenbus/xenbus_dev.c:1.11 src/sys/arch/xen/xenbus/xenbus_dev.c:1.12 --- src/sys/arch/xen/xenbus/xenbus_dev.c:1.11 Wed Mar 22 21:21:39 2017 +++ src/sys/arch/xen/xenbus/xenbus_dev.c Wed Mar 22 22:33:32 2017 @@ -1,4 +1,4 @@ -/* $NetBSD: xenbus_dev.c,v 1.11 2017/03/22 21:21:39 bouyer Exp $ */ +/* $NetBSD: xenbus_dev.c,v 1.12 2017/03/22 22:33:32 bouyer Exp $ */ /* * xenbus_dev.c * @@ -31,7 +31,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: xenbus_dev.c,v 1.11 2017/03/22 21:21:39 bouyer Exp $"); +__KERNEL_RCSID(0, "$NetBSD: xenbus_dev.c,v 1.12 2017/03/22 22:33:32 bouyer Exp $"); #include "opt_xen.h" @@ -153,13 +153,19 @@ xenbus_dev_read(void *v) } */ *ap = v; struct kernfs_node *kfs = VTOKERN(ap->a_vp); struct uio *uio = ap->a_uio; - struct xenbus_dev_data *u = kfs->kfs_v; + struct xenbus_dev_data *u; struct xenbus_dev_lwp *xlwp; int err; off_t offset; - KASSERT(u != NULL); + mutex_enter(&xenbus_dev_open_mtx); + u = kfs->kfs_v; + if (u == NULL) { + mutex_exit(&xenbus_dev_open_mtx); + return EBADF; + } mutex_enter(&u->mtx); + mutex_exit(&xenbus_dev_open_mtx); SLIST_FOREACH(xlwp, &u->lwps, lwp_next) { if (xlwp->lwp == curlwp) { break; @@ -221,15 +227,21 @@ xenbus_dev_write(void *v) struct kernfs_node *kfs = VTOKERN(ap->a_vp); struct uio *uio = ap->a_uio; - struct xenbus_dev_data *u = kfs->kfs_v; + struct xenbus_dev_data *u; struct xenbus_dev_lwp *xlwp; struct xenbus_dev_transaction *trans; void *reply; int err; size_t size; - KASSERT(u != NULL); + mutex_enter(&xenbus_dev_open_mtx); + u = kfs->kfs_v; + if (u == NULL) { + mutex_exit(&xenbus_dev_open_mtx); + return EBADF; + } mutex_enter(&u->mtx); + mutex_exit(&xenbus_dev_open_mtx); SLIST_FOREACH(xlwp, &u->lwps, lwp_next) { if (xlwp->lwp == curlwp) { break;