[alsa-devel] [PATCH v2 2/4] ALSA: compress: Prevent bypasses of set_params

Takashi Iwai tiwai at suse.de
Tue Jul 23 12:08:41 CEST 2019


On Mon, 22 Jul 2019 11:24:34 +0200,
Charles Keepax wrote:
> 
> Currently, whilst in SNDRV_PCM_STATE_OPEN it is possible to call
> snd_compr_stop, snd_compr_drain and snd_compr_partial_drain, which
> allow a transition to SNDRV_PCM_STATE_SETUP. The stream should
> only be able to move to the setup state once it has received a
> SNDRV_COMPRESS_SET_PARAMS ioctl. Fix this issue by not allowing
> those ioctls whilst in the open state.
> 
> Signed-off-by: Charles Keepax <ckeepax at opensource.cirrus.com>

Applied, thanks.


Takashi

> ---
> 
> No changes since v1.
> 
> Thanks,
> Charles
> 
>  sound/core/compress_offload.c | 30 ++++++++++++++++++++++++------
>  1 file changed, 24 insertions(+), 6 deletions(-)
> 
> diff --git a/sound/core/compress_offload.c b/sound/core/compress_offload.c
> index d79aee6b9edd2..40dae723c59db 100644
> --- a/sound/core/compress_offload.c
> +++ b/sound/core/compress_offload.c
> @@ -711,9 +711,15 @@ static int snd_compr_stop(struct snd_compr_stream *stream)
>  {
>  	int retval;
>  
> -	if (stream->runtime->state == SNDRV_PCM_STATE_PREPARED ||
> -			stream->runtime->state == SNDRV_PCM_STATE_SETUP)
> +	switch (stream->runtime->state) {
> +	case SNDRV_PCM_STATE_OPEN:
> +	case SNDRV_PCM_STATE_SETUP:
> +	case SNDRV_PCM_STATE_PREPARED:
>  		return -EPERM;
> +	default:
> +		break;
> +	}
> +
>  	retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_STOP);
>  	if (!retval) {
>  		snd_compr_drain_notify(stream);
> @@ -801,9 +807,14 @@ static int snd_compr_drain(struct snd_compr_stream *stream)
>  {
>  	int retval;
>  
> -	if (stream->runtime->state == SNDRV_PCM_STATE_PREPARED ||
> -			stream->runtime->state == SNDRV_PCM_STATE_SETUP)
> +	switch (stream->runtime->state) {
> +	case SNDRV_PCM_STATE_OPEN:
> +	case SNDRV_PCM_STATE_SETUP:
> +	case SNDRV_PCM_STATE_PREPARED:
>  		return -EPERM;
> +	default:
> +		break;
> +	}
>  
>  	retval = stream->ops->trigger(stream, SND_COMPR_TRIGGER_DRAIN);
>  	if (retval) {
> @@ -840,9 +851,16 @@ static int snd_compr_next_track(struct snd_compr_stream *stream)
>  static int snd_compr_partial_drain(struct snd_compr_stream *stream)
>  {
>  	int retval;
> -	if (stream->runtime->state == SNDRV_PCM_STATE_PREPARED ||
> -			stream->runtime->state == SNDRV_PCM_STATE_SETUP)
> +
> +	switch (stream->runtime->state) {
> +	case SNDRV_PCM_STATE_OPEN:
> +	case SNDRV_PCM_STATE_SETUP:
> +	case SNDRV_PCM_STATE_PREPARED:
>  		return -EPERM;
> +	default:
> +		break;
> +	}
> +
>  	/* stream can be drained only when next track has been signalled */
>  	if (stream->next_track == false)
>  		return -EPERM;
> -- 
> 2.11.0
> 
> 


More information about the Alsa-devel mailing list