> There you go (untested for now). > > ->runtime_idle() is still only called for the device's bus type, because > otherwise it will be hard to determine the right ordering of the bus type, > device type and device class callbacks. > > Comments welcome. :-) Looks good Rafael and exactly what I was looking for. I had one more question - +The ->runtime_suspend() callback is executed by the PM core for the bus type, +device type and device class of the device being suspended. The bus type, +device type and device class callbacks are then _entirely_ _responsible_ for +handling the device as appropriate, which may, but need not include executing +the device driver's own ->runtime_suspend() callback (from the PM core's point +of view it is not necessary to implement a ->runtime_suspend() callback in a +device driver as long as the bus type, device type and device class +->runtime_suspend() know what to do to handle the device). Any specific reason why from PM core we should not call the device driver's ->runtime_suspend() or ->runtime_resume()? I know one of either the bus/ class/type should implement device suspend but what if (worst case) none of them are doing it? Is it OK in that case (alone) to call device driver's runtime PM directly (if it is implemented) from the runtime PM core? Regards, Nithish Mahalingam _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm