From: William Lee Irwin III <wli@holomorphy.com>
To: Kirill Korotaev <dev@sw.ru>
Cc: linux-kernel@vger.kernel.org
Subject: Re: [Q] why switch_exec_pids() changes thread group leader pid?
Date: Mon, 20 Sep 2004 05:24:10 -0700 [thread overview]
Message-ID: <20040920122410.GU9106@holomorphy.com> (raw)
In-Reply-To: <414EC805.8070105@sw.ru>
On Mon, Sep 20, 2004 at 03:29:47PM +0400, Kirill Korotaev wrote:
>>> I've been looking through switch_exec_pids() function and found that it
>>> changes thread group leader PID/TGID. Is it really a good idea to change
>>> pid of the process during it's lifetime? I could understand if it was
>>> happenning in the context of that process, but pid changes everytime a
>>> thread calls do_execve().
>>> As far as I can see, leader doesn't have to do any of detach_pid()'s.
>>> Instead thread should change it's PID/TGID.
William Lee Irwin III wrote:
>> It's only done when a thread that is not a thread group leader
>> execve()'s. This is actually pretty rare and confined to threaded
>> applications, so it should be almost never called.
On Mon, Sep 20, 2004 at 04:07:33PM +0400, Kirill Korotaev wrote:
> Heh, rare doesn't mean correct, yeah? :)
The semantic it implements is that the thread calling execve() kills
all other threads of the process and assumes the identity of the thread
group leader. It should be clear that when the thread were already the
group leader, such as it is for unthreaded processes, one need only
kill the other threads, of which there are none for unthreaded
processes. I'm largely not involved with the implementation of POSIX
threading semantics, so there is some limit regarding the amount of
detail in which I can go on about it without resorting to research.
Ingo Molnar, Roland McGrath, and Ulrich Drepper will likely have more
information if you should care to question so deeply as to ask e.g.
whether this is actually faithful to whatever standard they followed.
-- wli
prev parent reply other threads:[~2004-09-20 12:24 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-09-20 11:29 [Q] why switch_exec_pids() changes thread group leader pid? Kirill Korotaev
2004-09-20 11:46 ` William Lee Irwin III
2004-09-20 12:07 ` Kirill Korotaev
2004-09-20 12:24 ` William Lee Irwin III [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=20040920122410.GU9106@holomorphy.com \
--to=wli@holomorphy.com \
--cc=dev@sw.ru \
--cc=linux-kernel@vger.kernel.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox