From: Vinod Koul <vkoul@kernel.org>
To: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
Cc: perex@perex.cz, tiwai@suse.com, lgirdwood@gmail.com,
broonie@kernel.org, alsa-devel@alsa-project.org,
linux-kernel@vger.kernel.org, ckeepax@opensource.cirrus.com
Subject: Re: [RFC PATCH] ALSA: compress: add support to change codec profile in gapless playback
Date: Thu, 2 Jul 2020 17:06:02 +0530 [thread overview]
Message-ID: <20200702113602.GA273932@vkoul-mobl> (raw)
In-Reply-To: <20200702111114.32217-1-srinivas.kandagatla@linaro.org>
Hi Srini,
On 02-07-20, 12:11, Srinivas Kandagatla wrote:
> For gapless playback its possible that each track can have different
s/its/it is
> codec profile with same decoder, for example we have WMA album,
> we may have different tracks as WMA v9, WMA v10 and so on
>
> Existing code does not allow to change this profile while doing gapless
> playback.
>
> This patch adds new SNDRV_COMPRESS_SET_CODEC_PARAMS IOCTL to allow
> userspace to set this new parameters required for new codec profile.
Thanks, this looks good and in line with discussions done in Audio uConf
>
> Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
> ---
> include/sound/compress_driver.h | 5 +++
> include/sound/soc-component.h | 3 ++
> include/sound/soc-dai.h | 5 +++
> include/uapi/sound/compress_offload.h | 1 +
> sound/core/compress_offload.c | 54 ++++++++++++++++++++++++---
> sound/soc/soc-compress.c | 30 +++++++++++++++
> sound/soc/soc-dai.c | 14 +++++++
Can we split the ALSA changes and ASoC changes to different patches
please?
Also please post driver support for this API..
Lastly, documentation needs update about this call
> 7 files changed, 106 insertions(+), 6 deletions(-)
>
> diff --git a/include/sound/compress_driver.h b/include/sound/compress_driver.h
> index 70cbc5095e72..8d23351f7ad7 100644
> --- a/include/sound/compress_driver.h
> +++ b/include/sound/compress_driver.h
> @@ -93,6 +93,9 @@ struct snd_compr_stream {
> * @set_params: Sets the compressed stream parameters, mandatory
> * This can be called in during stream creation only to set codec params
> * and the stream properties
> + * @set_codec_params: Sets the compressed stream codec parameters, mandatory
This should be optional as gapless is optional
> --- a/include/uapi/sound/compress_offload.h
> +++ b/include/uapi/sound/compress_offload.h
> @@ -172,6 +172,7 @@ struct snd_compr_metadata {
> struct snd_compr_metadata)
> #define SNDRV_COMPRESS_GET_METADATA _IOWR('C', 0x15,\
> struct snd_compr_metadata)
> +#define SNDRV_COMPRESS_SET_CODEC_PARAMS _IOW('C', 0x16, struct snd_codec)
> #define SNDRV_COMPRESS_TSTAMP _IOR('C', 0x20, struct snd_compr_tstamp)
> #define SNDRV_COMPRESS_AVAIL _IOR('C', 0x21, struct snd_compr_avail)
> #define SNDRV_COMPRESS_PAUSE _IO('C', 0x30)
I think we should bump the compress version too for checking in userland
about this support
> static int snd_compress_check_input(struct snd_compr_params *params)
> {
> /* first let's check the buffer parameter's */
> @@ -574,14 +586,41 @@ static int snd_compress_check_input(struct snd_compr_params *params)
> params->buffer.fragments == 0)
> return -EINVAL;
>
> - /* now codec parameters */
> - if (params->codec.id == 0 || params->codec.id > SND_AUDIOCODEC_MAX)
> - return -EINVAL;
> + return snd_compress_check_codec_params(¶ms->codec);
Can this be 1st patch to prepare for this change?
>
> - if (params->codec.ch_in == 0 || params->codec.ch_out == 0)
> - return -EINVAL;
> +}
>
> - return 0;
> +static int snd_compr_set_codec_params(struct snd_compr_stream *stream,
> + unsigned long arg)
> +{
> + struct snd_codec *params;
> + int retval;
> +
> + if (!stream->ops->set_codec_params)
> + return -EPERM;
> +
> + if (stream->runtime->state != SNDRV_PCM_STATE_RUNNING)
> + return -EPERM;
> +
> + /* codec params can be only set when next track has been signalled */
> + if (stream->next_track == false)
> + return -EPERM;
> +
> + params = memdup_user((void __user *)arg, sizeof(*params));
> + if (IS_ERR(params))
> + return PTR_ERR(params);
> +
> + retval = snd_compress_check_codec_params(params);
> + if (retval)
> + goto out;
> +
> + retval = stream->ops->set_codec_params(stream, params);
> + if (retval)
> + goto out;
this jump is superfluous
> +
> +out:
> + kfree(params);
> + return retval;
> }
...
> +static int soc_compr_set_codec_params(struct snd_compr_stream *cstream,
> + struct snd_codec *codec)
> +{
> + struct snd_soc_pcm_runtime *rtd = cstream->private_data;
> + struct snd_soc_component *component;
> + struct snd_soc_dai *cpu_dai = asoc_rtd_to_cpu(rtd, 0);
> + int i, ret;
> +
> + mutex_lock_nested(&rtd->card->pcm_mutex, rtd->card->pcm_subclass);
> +
> + ret = snd_soc_dai_compr_set_codec_params(cpu_dai, cstream, codec);
> + if (ret < 0)
> + goto err;
> +
> + for_each_rtd_components(rtd, i, component) {
> + if (!component->driver->compress_ops ||
> + !component->driver->compress_ops->set_codec_params)
> + continue;
> +
> + ret = component->driver->compress_ops->set_codec_params(component, cstream,
> + codec);
maybe use a compress_ops pointer to make this look and read better :)
--
~Vinod
next prev parent reply other threads:[~2020-07-02 11:36 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-07-02 11:11 [RFC PATCH] ALSA: compress: add support to change codec profile in gapless playback Srinivas Kandagatla
2020-07-02 11:36 ` Vinod Koul [this message]
2020-07-02 12:29 ` Srinivas Kandagatla
2020-07-02 15:00 ` Pierre-Louis Bossart
2020-07-03 9:47 ` Srinivas Kandagatla
2020-07-06 15:14 ` Pierre-Louis Bossart
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20200702113602.GA273932@vkoul-mobl \
--to=vkoul@kernel.org \
--cc=alsa-devel@alsa-project.org \
--cc=broonie@kernel.org \
--cc=ckeepax@opensource.cirrus.com \
--cc=lgirdwood@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=perex@perex.cz \
--cc=srinivas.kandagatla@linaro.org \
--cc=tiwai@suse.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).