Module Name: src
Committed By: pgoyette
Date: Sat Jan 9 07:27:31 UTC 2016
Modified Files:
src/sys/dev/filemon: filemon.c
Log Message:
When following process parent pointers, lock the new (parent) before
releasing the initial process.
To generate a diff of this commit:
cvs rdiff -u -r1.26 -r1.27 src/sys/dev/filemon/filemon.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/dev/filemon/filemon.c
diff -u src/sys/dev/filemon/filemon.c:1.26 src/sys/dev/filemon/filemon.c:1.27
--- src/sys/dev/filemon/filemon.c:1.26 Fri Jan 8 08:57:14 2016
+++ src/sys/dev/filemon/filemon.c Sat Jan 9 07:27:31 2016
@@ -1,4 +1,4 @@
-/* $NetBSD: filemon.c,v 1.26 2016/01/08 08:57:14 pgoyette Exp $ */
+/* $NetBSD: filemon.c,v 1.27 2016/01/09 07:27:31 pgoyette Exp $ */
/*
* Copyright (c) 2010, Juniper Networks, Inc.
*
@@ -25,7 +25,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: filemon.c,v 1.26 2016/01/08 08:57:14 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: filemon.c,v 1.27 2016/01/09 07:27:31 pgoyette Exp $");
#include <sys/param.h>
#include <sys/kernel.h>
@@ -154,13 +154,14 @@ filemon_pid_check(struct proc * p)
struct filemon *filemon;
struct proc * lp;
+ KASSERT(p != NULL);
if (!TAILQ_EMPTY(&filemons_inuse)) {
+ /*
+ * make sure p cannot exit
+ * until we have moved on to p_pptr
+ */
+ rw_enter(&p->p_reflock, RW_READER);
while (p) {
- /*
- * make sure p cannot exit
- * until we have moved on to p_pptr
- */
- rw_enter(&p->p_reflock, RW_READER);
TAILQ_FOREACH(filemon, &filemons_inuse, fm_link) {
if (p->p_pid == filemon->fm_pid) {
rw_exit(&p->p_reflock);
@@ -169,6 +170,10 @@ filemon_pid_check(struct proc * p)
}
lp = p;
p = p->p_pptr;
+
+ /* lock parent before releasing child */
+ if (p != NULL)
+ rw_enter(&p->p_reflock, RW_READER);
rw_exit(&lp->p_reflock);
}
}