Commit 63e45324 authored by Cezary Rojewski's avatar Cezary Rojewski Committed by Mark Brown

ASoC: Intel: Skylake: Limit large_config_get to single frame

Reply for the very first LARGE_CONFIG_GET request contains total size of
payload to be retrieved by host.
From then on, each subsequent reply carries buffer offset instead. As
looping is not covered by any real-life example, remove it and cleanup
the function for followup overhaul.
Signed-off-by: default avatarCezary Rojewski <cezary.rojewski@intel.com>
Link: https://lore.kernel.org/r/20190808181549.12521-2-cezary.rojewski@intel.comReviewed-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 0e4cc44f
...@@ -973,8 +973,7 @@ int skl_ipc_get_large_config(struct sst_generic_ipc *ipc, ...@@ -973,8 +973,7 @@ int skl_ipc_get_large_config(struct sst_generic_ipc *ipc,
{ {
struct skl_ipc_header header = {0}; struct skl_ipc_header header = {0};
struct sst_ipc_message request = {0}, reply = {0}; struct sst_ipc_message request = {0}, reply = {0};
int ret = 0; int ret;
size_t sz_remaining, rx_size, data_offset;
header.primary = IPC_MSG_TARGET(IPC_MOD_MSG); header.primary = IPC_MSG_TARGET(IPC_MOD_MSG);
header.primary |= IPC_MSG_DIR(IPC_MSG_REQUEST); header.primary |= IPC_MSG_DIR(IPC_MSG_REQUEST);
...@@ -987,34 +986,12 @@ int skl_ipc_get_large_config(struct sst_generic_ipc *ipc, ...@@ -987,34 +986,12 @@ int skl_ipc_get_large_config(struct sst_generic_ipc *ipc,
header.extension |= IPC_FINAL_BLOCK(1); header.extension |= IPC_FINAL_BLOCK(1);
header.extension |= IPC_INITIAL_BLOCK(1); header.extension |= IPC_INITIAL_BLOCK(1);
sz_remaining = msg->param_data_size; request.header = *(u64 *)(&header);
data_offset = 0; reply.data = param;
reply.size = msg->param_data_size;
while (sz_remaining != 0) { ret = sst_ipc_tx_message_wait(ipc, request, &reply);
rx_size = sz_remaining > SKL_ADSP_W1_SZ if (ret < 0)
? SKL_ADSP_W1_SZ : sz_remaining; dev_err(ipc->dev, "ipc: get large config fail, err: %d\n", ret);
if (rx_size == sz_remaining)
header.extension |= IPC_FINAL_BLOCK(1);
request.header = *(u64 *)(&header);
reply.data = ((char *)param) + data_offset;
reply.size = msg->param_data_size;
ret = sst_ipc_tx_message_wait(ipc, request, &reply);
if (ret < 0) {
dev_err(ipc->dev,
"ipc: get large config fail, err: %d\n", ret);
return ret;
}
sz_remaining -= rx_size;
data_offset = msg->param_data_size - sz_remaining;
/* clear the fields */
header.extension &= IPC_INITIAL_BLOCK_CLEAR;
header.extension &= IPC_DATA_OFFSET_SZ_CLEAR;
/* fill the fields */
header.extension |= IPC_INITIAL_BLOCK(1);
header.extension |= IPC_DATA_OFFSET_SZ(data_offset);
}
return ret; return ret;
} }
......
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