All of lore.kernel.org
 help / color / mirror / Atom feed
From: Oleg Nesterov <oleg@redhat.com>
To: Andrew Morton <akpm@linux-foundation.org>
Cc: Roland McGrath <roland@redhat.com>,
	Vitaly Mayatskikh <vmayatsk@redhat.com>,
	linux-kernel@vger.kernel.org
Subject: Re: [PATCH 1/1] ptrace: __ptrace_detach: do __wake_up_parent() if we reap the tracee
Date: Thu, 2 Jul 2009 20:51:39 +0200	[thread overview]
Message-ID: <20090702185139.GA31404@redhat.com> (raw)
In-Reply-To: <20090701192844.GA26624@redhat.com>

On 07/01, Oleg Nesterov wrote:
>
> --- WAIT/kernel/ptrace.c~PT_DETACH_WAKE_PARENT	2009-07-01 19:59:01.000000000 +0200
> +++ WAIT/kernel/ptrace.c	2009-07-01 20:52:58.000000000 +0200
> @@ -266,9 +266,10 @@ static int ignoring_children(struct sigh
>   * or self-reaping.  Do notification now if it would have happened earlier.
>   * If it should reap itself, return true.
>   *
> - * If it's our own child, there is no notification to do.
> - * But if our normal children self-reap, then this child
> - * was prevented by ptrace and we must reap it now.
> + * If it's our own child, there is no notification to do. But if our normal
> + * children self-reap, then this child was prevented by ptrace and we must
> + * reap it now, in that case we must also wake up sub-threads sleeping in
> + * do_wait().
>   */
>  static bool __ptrace_detach(struct task_struct *tracer, struct task_struct *p)
>  {
> @@ -278,8 +279,10 @@ static bool __ptrace_detach(struct task_
>  		if (!task_detached(p) && thread_group_empty(p)) {
>  			if (!same_thread_group(p->real_parent, tracer))
>  				do_notify_parent(p, p->exit_signal);
> -			else if (ignoring_children(tracer->sighand))
> +			else if (ignoring_children(tracer->sighand)) {
> +				__wake_up_parent(p, tracer);
>  				p->exit_signal = -1;
> +			}

I wonder if we need more fixes here.

ignoring_children() is not exactly right afaics, we assume that
tracee->exit_signal == SIGCHLD.

But I guess this can be ignored, it falls into "ptracing with SIGCHLD
ignored asks for trouble" category.

But !same_thread_group() doesn't look 100% right too, for the same
reason. If ->exit_signal != SIGCHLD, we can't assume we already had
the correct notification. Hopefully this can be ignored too.

Oleg.


      reply	other threads:[~2009-07-02 18:54 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-07-01 19:28 [PATCH 1/1] ptrace: __ptrace_detach: do __wake_up_parent() if we reap the tracee Oleg Nesterov
2009-07-02 18:51 ` Oleg Nesterov [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20090702185139.GA31404@redhat.com \
    --to=oleg@redhat.com \
    --cc=akpm@linux-foundation.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=roland@redhat.com \
    --cc=vmayatsk@redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.