buggy GFP_KERNEL allocators

Rik van Riel riel en nl.linux.org
Jue Ene 27 01:28:51 CST 2000


On Wed, 26 Jan 2000, Ben LaHaise wrote:
> On Wed, 26 Jan 2000 kuznet en ms2.inr.ac.ru wrote:
> 
> > Hello!
> > 
> > > +				current->state = TASK_RUNNING;	/* We *must* do this before touching userspace! */
> > 
> > This smells suspiciously. Page fault code should not stuck only because
> > task state is not running. It contaradicts all the idea behind wait queues.
> > 
> > Essentially, fault is like signal. It must move task state to running.
> 
> Applying the change to the page fault handler might just be the
> right thing to do, and in fact it would make sense in 2.3 to have
> the fault handler also switch to lazy tlb mode if the task has to
> perform io.  The fault handler does neither of these things right
> now, and in fact this was causing occasional stuck tasks if the
> fault ended up calling schedule before changing current->state.

Won't we confuse lots of pieces of code when their
TASK_UNINTERRUPTIBLE process is returned to them as
a TASK_RUNNING one?

I'm somewhat afraid that we will break code whichever
way we go. That's why I've added a no-sleep workaround
to __get_free_pages() (hey, this isn't happening often
enough to run us out of memory) and added the printk()
to warn us about potentially dangerous code.

regards,

Rik
--
The Internet is not a network of computers. It is a network
of people. That is its real strength.


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo en vger.rutgers.edu
Please read the FAQ at http://www.tux.org/lkml/



Más información sobre la lista de distribución Ayuda