Re: Wait for console to become available, v3.2

From: Jamie Lokier
Date: Tue Apr 21 2009 - 10:06:34 EST


Ingo Molnar wrote:
> * Arjan van de Ven <arjan@xxxxxxxxxxxxx> wrote:
> > But more importantly... USB *CANNOT* do this fundamental
> > operation. USB does not have the capability to know when you have
> > seen all devices that are connected. Devices just show up a random
> > amount of time after you turn the power on for the bus.... there's
> > no "and now we've seen all" operation.
>
> Yes - and this is fundamentally true of any hotplug bus design.

It's not fundamental, for devices you know are plugged in at boot.
All it takes is for the bus to support a synchronous "enumerate all"
procedure. That _could_ involve a timeout, but there are better ways.
But not for USB.

> What i'm saying is: instead of "wait 2000 msecs, maybe it works out"
> hack, there should be a proper sleep+event based approach to the
> same. With perhaps a _timeout_ for the "no console arrived" negative
> case as well. (which timeout can be set to zero in the "I _know_
> there's no console around".)

Isn't the proposed code doing exactly that? It sleeps waiting for a
console, with a timeout of X msecs. If a console arrives before that,
doesn't it wake immediately?

> Do you see the fundamental design difference between the two
> solutions?

The only difference I see is: If you asked for a USB console, the
timeout should begin relative to when the USB host driver kicks the
bus, not the first /dev/console open.

Conceptually the timeout is a USB characteristic, not a generic
console one.

For other (non-USB) devices which might take a while to initialise, it
should work as you describe. E.g. an ethernet TCP console should
register ("i'm trying to give you a console") followed by ("got it")
or ("failed, carry on without me").

-- Jamie
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/