[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <489A2B52.6090605@simon.arlott.org.uk>
Date: Wed, 06 Aug 2008 23:53:06 +0100
From: Simon Arlott <simon@...e.lp0.eu>
To: Alan Stern <stern@...land.harvard.edu>
CC: Rene Herman <rene.herman@...access.nl>,
Arjan van de Ven <arjan@...radead.org>,
linux-kernel@...r.kernel.org, mingo@...e.hu,
Daniel Walker <dwalker@...sta.com>,
USB list <linux-usb@...r.kernel.org>,
Greg Kroah-Hartman <gregkh@...e.de>
Subject: Re: [PATCH RFC] USB: Add HCD fastboot
On 06/08/08 23:34, Alan Stern wrote:
> On Wed, 6 Aug 2008, Simon Arlott wrote:
>
>> > Doing the HCD initcalls last certainly ought to work.
>>
>> Right - so then all that's needed is to move usb/ before most other things that
>> take a while to init, and it has some time to initialise usb devices in the
>> background.
>
> Not exactly -- you should move most of usb/ forward so that it comes
> before usb/host/. Or alternatively move usb/host/ later so that it
> comes after the rest of usb/.
Well, putting usb/ before net/ etc. requires that usb/host/ is the usb/stuff/ or
they'll all wait until they can probe for devices.
>> > So what exactly do you recommend?
>>
>> I'm not an expert on what can be done with the Makefile process, perhaps there's
>> an easier way to move things around based on a config option. If host init is
>> moved before device init for everyone, wouldn't there be too many side effects?
>
> Doesn't the host init _already_ come before device init? If host init
> were moved _after_ device init, I don't think there would be a lot of
> side effects. But it's hard to be sure without trying it.
Host init is before device init, as that's the Makefile link order. Any device
init causes it to wait for *all* devices, so swapping them around means devices
are going to appear at any time after that - there's no device initcall to make
it block. Presumably it would be possible to have a late_initcall (which would
be early in that list if usb was earlier) that could ensure khubd had finished
[its current queue] before continuing - as if there was a device driver initcall?
If someone currently has HCD init compiled in but nothing else, then the boot
process would block unnecessarily... the initcall would need to be disabled
in that case to maintain existing behaviour - which is why it probably needs
to be a config option, which requires some mess in the Makefile or a new
initcall type.
>> Lack of a keyboard makes it impossible to do anything if the module fails to
>> load... as I understand it when the HCD init runs, any BIOS emulation stops?
>
> That's right. The host driver kicks the BIOS off the hardware.
It seems like there's always going to be a stage where there's no keyboard...
>> Although if HCD is a module too...
>>
>> >> If even one device driver and the hcd is compiled in, they'd need to
>> >> wait for every USB device to finish init before the usbhid probe could complete.
>> >
>> > What if usbhid is the one device driver that is compiled in? :-)
>>
>> That was the situation I was thinking of - surely that would be compiled in
>> if the HCDs were?
>
> I noticed in your logs earlier that some of your USB drivers were
> compiled in and others weren't. Maybe if _all_ of them were compiled
> in you wouldn't experience as much contention and the init delays would
> be shorter.
I don't know where you got that from - they're definitely all compiled in.
Whichever is first to have its initcall run is blocked, and the logs may have
been from a test of that.
--
Simon Arlott
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists