summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/kern_event.c10
-rw-r--r--sys/kern/kern_exit.c7
2 files changed, 9 insertions, 8 deletions
diff --git a/sys/kern/kern_event.c b/sys/kern/kern_event.c
index a0229a7..73139f6 100644
--- a/sys/kern/kern_event.c
+++ b/sys/kern/kern_event.c
@@ -218,7 +218,8 @@ filt_procattach(struct knote *kn)
kn->kn_flags &= ~EV_FLAG1;
}
- SLIST_INSERT_HEAD(&p->p_klist, kn, kn_selnext);
+ if (immediate == 0)
+ SLIST_INSERT_HEAD(&p->p_klist, kn, kn_selnext);
/*
* Immediately activate any exit notes if the target process is a
@@ -280,13 +281,6 @@ filt_proc(struct knote *kn, long hint)
}
/*
- * Process will already be reported as gone.
- * Do not report anything else, as the knote will be destroyed soon.
- */
- if (kn->kn_status & KN_DETACHED)
- return (0);
-
- /*
* process forked, and user wants to track the new process,
* so attach a new knote to it, and immediately report an
* event with the parent's pid.
diff --git a/sys/kern/kern_exit.c b/sys/kern/kern_exit.c
index c65dfeb..10eeac3 100644
--- a/sys/kern/kern_exit.c
+++ b/sys/kern/kern_exit.c
@@ -436,6 +436,13 @@ exit1(struct thread *td, int rv)
* Notify interested parties of our demise.
*/
KNOTE(&p->p_klist, NOTE_EXIT);
+ /*
+ * Just delete all entries in the p_klist. At this point we won't
+ * report any more events, and there are nasty race conditions that
+ * can beat us if we don't.
+ */
+ while (SLIST_FIRST(&p->p_klist))
+ SLIST_REMOVE_HEAD(&p->p_klist, kn_selnext);
/*
* Notify parent that we're gone. If parent has the PS_NOCLDWAIT
OpenPOWER on IntegriCloud