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);
 		}
 	}

Reply via email to