On 22-07-20, 04:37, Bard Liao wrote: > From: Pierre-Louis Bossart <pierre-louis.bossart@xxxxxxxxxxxxxxx> > > The system resume does the entire bus re-initialization and brings it > to full-power. If the device was pm_runtime suspended, there is no > need to run the pm_runtime resume sequence after the system runtime. > > Follow the documentation from runtime_pm.rst, and conditionally > disable, set_active and re-enable the device on system resume. > > Note that pm_runtime_suspended() is used instead of > pm_runtime_status_suspended() so that we can deal with the case where > pm_runtime is disabled. > > Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@xxxxxxxxxxxxxxx> > Signed-off-by: Bard Liao <yung-chuan.liao@xxxxxxxxxxxxxxx> > --- > drivers/soundwire/intel.c | 20 ++++++++++++++++++++ > 1 file changed, 20 insertions(+) > > diff --git a/drivers/soundwire/intel.c b/drivers/soundwire/intel.c > index ed7163ae5f7a..284e5c9d240a 100644 > --- a/drivers/soundwire/intel.c > +++ b/drivers/soundwire/intel.c > @@ -1433,6 +1433,14 @@ static int intel_suspend(struct device *dev) > return 0; > } > > + if (pm_runtime_suspended(dev)) { > + dev_dbg(dev, > + "%s: pm_runtime status: suspended\n", > + __func__); first, can we have this in a single line, or better drop it second why would this be called when device is suspended > + > + return 0; > + } > + > ret = sdw_cdns_enable_interrupt(cdns, false); > if (ret < 0) { > dev_err(dev, "cannot disable interrupts on suspend\n"); > @@ -1493,6 +1501,18 @@ static int intel_resume(struct device *dev) > return 0; > } > > + if (pm_runtime_suspended(dev)) { > + dev_dbg(dev, > + "%s: pm_runtime status was suspended, forcing active\n", > + __func__); this one also could look better in a single line > + > + /* follow required sequence from runtime_pm.rst */ > + pm_runtime_disable(dev); > + pm_runtime_set_active(dev); > + pm_runtime_mark_last_busy(dev); > + pm_runtime_enable(dev); > + } > + > ret = intel_init(sdw); > if (ret) { > dev_err(dev, "%s failed: %d", __func__, ret); > -- > 2.17.1 -- ~Vinod