ASoC: wcd-mbhc-v2: Revert "ASoC: wcd-mbhc-v2: use pm_runtime_resume_and_get()"
This reverts commitddea4bbf28
("ASoC: wcd-mbhc-v2: use pm_runtime_resume_and_get()"), because it introduced double runtime PM put if pm_runtime_get_sync() returns -EACCES: wcd934x-codec wcd934x-codec.3.auto: WCD934X Minor:0x1 Version:0x401 wcd934x-codec wcd934x-codec.3.auto: Runtime PM usage count underflow! The commit claimed no changes in functionality except dropping the reference on -EACCESS. This is exactly the change introducing bug because function calls unconditionally pm_runtime_put_autosuspend() at the end. Fixes:ddea4bbf28
("ASoC: wcd-mbhc-v2: use pm_runtime_resume_and_get()") Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://lore.kernel.org/r/20220929131528.217502-1-krzysztof.kozlowski@linaro.org Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
086ceada21
commit
e18f6bcf8e
|
@ -714,11 +714,12 @@ static int wcd_mbhc_initialise(struct wcd_mbhc *mbhc)
|
|||
struct snd_soc_component *component = mbhc->component;
|
||||
int ret;
|
||||
|
||||
ret = pm_runtime_resume_and_get(component->dev);
|
||||
ret = pm_runtime_get_sync(component->dev);
|
||||
if (ret < 0 && ret != -EACCES) {
|
||||
dev_err_ratelimited(component->dev,
|
||||
"pm_runtime_resume_and_get failed in %s, ret %d\n",
|
||||
"pm_runtime_get_sync failed in %s, ret %d\n",
|
||||
__func__, ret);
|
||||
pm_runtime_put_noidle(component->dev);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -1096,11 +1097,12 @@ static void wcd_correct_swch_plug(struct work_struct *work)
|
|||
mbhc = container_of(work, struct wcd_mbhc, correct_plug_swch);
|
||||
component = mbhc->component;
|
||||
|
||||
ret = pm_runtime_resume_and_get(component->dev);
|
||||
ret = pm_runtime_get_sync(component->dev);
|
||||
if (ret < 0 && ret != -EACCES) {
|
||||
dev_err_ratelimited(component->dev,
|
||||
"pm_runtime_resume_and_get failed in %s, ret %d\n",
|
||||
"pm_runtime_get_sync failed in %s, ret %d\n",
|
||||
__func__, ret);
|
||||
pm_runtime_put_noidle(component->dev);
|
||||
return;
|
||||
}
|
||||
micbias_mv = wcd_mbhc_get_micbias(mbhc);
|
||||
|
|
Loading…
Reference in New Issue