[PATCH 2/2] ASoC: Intel: avs: Disconnect substream if suspend or resume fails
Cezary Rojewski
cezary.rojewski at intel.com
Thu Nov 10 17:06:45 CET 2022
On 2022-11-10 4:39 PM, Pierre-Louis Bossart wrote:
> On 11/10/22 08:13, Cezary Rojewski wrote:
>> --- a/sound/soc/intel/avs/pcm.c
>> +++ b/sound/soc/intel/avs/pcm.c
>> @@ -934,8 +934,11 @@ static int avs_component_pm_op(struct snd_soc_component *component, bool be,
>> rtd = snd_pcm_substream_chip(data->substream);
>> if (rtd->dai_link->no_pcm == be && !rtd->dai_link->ignore_suspend) {
>> ret = op(dai, data);
>> - if (ret < 0)
>> + if (ret < 0) {
>> + data->substream->runtime->status->state =
>> + SNDRV_PCM_STATE_DISCONNECTED;
>
> should runtime->state be used instead of runtime->status->state?
>
> A quick grep shows the former seems more popular in drivers,
> status->seems to be only used in pcm_native.c?
>
> Another plumbing question is whether it's actually ok to change the
> state of the runtime in a driver, are you not going to have locking
> issues? Very few drivers change the internal state and I wonder how
> legit/safe this is.
Unless something new has been added/updated, there is no runtime->state
field available. All the PCM code works with runtime->status->state.
component->resume() gets fired before any PCMs have a chance to be
resumed. Userspace cannot access us _yet_. Similarly for suspend,
component->suspend() is called once all the streams receive
TRIGGER_SUSPEND and from then on, we're on device-pm level already.
Well, in regard to grep, very few drivers enter the recovery jungle. All
of this is to help improve user experience when things go south.
Unfortunately for us, restoring regmap is insufficient to get AudioDSP
happy. Right now if things do go south, userspace still performs all of
the PCM commands on the stream as nothing has happened -
snd_soc_suspend/resume() return 0 in all cases.
Regards,
Czarek
More information about the Alsa-devel
mailing list