Commit 3b64fd2f authored by Peter Ujfalusi's avatar Peter Ujfalusi Committed by Mark Brown

ASoC: SOF: ipc4-topology/pcm: Rename sof_ipc4_copier_is_single_format()

Rename the sof_ipc4_copier_is_single_format() to
sof_ipc4_copier_is_single_bitdepth() to clear the confusion of the use of
'format' when we are querying information on the bit depth.
Format is used to describe a combination of parameters (rate, channels,
sample format / bit depth).
Rename the flags used to store the result at the same time.
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
Reviewed-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Reviewed-by: default avatarSeppo Ingalsuo <seppo.ingalsuo@linux.intel.com>
Reviewed-by: default avatarRanjani Sridharan <ranjani.sridharan@linux.intel.com>
Link: https://msgid.link/r/20240530111918.21974-4-peter.ujfalusi@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 2a865c9c
...@@ -650,7 +650,7 @@ static int sof_ipc4_pcm_dai_link_fixup(struct snd_soc_pcm_runtime *rtd, ...@@ -650,7 +650,7 @@ static int sof_ipc4_pcm_dai_link_fixup(struct snd_soc_pcm_runtime *rtd,
struct snd_soc_dai *cpu_dai = snd_soc_rtd_to_cpu(rtd, 0); struct snd_soc_dai *cpu_dai = snd_soc_rtd_to_cpu(rtd, 0);
struct sof_ipc4_audio_format *ipc4_fmt; struct sof_ipc4_audio_format *ipc4_fmt;
struct sof_ipc4_copier *ipc4_copier; struct sof_ipc4_copier *ipc4_copier;
bool single_fmt = false; bool single_bitdepth = false;
u32 valid_bits = 0; u32 valid_bits = 0;
int dir, ret; int dir, ret;
...@@ -682,18 +682,18 @@ static int sof_ipc4_pcm_dai_link_fixup(struct snd_soc_pcm_runtime *rtd, ...@@ -682,18 +682,18 @@ static int sof_ipc4_pcm_dai_link_fixup(struct snd_soc_pcm_runtime *rtd,
return 0; return 0;
if (dir == SNDRV_PCM_STREAM_PLAYBACK) { if (dir == SNDRV_PCM_STREAM_PLAYBACK) {
if (sof_ipc4_copier_is_single_format(sdev, if (sof_ipc4_copier_is_single_bitdepth(sdev,
available_fmt->output_pin_fmts, available_fmt->output_pin_fmts,
available_fmt->num_output_formats)) { available_fmt->num_output_formats)) {
ipc4_fmt = &available_fmt->output_pin_fmts->audio_fmt; ipc4_fmt = &available_fmt->output_pin_fmts->audio_fmt;
single_fmt = true; single_bitdepth = true;
} }
} else { } else {
if (sof_ipc4_copier_is_single_format(sdev, if (sof_ipc4_copier_is_single_bitdepth(sdev,
available_fmt->input_pin_fmts, available_fmt->input_pin_fmts,
available_fmt->num_input_formats)) { available_fmt->num_input_formats)) {
ipc4_fmt = &available_fmt->input_pin_fmts->audio_fmt; ipc4_fmt = &available_fmt->input_pin_fmts->audio_fmt;
single_fmt = true; single_bitdepth = true;
} }
} }
} }
...@@ -703,7 +703,7 @@ static int sof_ipc4_pcm_dai_link_fixup(struct snd_soc_pcm_runtime *rtd, ...@@ -703,7 +703,7 @@ static int sof_ipc4_pcm_dai_link_fixup(struct snd_soc_pcm_runtime *rtd,
if (ret) if (ret)
return ret; return ret;
if (single_fmt) { if (single_bitdepth) {
snd_mask_none(fmt); snd_mask_none(fmt);
valid_bits = SOF_IPC4_AUDIO_FORMAT_CFG_V_BIT_DEPTH(ipc4_fmt->fmt_cfg); valid_bits = SOF_IPC4_AUDIO_FORMAT_CFG_V_BIT_DEPTH(ipc4_fmt->fmt_cfg);
dev_dbg(component->dev, "Set %s to %d bit format\n", dai->name, valid_bits); dev_dbg(component->dev, "Set %s to %d bit format\n", dai->name, valid_bits);
......
...@@ -1423,7 +1423,7 @@ static int snd_sof_get_hw_config_params(struct snd_sof_dev *sdev, struct snd_sof ...@@ -1423,7 +1423,7 @@ static int snd_sof_get_hw_config_params(struct snd_sof_dev *sdev, struct snd_sof
static int static int
snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai, snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai,
bool single_format, bool single_bitdepth,
struct snd_pcm_hw_params *params, u32 dai_index, struct snd_pcm_hw_params *params, u32 dai_index,
u32 linktype, u8 dir, u32 **dst, u32 *len) u32 linktype, u8 dir, u32 **dst, u32 *len)
{ {
...@@ -1446,7 +1446,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai ...@@ -1446,7 +1446,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai
* Look for 32-bit blob first instead of 16-bit if copier * Look for 32-bit blob first instead of 16-bit if copier
* supports multiple formats * supports multiple formats
*/ */
if (bit_depth == 16 && !single_format) { if (bit_depth == 16 && !single_bitdepth) {
dev_dbg(sdev->dev, "Looking for 32-bit blob first for DMIC\n"); dev_dbg(sdev->dev, "Looking for 32-bit blob first for DMIC\n");
format_change = true; format_change = true;
bit_depth = 32; bit_depth = 32;
...@@ -1494,7 +1494,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai ...@@ -1494,7 +1494,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai
bit_depth = params_width(params); bit_depth = params_width(params);
format_change = false; format_change = false;
get_new_blob = true; get_new_blob = true;
} else if (linktype == SOF_DAI_INTEL_DMIC && !single_format) { } else if (linktype == SOF_DAI_INTEL_DMIC && !single_bitdepth) {
/* /*
* The requested 32-bit blob (no format change for the * The requested 32-bit blob (no format change for the
* blob request) was not found in NHLT table, try to * blob request) was not found in NHLT table, try to
...@@ -1550,7 +1550,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai ...@@ -1550,7 +1550,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai
#else #else
static int static int
snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai, snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai,
bool single_format, bool single_bitdepth,
struct snd_pcm_hw_params *params, u32 dai_index, struct snd_pcm_hw_params *params, u32 dai_index,
u32 linktype, u8 dir, u32 **dst, u32 *len) u32 linktype, u8 dir, u32 **dst, u32 *len)
{ {
...@@ -1558,7 +1558,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai ...@@ -1558,7 +1558,7 @@ snd_sof_get_nhlt_endpoint_data(struct snd_sof_dev *sdev, struct snd_sof_dai *dai
} }
#endif #endif
bool sof_ipc4_copier_is_single_format(struct snd_sof_dev *sdev, bool sof_ipc4_copier_is_single_bitdepth(struct snd_sof_dev *sdev,
struct sof_ipc4_pin_format *pin_fmts, struct sof_ipc4_pin_format *pin_fmts,
u32 pin_fmts_size) u32 pin_fmts_size)
{ {
...@@ -1591,7 +1591,7 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai, ...@@ -1591,7 +1591,7 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai,
struct snd_pcm_hw_params dai_params = *params; struct snd_pcm_hw_params dai_params = *params;
struct sof_ipc4_copier_data *copier_data; struct sof_ipc4_copier_data *copier_data;
struct sof_ipc4_copier *ipc4_copier; struct sof_ipc4_copier *ipc4_copier;
bool single_format; bool single_bitdepth;
int ret; int ret;
ipc4_copier = dai->private; ipc4_copier = dai->private;
...@@ -1605,12 +1605,12 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai, ...@@ -1605,12 +1605,12 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai,
* format lookup * format lookup
*/ */
if (dir == SNDRV_PCM_STREAM_PLAYBACK) { if (dir == SNDRV_PCM_STREAM_PLAYBACK) {
single_format = sof_ipc4_copier_is_single_format(sdev, single_bitdepth = sof_ipc4_copier_is_single_bitdepth(sdev,
available_fmt->output_pin_fmts, available_fmt->output_pin_fmts,
available_fmt->num_output_formats); available_fmt->num_output_formats);
/* Update the dai_params with the only supported format */ /* Update the dai_params with the only supported format */
if (single_format) { if (single_bitdepth) {
ret = sof_ipc4_update_hw_params(sdev, &dai_params, ret = sof_ipc4_update_hw_params(sdev, &dai_params,
&available_fmt->output_pin_fmts[0].audio_fmt, &available_fmt->output_pin_fmts[0].audio_fmt,
BIT(SNDRV_PCM_HW_PARAM_FORMAT)); BIT(SNDRV_PCM_HW_PARAM_FORMAT));
...@@ -1618,12 +1618,12 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai, ...@@ -1618,12 +1618,12 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai,
return ret; return ret;
} }
} else { } else {
single_format = sof_ipc4_copier_is_single_format(sdev, single_bitdepth = sof_ipc4_copier_is_single_bitdepth(sdev,
available_fmt->input_pin_fmts, available_fmt->input_pin_fmts,
available_fmt->num_input_formats); available_fmt->num_input_formats);
/* Update the dai_params with the only supported format */ /* Update the dai_params with the only supported format */
if (single_format) { if (single_bitdepth) {
ret = sof_ipc4_update_hw_params(sdev, &dai_params, ret = sof_ipc4_update_hw_params(sdev, &dai_params,
&available_fmt->input_pin_fmts[0].audio_fmt, &available_fmt->input_pin_fmts[0].audio_fmt,
BIT(SNDRV_PCM_HW_PARAM_FORMAT)); BIT(SNDRV_PCM_HW_PARAM_FORMAT));
...@@ -1632,7 +1632,7 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai, ...@@ -1632,7 +1632,7 @@ sof_ipc4_prepare_dai_copier(struct snd_sof_dev *sdev, struct snd_sof_dai *dai,
} }
} }
ret = snd_sof_get_nhlt_endpoint_data(sdev, dai, single_format, ret = snd_sof_get_nhlt_endpoint_data(sdev, dai, single_bitdepth,
&dai_params, &dai_params,
ipc4_copier->dai_index, ipc4_copier->dai_index,
ipc4_copier->dai_type, dir, ipc4_copier->dai_type, dir,
...@@ -1667,7 +1667,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget, ...@@ -1667,7 +1667,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget,
u32 out_ref_rate, out_ref_channels; u32 out_ref_rate, out_ref_channels;
u32 deep_buffer_dma_ms = 0; u32 deep_buffer_dma_ms = 0;
int output_fmt_index; int output_fmt_index;
bool single_output_format; bool single_output_bitdepth;
int i; int i;
dev_dbg(sdev->dev, "copier %s, type %d", swidget->widget->name, swidget->id); dev_dbg(sdev->dev, "copier %s, type %d", swidget->widget->name, swidget->id);
...@@ -1804,7 +1804,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget, ...@@ -1804,7 +1804,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget,
return ret; return ret;
/* set the reference params for output format selection */ /* set the reference params for output format selection */
single_output_format = sof_ipc4_copier_is_single_format(sdev, single_output_bitdepth = sof_ipc4_copier_is_single_bitdepth(sdev,
available_fmt->output_pin_fmts, available_fmt->output_pin_fmts,
available_fmt->num_output_formats); available_fmt->num_output_formats);
switch (swidget->id) { switch (swidget->id) {
...@@ -1818,7 +1818,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget, ...@@ -1818,7 +1818,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget,
out_ref_rate = in_fmt->sampling_frequency; out_ref_rate = in_fmt->sampling_frequency;
out_ref_channels = SOF_IPC4_AUDIO_FORMAT_CFG_CHANNELS_COUNT(in_fmt->fmt_cfg); out_ref_channels = SOF_IPC4_AUDIO_FORMAT_CFG_CHANNELS_COUNT(in_fmt->fmt_cfg);
if (!single_output_format) if (!single_output_bitdepth)
out_ref_valid_bits = out_ref_valid_bits =
SOF_IPC4_AUDIO_FORMAT_CFG_V_BIT_DEPTH(in_fmt->fmt_cfg); SOF_IPC4_AUDIO_FORMAT_CFG_V_BIT_DEPTH(in_fmt->fmt_cfg);
break; break;
...@@ -1827,7 +1827,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget, ...@@ -1827,7 +1827,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget,
case snd_soc_dapm_dai_in: case snd_soc_dapm_dai_in:
out_ref_rate = params_rate(fe_params); out_ref_rate = params_rate(fe_params);
out_ref_channels = params_channels(fe_params); out_ref_channels = params_channels(fe_params);
if (!single_output_format) { if (!single_output_bitdepth) {
out_ref_valid_bits = sof_ipc4_get_valid_bits(sdev, fe_params); out_ref_valid_bits = sof_ipc4_get_valid_bits(sdev, fe_params);
if (out_ref_valid_bits < 0) if (out_ref_valid_bits < 0)
return out_ref_valid_bits; return out_ref_valid_bits;
...@@ -1845,7 +1845,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget, ...@@ -1845,7 +1845,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget,
* if the output format is the same across all available output formats, choose * if the output format is the same across all available output formats, choose
* that as the reference. * that as the reference.
*/ */
if (single_output_format) { if (single_output_bitdepth) {
struct sof_ipc4_audio_format *out_fmt; struct sof_ipc4_audio_format *out_fmt;
out_fmt = &available_fmt->output_pin_fmts[0].audio_fmt; out_fmt = &available_fmt->output_pin_fmts[0].audio_fmt;
......
...@@ -476,7 +476,7 @@ struct sof_ipc4_process { ...@@ -476,7 +476,7 @@ struct sof_ipc4_process {
u32 init_config; u32 init_config;
}; };
bool sof_ipc4_copier_is_single_format(struct snd_sof_dev *sdev, bool sof_ipc4_copier_is_single_bitdepth(struct snd_sof_dev *sdev,
struct sof_ipc4_pin_format *pin_fmts, struct sof_ipc4_pin_format *pin_fmts,
u32 pin_fmts_size); u32 pin_fmts_size);
#endif #endif
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