public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Re: PROBLEM: Bug in __pollwait() can cause select() and poll() to hang in
@ 2003-06-19 16:13 Manfred Spraul
  2003-06-19 18:09 ` PROBLEM: Bug in __pollwait() can cause select() and poll() tohang in Ray Bryant
  0 siblings, 1 reply; 3+ messages in thread
From: Manfred Spraul @ 2003-06-19 16:13 UTC (permalink / raw)
  To: Ray Bryant, linux-kernel

Hi Ray,

your bug description seems to be correct, but the fix is wrong:
If the allocation is for the 2nd page of wait queue heads, then 
"current->state = TASK_INTERRUPTIBLE" can lead to lost wakeups, if an fd 
that is stored in the first page gets ready during the allocation. 
Setting the state to interruptible is only permitted if a full scan of 
all file descriptors happens before calling schedule(). This is 
expensive and should be avoided.

The correct fix is current->state = TASK_RUNNING just before calling 
yield() in the rebalance code.

--
    Manfred


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

end of thread, other threads:[~2003-06-19 18:06 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-06-19 16:13 PROBLEM: Bug in __pollwait() can cause select() and poll() to hang in Manfred Spraul
2003-06-19 18:09 ` PROBLEM: Bug in __pollwait() can cause select() and poll() tohang in Ray Bryant
2003-06-19 18:21   ` Andrew Morton

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