Re: Patch: linux-2.5.42/kernel/sys.c - warm reboot should not suspend devices

From: Eric W. Biederman (ebiederm@xmission.com)
Date: Tue Oct 15 2002 - 11:59:56 EST


"Adam J. Richter" <adam@yggdrasil.com> writes:

> Eric W. Biederman writes:

> >If there is non-trivial work to detect if a card is present it
> >probably makes sense to factor remove into
> >->quiet() and ->remove()
> >Where quiet would put the device into a quiescent state, and
> >remove would simply clean up the driver state.
>
> Splitting into ->quiet() and ->removed() would be helpful
> in any case, where removed() would normally not touch the hardware,
> since it is quite possible the device has already been removed,
> since the callers of these routines generally know if they are
> calling because the device has been removed or because they want
> just want to turn it off, while ->remove() currently has to guess,
> which not only wastes time but also can be difficult to do safely
> when you don't know if the device that you're talking to is even
> present anymore.

Except for the case when a device is physically swapped before ->remove()
which is really, really, nasty. But it is quiet unlikely anyone will
actually be that fast. Whatever talks to the hardware has to check to
see if it's device is present. But if usb is anything like PCI it
should be a very inexpensive check to see if a driver is present. And
writes to a non-existent device should be safe.

Splitting ->remove() into quiet() and ->removed() will be racy. So
unless there is shown to be a compelling reason to do the split I
don't want to go there. It appears easier to write correct code
with a single ->remove() method than two separate methods in the
hot-plug case.

Eric
-
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/



This archive was generated by hypermail 2b29 : Tue Oct 15 2002 - 22:00:55 EST