summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authormjg <mjg@FreeBSD.org>2014-03-25 23:30:35 +0000
committermjg <mjg@FreeBSD.org>2014-03-25 23:30:35 +0000
commit028af9e58bfeb70aec45be43539d48d5ab95246d (patch)
treefa1365d3100aef7757af5ebe00b14bcaf321d226 /sys/kern
parent6131eec5de478c13b397c906b072a2574e96535d (diff)
downloadFreeBSD-src-028af9e58bfeb70aec45be43539d48d5ab95246d.zip
FreeBSD-src-028af9e58bfeb70aec45be43539d48d5ab95246d.tar.gz
Document a known problem with handling the process intended to receive
SIGIO in /dev/devctl. Suggested by: adrian MFC after: 6 days
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/subr_bus.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/sys/kern/subr_bus.c b/sys/kern/subr_bus.c
index 45d6b35..b5d4a16 100644
--- a/sys/kern/subr_bus.c
+++ b/sys/kern/subr_bus.c
@@ -490,6 +490,21 @@ devioctl(struct cdev *dev, u_long cmd, caddr_t data, int fflag, struct thread *t
devsoftc.nonblock = 0;
return (0);
case FIOASYNC:
+ /*
+ * FIXME:
+ * Since this is a simple assignment there is no guarantee that
+ * devsoftc.async_proc consumers will get a valid pointer.
+ *
+ * Example scenario where things break (processes A and B):
+ * 1. A opens devctl
+ * 2. A sends fd to B
+ * 3. B sets itself as async_proc
+ * 4. B exits
+ *
+ * However, normally this requires root privileges and the only
+ * in-tree consumer does not behave in a dangerous way so the
+ * issue is not critical.
+ */
if (*(int*)data)
devsoftc.async_proc = td->td_proc;
else
@@ -575,6 +590,7 @@ devctl_queue_data_f(char *data, int flags)
cv_broadcast(&devsoftc.cv);
mtx_unlock(&devsoftc.mtx);
selwakeup(&devsoftc.sel);
+ /* XXX see a comment in devioctl */
p = devsoftc.async_proc;
if (p != NULL) {
PROC_LOCK(p);
OpenPOWER on IntegriCloud