Hi Wolfram, On Wed, May 13, 2020 at 7:12 PM Wolfram Sang <wsa@xxxxxxxxxx> wrote: > From: Wolfram Sang <wsa+renesas@xxxxxxxxxxxxxxxxxxxx> > > Because we enabled the device with _noresume, we should disable it with > _noidle to match the ref counting of the clocks during remove(). > > Reported-by: Geert Uytterhoeven <geert+renesas@xxxxxxxxx> > Signed-off-by: Wolfram Sang <wsa+renesas@xxxxxxxxxxxxxxxxxxxx> Reviewed-by: Geert Uytterhoeven <geert+renesas@xxxxxxxxx> > I think this is the proper fix to the problem Geert reported [1]. I am Thanks, I can confirm this fixes the issue on unbind, so Tested-by: Geert Uytterhoeven <geert+renesas@xxxxxxxxx> > not sure about a proper Fixes-tag, though. The corresponding _noidle > call in the probe()-error-path was added with: > > aa86f1a38875 ("mmc: tmio: Fixup runtime PM management during probe") That one also added a pm_runtime_put() call to the normal probe path, but a pm_runtime_put_noidle() call to the error path, causing another possible imbalance, which is still there. So I guess the former has to be replaced by a _noidle call, too? Also, the conditional if (_host->native_hotplug) pm_runtime_get_noresume(&pdev->dev); in probe() is not undone in the error path. > However, from my understanding this is more fitting? > > 1b32999e205b ("mmc: tmio: Avoid boilerplate code in ->runtime_suspend()") > > But maybe my understanding of the situation is still not perfect and > even the commit message is bogus? Ulf, since both mentioned commits are > from you, could you have a look? Thanks in advance! > > Wolfram > > [1] Message-ID: <alpine.DEB.2.21.2004291630090.4052@xxxxxxxxxxxxxx> Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds