Maybe when Linus' release is a bit closer to the USB tree I could help
with that. Right now it's sufficiently divergent to make usb patches
against usbcore be rather helpful in general (though maybe not in that
particular case). I'll certainly be glad to take a whack at that.
>>Related issue to the suspend/resume code ... I recently noticed
>>(again) that the hub code was disconnecting top-down rather than
>>bottom up. That should eventually get delegated to the driver
>>framework ... any idea whether there was a reason not to do that
>>bottom-up in the first place? At what point does the driver model
>>kick in to handle that part of what the hub driver now does? If
>>the patch you sent around did that, my quick look missed it ... :)
>
>
> Hm, I didn't realize it was going top-down at all. What changes caused
> that? And no, I don't think I changed it, as I didn't realize it had
> been changed in the first place :)
I think it's just been that way for ages, no changes. It's actually
usb_disconnect(), not the hub driver, that goes top down, disconnecting
children only _after_ the parent is disconnected. (Might be nice to
flag all devices as "dead" before disconnecting in such cases, but we
don't have a way to flag devices as "dead" AFAIK. That'd make it easy
to fail new urb submissions for now-gone devices.)
If the current changes don't automagically make disconnection work
according to the device tree, something needs to change to make that
work correctly. But I'm not sure what it'd be; seems like the converse
of the probe() changes you started.
- Dave
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/