* Ulf Hansson <ulf.hansson@xxxxxxxxxx> [160203 02:24]: > On 3 February 2016 at 00:41, Tony Lindgren <tony@xxxxxxxxxxx> wrote: > > > Well we actually pretty much have devices in that state to start > > with. > > That's not true, not even for omap. > > There are definitely devices which HW state is reflected by RPM_ACTIVE > at boot. It's the responsible of the subsystem/driver (including PM > domains) to make sure the runtime PM status is updated accordingly, to > reflect the real HW state. > > For omap hwmod, at device registration in omap_device_build_from_dt() > it may actually invoke pm_runtime_set_active() if the device is > enabled. To my understanding, that's done to synchronize the real HW > state with the runtime PM status, right? Sure we do have cases where the bootloader state needs to be preserved for some devices. Like GPIO pin state to power memory on some devices! :) > >> To me, it's the responsible of the PM domain to *help* with the > >> synchronization, not prevent it as it currently does. > > > > The problem is that the hardware state gets out of sync with > > PM runtime. And that's going to be a pain to debug later on. > > I don't see the problem, but of course you know omap for better than I do. Well there's also the long term maintenance aspect at least I need to consider. > So if you are concerned about this, perhaps adding a dev_dbg print > when the omap hwmod's ->runtime_suspend() callback returns zero could > be a way forward? If we downgrade it to a debug statement or a warning, we'll soon end up with even more driver specific warnings than we already have. And I don't want to be chasing people around to fix their drivers for eavery new driver that gets submitted. Also, without this error I would not even originally have noticed we have a problem :) So I suggest the following: 1. I'll do a series of patches to fix up the handful of omap specific drivers with pm_runtime_use_autosuspend() that depend on omap_device 2. I'll also do a patch to improve the omap_device error message so new drivers are easy to fix. Something like: "%() called from invalid state %d, use pm_runtime_put_sync_suspend()?" Does that sounds OK to you? Regards, Tony -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html