Commit 1fc10044 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Mark Brown

ASoC: sigmadsp: Fix endianness conversion

Make sure to always convert the firmware data to local endianness before
using it.
Reported-by: default avatarkbuild test robot <fengguang.wu@intel.com>
Fixes: a35daac7 ("ASoC: sigmadsp: Add support for fw v2")
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent dee9cec4
...@@ -235,7 +235,7 @@ static int sigma_fw_load_control(struct sigmadsp *sigmadsp, ...@@ -235,7 +235,7 @@ static int sigma_fw_load_control(struct sigmadsp *sigmadsp,
ctrl->addr = le16_to_cpu(ctrl_chunk->addr); ctrl->addr = le16_to_cpu(ctrl_chunk->addr);
ctrl->num_bytes = num_bytes; ctrl->num_bytes = num_bytes;
ctrl->samplerates = chunk->samplerates; ctrl->samplerates = le32_to_cpu(chunk->samplerates);
list_add_tail(&ctrl->head, &sigmadsp->ctrl_list); list_add_tail(&ctrl->head, &sigmadsp->ctrl_list);
...@@ -266,7 +266,7 @@ static int sigma_fw_load_data(struct sigmadsp *sigmadsp, ...@@ -266,7 +266,7 @@ static int sigma_fw_load_data(struct sigmadsp *sigmadsp,
data->addr = le16_to_cpu(data_chunk->addr); data->addr = le16_to_cpu(data_chunk->addr);
data->length = length; data->length = length;
data->samplerates = chunk->samplerates; data->samplerates = le32_to_cpu(chunk->samplerates);
memcpy(data->data, data_chunk->data, length); memcpy(data->data, data_chunk->data, length);
list_add_tail(&data->head, &sigmadsp->data_list); list_add_tail(&data->head, &sigmadsp->data_list);
...@@ -329,7 +329,7 @@ static int sigmadsp_fw_load_v2(struct sigmadsp *sigmadsp, ...@@ -329,7 +329,7 @@ static int sigmadsp_fw_load_v2(struct sigmadsp *sigmadsp,
if (length > fw->size - pos || length < sizeof(*chunk)) if (length > fw->size - pos || length < sizeof(*chunk))
return -EINVAL; return -EINVAL;
switch (chunk->tag) { switch (le32_to_cpu(chunk->tag)) {
case SIGMA_FW_CHUNK_TYPE_DATA: case SIGMA_FW_CHUNK_TYPE_DATA:
ret = sigma_fw_load_data(sigmadsp, chunk, length); ret = sigma_fw_load_data(sigmadsp, chunk, length);
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment