[alsa-devel] [PATCH] topology: treat all DAPM controls types the same when copying
Takashi Iwai
tiwai at suse.de
Fri Aug 7 18:07:27 CEST 2015
On Fri, 07 Aug 2015 17:39:15 +0200,
Liam Girdwood wrote:
>
> From: Mengdong Lin <mengdong.lin at intel.com>
>
> Copy all DAPM controls types using the same method.
>
> Signed-off-by: Mengdong Lin <mengdong.lin at intel.com>
> Signed-off-by: Liam Girdwood <liam.r.girdwood at linux.intel.com>
Applied, thanks.
Takashi
> ---
> src/topology/dapm.c | 11 +++--------
> 1 file changed, 3 insertions(+), 8 deletions(-)
>
> diff --git a/src/topology/dapm.c b/src/topology/dapm.c
> index 7e26ea0..a0a8b86 100644
> --- a/src/topology/dapm.c
> +++ b/src/topology/dapm.c
> @@ -107,8 +107,6 @@ static int tplg_parse_dapm_enums(snd_config_t *cfg, struct tplg_elem *elem)
> static int copy_dapm_control(struct tplg_elem *elem, struct tplg_elem *ref)
> {
> struct snd_soc_tplg_dapm_widget *widget = elem->widget;
> - struct snd_soc_tplg_mixer_control *mixer_ctrl = ref->mixer_ctrl;
> - struct snd_soc_tplg_enum_control *enum_ctrl = ref->enum_ctrl;
>
> tplg_dbg("Control '%s' used by '%s'\n", ref->id, elem->id);
> tplg_dbg("\tparent size: %d + %d -> %d, priv size -> %d\n",
> @@ -121,13 +119,10 @@ static int copy_dapm_control(struct tplg_elem *elem, struct tplg_elem *ref)
>
> elem->widget = widget;
>
> - /* copy new widget at the end */
> - if (ref->type == OBJECT_TYPE_MIXER)
> - memcpy((void*)widget + elem->size, mixer_ctrl, ref->size);
> - else if (ref->type == OBJECT_TYPE_ENUM)
> - memcpy((void*)widget + elem->size, enum_ctrl, ref->size);
> -
> + /* append the control to the end of the widget */
> + memcpy((void*)widget + elem->size, ref->obj, ref->size);
> elem->size += ref->size;
> +
> widget->num_kcontrols++;
> ref->compound_elem = 1;
> return 0;
> --
> 2.1.4
>
More information about the Alsa-devel
mailing list