From: Oleg Nesterov Date: Wed, 23 Sep 2009 22:56:47 +0000 (-0700) Subject: do_wait() wakeup optimization: child_wait_callback: check __WNOTHREAD case X-Git-Tag: firefly_0821_release~12389 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=b4fe51823d797d6959b2eee7868023e61606daa9;p=firefly-linux-kernel-4.4.55.git do_wait() wakeup optimization: child_wait_callback: check __WNOTHREAD case Suggested by Roland. do_wait(__WNOTHREAD) can only succeed if the caller is either ptracer, or it is ->real_parent and the child is not traced. IOW, caller == p->parent otherwise we should not wake up. Change child_wait_callback() to check this. Ratan reports the workload with CPU load >99% caused by unnecessary wakeups, should be fixed by this patch. Signed-off-by: Oleg Nesterov Acked-by: Roland McGrath Cc: Ingo Molnar Cc: Ratan Nalumasu Cc: Vitaly Mayatskikh Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/kernel/exit.c b/kernel/exit.c index 7838b4d68774..270a68b7f22f 100644 --- a/kernel/exit.c +++ b/kernel/exit.c @@ -1581,6 +1581,9 @@ static int child_wait_callback(wait_queue_t *wait, unsigned mode, if (!eligible_child(wo, p)) return 0; + if ((wo->wo_flags & __WNOTHREAD) && wait->private != p->parent) + return 0; + return default_wake_function(wait, mode, sync, key); }