]> git.baikalelectronics.ru Git - kernel.git/commit
soundwire: bus: pm_runtime_request_resume on peripheral attachment
authorPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Wed, 20 Apr 2022 02:32:41 +0000 (10:32 +0800)
committerVinod Koul <vkoul@kernel.org>
Mon, 9 May 2022 06:31:09 +0000 (12:01 +0530)
commit54a0eccef5ea09b354dacea359279140f64ff496
tree3e0ee4d66b9511d41feae1f8e89f5144ceffad6b
parentfd3cc8390d4568eef69ac86f7f871a9603ecb97e
soundwire: bus: pm_runtime_request_resume on peripheral attachment

In typical use cases, the peripheral becomes pm_runtime active as a
result of the ALSA/ASoC framework starting up a DAI. The parent/child
hierarchy guarantees that the manager device will be fully resumed
beforehand.

There is however a corner case where the manager device may become
pm_runtime active, but without ALSA/ASoC requesting any functionality
from the peripherals. In this case, the hardware peripheral device
will report as ATTACHED and its initialization routine will be
executed. If this initialization routine initiates any sort of
deferred processing, there is a possibility that the manager could
suspend without the peripheral suspend sequence being invoked: from
the pm_runtime framework perspective, the peripheral is *already*
suspended.

To avoid such disconnects between hardware state and pm_runtime state,
this patch adds an asynchronous pm_request_resume() upon successful
attach/initialization which will result in the proper resume/suspend
sequence to be followed on the peripheral side.

BugLink: https://github.com/thesofproject/linux/issues/3459
Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
Reviewed-by: Rander Wang <rander.wang@intel.com>
Signed-off-by: Bard Liao <yung-chuan.liao@linux.intel.com>
Link: https://lore.kernel.org/r/20220420023241.14335-4-yung-chuan.liao@linux.intel.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/soundwire/bus.c