public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* A bug (probably) in stop_all_threads
@ 2008-09-13  8:27 karthikeyan S
  2008-09-13 10:07 ` Grant Coady
  0 siblings, 1 reply; 9+ messages in thread
From: karthikeyan S @ 2008-09-13  8:27 UTC (permalink / raw)
  To: linux-kernel

Hi,

Apologies if I am posting this message in an incorrect mailing list
and for bringing up an issue with older kernel version (2.4), and if
the issue had been brought up earlier and I missed it.

There seems to be a bug with stop_all_threads function in 2.4. The
function sends SIGSTOP to all the threads in the thread group and
waits until all the threads get their state changed accordingly.

While waiting, if it finds that the event has not occurred, it tires
to yield the processor to other processes by calling
schedule_timeout().

Bur before calling schedule_timeout() it does not set the task state
to either TASK_INTERRUPTIBLE or TASK_UNINTERRUPTIBLE.
So schedule_timeout() does not do anything effectively.

This causes a problem in our device which uses kernel 2.4. When we
have a sigsegv from the task which runs at highest priority, the
control is stuck waiting for all the threads in the thread group to
change their task state. But the other threads never get a chance to
run and the SIGSTOP sent to them is of no effect.

When  I changed the stop_all_threads function to set the task state to
TASK_INTERRUPTIBLE, the problem disappears.

So is this a real issue that stop_all_threads() does not set the
current task to TASK_INTERRUPTIBLE before calling schedule_timeout()?

Please provide your feedback. Thanks a lot.

-karthik

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2008-09-16 20:21 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-13  8:27 A bug (probably) in stop_all_threads karthikeyan S
2008-09-13 10:07 ` Grant Coady
2008-09-16  5:17   ` Willy Tarreau
2008-09-16  5:49     ` karthikeyan S
2008-09-16  6:22       ` Willy Tarreau
2008-09-16  8:28         ` karthikeyan S
2008-09-16  9:28           ` Willy Tarreau
2008-09-16 19:30             ` karthikeyan S
2008-09-16 20:21               ` Willy Tarreau

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox