git: kernel: Remove an extra p_lock == 0 check

Matthew Dillon dillon at apollo.backplane.com
Thu Jun 2 13:38:38 PDT 2011


:commit 4a7e6f5530dd5eb9ca5195aeb18a0ebd59b0fa41
:Author: YONETANI Tomokazu <y0netan1 at dragonflybsd.org>
:Date:   Thu Jun 2 14:17:46 2011 +0900
:
:    kernel: Remove an extra p_lock == 0 check
:    
:    proc_remove_zombie() waits for p_lock to drop to zero before removing
:    the process off zombproc, so this assertion is not needed (any more).
:
:Summary of changes:
: sys/kern/kern_exit.c |    1 -
: 1 files changed, 0 insertions(+), 1 deletions(-)
:
:http://gitweb.dragonflybsd.org/dragonfly.git/commitdiff/4a7e6f5530dd5eb9ca5195aeb18a0ebd59b0fa41
:

    I think we need one more addition.  Since p_lock can be acquired during
    the process removal there need to be a final wait loop after the proc
    has been removed from all queues, just before the kfree(p).  It will be
    a very rare case but it definitely can still occur if e.g. the SYSCTL_OUT
    code blocks on a VM fault or something like that.

    (untested patch below)

					-Matt
					Matthew Dillon 
					<dillon at backplane.com>

diff --git a/sys/kern/kern_exit.c b/sys/kern/kern_exit.c
index 1e5a110..274f153 100644
--- a/sys/kern/kern_exit.c
+++ b/sys/kern/kern_exit.c
@@ -934,6 +934,17 @@ loop:
 			}
 
 			vm_waitproc(p);
+
+			/*
+			 * Temporary refs may still have been acquired while
+			 * we removed the process, make sure they are all
+			 * gone before kfree()ing.  Now that the process has
+			 * been removed from all lists and all references to
+			 * it have gone away, no new refs can occur.
+			 */
+			while (p->p_lock)
+				tsleep(p, 0, "reap4", hz);
+
 			kfree(p, M_PROC);
 			nprocs--;
 			error = 0;






More information about the Commits mailing list