Skip to content

Commit c447636

Browse files
ujfalusibroonie
authored andcommitted
ASoC: SOF: ipc4-topology: Correct data structures for the SRC module
Separate the IPC message part as struct sof_ipc4_src_data. This struct describes the message payload passed to the firmware via the mailbox. It is not wise to be 'clever' and try to use the first part of a struct as IPC message without marking the message section as packed and aligned. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@linux.intel.com> Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Reviewed-by: Bard Liao <yung-chuan.liao@linux.intel.com> Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com> Link: https://lore.kernel.org/r/20231129131411.27516-2-peter.ujfalusi@linux.intel.com Signed-off-by: Mark Brown <broonie@kernel.org>
1 parent a0575b4 commit c447636

2 files changed

Lines changed: 23 additions & 14 deletions

File tree

sound/soc/sof/ipc4-topology.c

Lines changed: 11 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -141,7 +141,7 @@ static const struct sof_topology_token gain_tokens[] = {
141141
/* SRC */
142142
static const struct sof_topology_token src_tokens[] = {
143143
{SOF_TKN_SRC_RATE_OUT, SND_SOC_TPLG_TUPLE_TYPE_WORD, get_token_u32,
144-
offsetof(struct sof_ipc4_src, sink_rate)},
144+
offsetof(struct sof_ipc4_src_data, sink_rate)},
145145
};
146146

147147
static const struct sof_token_info ipc4_token_list[SOF_TOKEN_COUNT] = {
@@ -811,11 +811,12 @@ static int sof_ipc4_widget_setup_comp_src(struct snd_sof_widget *swidget)
811811

812812
swidget->private = src;
813813

814-
ret = sof_ipc4_get_audio_fmt(scomp, swidget, &src->available_fmt, &src->base_config);
814+
ret = sof_ipc4_get_audio_fmt(scomp, swidget, &src->available_fmt,
815+
&src->data.base_config);
815816
if (ret)
816817
goto err;
817818

818-
ret = sof_update_ipc_object(scomp, src, SOF_SRC_TOKENS, swidget->tuples,
819+
ret = sof_update_ipc_object(scomp, &src->data, SOF_SRC_TOKENS, swidget->tuples,
819820
swidget->num_tuples, sizeof(*src), 1);
820821
if (ret) {
821822
dev_err(scomp->dev, "Parsing SRC tokens failed\n");
@@ -824,7 +825,7 @@ static int sof_ipc4_widget_setup_comp_src(struct snd_sof_widget *swidget)
824825

825826
spipe->core_mask |= BIT(swidget->core);
826827

827-
dev_dbg(scomp->dev, "SRC sink rate %d\n", src->sink_rate);
828+
dev_dbg(scomp->dev, "SRC sink rate %d\n", src->data.sink_rate);
828829

829830
ret = sof_ipc4_widget_setup_msg(swidget, &src->msg);
830831
if (ret)
@@ -1900,7 +1901,7 @@ static int sof_ipc4_prepare_src_module(struct snd_sof_widget *swidget,
19001901
u32 out_ref_rate, out_ref_channels, out_ref_valid_bits;
19011902
int output_format_index, input_format_index;
19021903

1903-
input_format_index = sof_ipc4_init_input_audio_fmt(sdev, swidget, &src->base_config,
1904+
input_format_index = sof_ipc4_init_input_audio_fmt(sdev, swidget, &src->data.base_config,
19041905
pipeline_params, available_fmt);
19051906
if (input_format_index < 0)
19061907
return input_format_index;
@@ -1930,7 +1931,7 @@ static int sof_ipc4_prepare_src_module(struct snd_sof_widget *swidget,
19301931
*/
19311932
out_ref_rate = params_rate(fe_params);
19321933

1933-
output_format_index = sof_ipc4_init_output_audio_fmt(sdev, &src->base_config,
1934+
output_format_index = sof_ipc4_init_output_audio_fmt(sdev, &src->data.base_config,
19341935
available_fmt, out_ref_rate,
19351936
out_ref_channels, out_ref_valid_bits);
19361937
if (output_format_index < 0) {
@@ -1940,10 +1941,10 @@ static int sof_ipc4_prepare_src_module(struct snd_sof_widget *swidget,
19401941
}
19411942

19421943
/* update pipeline memory usage */
1943-
sof_ipc4_update_resource_usage(sdev, swidget, &src->base_config);
1944+
sof_ipc4_update_resource_usage(sdev, swidget, &src->data.base_config);
19441945

19451946
out_audio_fmt = &available_fmt->output_pin_fmts[output_format_index].audio_fmt;
1946-
src->sink_rate = out_audio_fmt->sampling_frequency;
1947+
src->data.sink_rate = out_audio_fmt->sampling_frequency;
19471948

19481949
/* update pipeline_params for sink widgets */
19491950
return sof_ipc4_update_hw_params(sdev, pipeline_params, out_audio_fmt);
@@ -2344,8 +2345,8 @@ static int sof_ipc4_widget_setup(struct snd_sof_dev *sdev, struct snd_sof_widget
23442345
{
23452346
struct sof_ipc4_src *src = swidget->private;
23462347

2347-
ipc_size = sizeof(struct sof_ipc4_base_module_cfg) + sizeof(src->sink_rate);
2348-
ipc_data = src;
2348+
ipc_size = sizeof(src->data);
2349+
ipc_data = &src->data;
23492350

23502351
msg = &src->msg;
23512352
break;

sound/soc/sof/ipc4-topology.h

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -404,16 +404,24 @@ struct sof_ipc4_mixer {
404404
struct sof_ipc4_msg msg;
405405
};
406406

407-
/**
408-
* struct sof_ipc4_src SRC config data
407+
/*
408+
* struct sof_ipc4_src_data - IPC data for SRC
409409
* @base_config: IPC base config data
410410
* @sink_rate: Output rate for sink module
411+
*/
412+
struct sof_ipc4_src_data {
413+
struct sof_ipc4_base_module_cfg base_config;
414+
uint32_t sink_rate;
415+
} __packed __aligned(4);
416+
417+
/**
418+
* struct sof_ipc4_src - SRC config data
419+
* @data: IPC base config data
411420
* @available_fmt: Available audio format
412421
* @msg: IPC4 message struct containing header and data info
413422
*/
414423
struct sof_ipc4_src {
415-
struct sof_ipc4_base_module_cfg base_config;
416-
uint32_t sink_rate;
424+
struct sof_ipc4_src_data data;
417425
struct sof_ipc4_available_audio_format available_fmt;
418426
struct sof_ipc4_msg msg;
419427
};

0 commit comments

Comments
 (0)