USB2+umass: root mount fails
Marcel Moolenaar
xcllnt at mac.com
Tue Feb 17 10:36:48 PST 2009
On Feb 16, 2009, at 11:56 PM, Hans Petter Selasky wrote:
> On Tuesday 17 February 2009, Marcel Moolenaar wrote:
>> On Feb 16, 2009, at 6:03 PM, M. Warner Losh wrote:
>>> : root_mount_hold() and root_mount_rel() are specifically
>>> : designed to inform the mountroot code that it needs to
>>> : wait (or that it should go ahead and mount root).
>>>
>>> But it looks like the old usb code didn't call it either... I think
>>> old code enumerated right away during boot, while the new code
>>> defers
>>> the enumeration until events can be processed...
>>
>> Yes, you're right. USB1 used the following:
>>
>> SYSINIT(usb_cold_explore, SI_SUB_CONFIGURE, SI_ORDER_MIDDLE,
>> usb_cold_explore, NULL);
>>
>> SI_SUB_CONFIGURE didn't complete before all USB busses
>> were enumerated.
>
> I would really prefer that first time USB enumeration is not
> synchronous.
You misunderstand. I wasn't suggesting you changed USB2
to do the same thing as USB1. I was merely pointing out
how USB1 did it and why root mounts worked.
I think the USB2 approacj is better and as you say, we
just need to hold the root mount until we're done.
--
Marcel Moolenaar
xcllnt at mac.com
More information about the freebsd-usb
mailing list