Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Unverified Commit b2f3e0c9 authored by Jaska Uimonen's avatar Jaska Uimonen Committed by Mark Brown
Browse files

ASoC: SOF: topology: fix get control data return type and arguments



sof_get_control_data returns negative values even though the return
value is defined unsigned (size_t). So change the return value type to
int and add the data size as pointer argument to sof_get_control_data to
avoid ambiquity in the meaning of the return type.

Fixes: cac974a5 ("ASoC: SOF: topology: use set_get_data in process load")
Reported by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarJaska Uimonen <jaska.uimonen@intel.com>
Link: https://lore.kernel.org/r/20190821211138.14618-1-jaska.uimonen@linux.intel.com


Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 8d92bb51
Loading
Loading
Loading
Loading
+11 −10
Original line number Diff line number Diff line
@@ -1752,17 +1752,19 @@ static int sof_widget_load_siggen(struct snd_soc_component *scomp, int index,
	return ret;
}

static size_t sof_get_control_data(struct snd_sof_dev *sdev,
static int sof_get_control_data(struct snd_sof_dev *sdev,
				struct snd_soc_dapm_widget *widget,
				   struct sof_widget_data *wdata)
				struct sof_widget_data *wdata,
				size_t *size)
{
	const struct snd_kcontrol_new *kc;
	struct soc_mixer_control *sm;
	struct soc_bytes_ext *sbe;
	struct soc_enum *se;
	size_t size = 0;
	int i;

	*size = 0;

	for (i = 0; i < widget->num_kcontrols; i++) {
		kc = &widget->kcontrol_news[i];

@@ -1800,7 +1802,7 @@ static size_t sof_get_control_data(struct snd_sof_dev *sdev,
		if (wdata[i].pdata->magic != SOF_ABI_MAGIC)
			return -EINVAL;

		size += wdata[i].pdata->size;
		*size += wdata[i].pdata->size;

		/* get data type */
		switch (wdata[i].control->cmd) {
@@ -1819,7 +1821,7 @@ static size_t sof_get_control_data(struct snd_sof_dev *sdev,
		}
	}

	return size;
	return 0;
}

static int sof_process_load(struct snd_soc_component *scomp, int index,
@@ -1855,13 +1857,12 @@ static int sof_process_load(struct snd_soc_component *scomp, int index,
			return -ENOMEM;

		/* get possible component controls and get size of all pdata */
		ipc_data_size = sof_get_control_data(sdev, widget, wdata);
		ret = sof_get_control_data(sdev, widget, wdata,
					   &ipc_data_size);

		if (ipc_data_size <= 0) {
			ret = ipc_data_size;
		if (ret < 0)
			goto out;
	}
	}

	ipc_size = sizeof(struct sof_ipc_comp_process) +
		le32_to_cpu(private->size) +