summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authorimp <imp@FreeBSD.org>2010-04-25 19:13:08 +0000
committerimp <imp@FreeBSD.org>2010-04-25 19:13:08 +0000
commitedfae4ce2be1d27e2527723772ece3017874bf7b (patch)
tree01967bfff423a614e65ea17d938acf877ac2b255 /sys/kern
parent13325206c6f1da85d4846aa8ff4aa531a3a16409 (diff)
downloadFreeBSD-src-edfae4ce2be1d27e2527723772ece3017874bf7b.zip
FreeBSD-src-edfae4ce2be1d27e2527723772ece3017874bf7b.tar.gz
MFC r206916
Make sure that we free the passed in data message if we don't actually insert it onto the queue. Also, fix a mtx leak if someone turns off devctl while we're processing a messages. MFC after: 5 days
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/subr_bus.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/sys/kern/subr_bus.c b/sys/kern/subr_bus.c
index eaec75b..cd170a9 100644
--- a/sys/kern/subr_bus.c
+++ b/sys/kern/subr_bus.c
@@ -545,15 +545,16 @@ devctl_queue_data(char *data)
struct proc *p;
if (strlen(data) == 0)
- return;
+ goto out;
if (devctl_queue_length == 0)
- return;
+ goto out;
n1 = malloc(sizeof(*n1), M_BUS, M_NOWAIT);
if (n1 == NULL)
- return;
+ goto out;
n1->dei_data = data;
mtx_lock(&devsoftc.mtx);
if (devctl_queue_length == 0) {
+ mtx_unlock(&devsoftc.mtx);
free(n1->dei_data, M_BUS);
free(n1, M_BUS);
return;
@@ -577,6 +578,14 @@ devctl_queue_data(char *data)
psignal(p, SIGIO);
PROC_UNLOCK(p);
}
+ return;
+out:
+ /*
+ * We have to free data on all error paths since the caller
+ * assumes it will be free'd when this item is dequeued.
+ */
+ free(data, M_BUS);
+ return;
}
/**
OpenPOWER on IntegriCloud