asoc: get hw params for auto target

soc-util no longer sets hw params for snd-soc-dummy components.
pcm_open() is blocked by snd_pcm_hw_constraints_complete() function.
read hw params from dts and set it during dailink startup.

Change-Id: I0d0c6ae581c5fb72091ec6c2cadb85e93e475deb
Signed-off-by: Jiazai Wu <quic_jiazwu@quicinc.com>
This commit is contained in:
Jiazai Wu
2023-11-02 13:36:14 +05:30
parent 60687055d2
commit 08a0be98ec

View File

@@ -159,6 +159,7 @@ struct msm_asoc_mach_data {
bool mclk_used;
struct msm_pinctrl_info mclk_pinctrl_info[MCLK_MAX];
struct msm_mclk_conf mclk_conf[MCLK_MAX];
struct snd_pcm_hardware hw_params;
};
static struct platform_device *spdev;
@@ -579,6 +580,9 @@ static int tdm_snd_startup(struct snd_pcm_substream *substream)
int ret_pinctrl = 0;
int index, mclk_index;
if (!dai_link->no_pcm)
snd_soc_set_runtime_hwparams(substream, &pdata->hw_params);
index = msm_tdm_get_intf_idx(dai_link->id);
if (index < 0) {
ret = -EINVAL;
@@ -1190,6 +1194,75 @@ static struct snd_soc_card *populate_snd_card_dailinks(struct device *dev)
return card;
}
static int msm_get_hwparams(struct platform_device *pdev)
{
struct snd_soc_card *card = NULL;
struct msm_asoc_mach_data *pdata = NULL;
u32 pcm_info = 0;
u32 buffer_bytes_max = 0;
u32 periods_bytes[2] = {0};
u32 periods_count[2] = {0};
int ret = 0;
card = platform_get_drvdata(pdev);
if (!card) {
pr_err("%s: card is NULL\n",
__func__);
return -EINVAL;
}
pdata = snd_soc_card_get_drvdata(card);
if (!pdata) {
pr_err("%s: pdata is NULL\n",
__func__);
return -EINVAL;
}
ret = of_property_read_u32(pdev->dev.of_node,
"qcom,hw_pcm_info",
&pcm_info);
if (ret) {
pr_err("%s: read pcm info failed\n",
__func__);
return ret;
}
ret = of_property_read_u32(pdev->dev.of_node,
"qcom,hw_buffer_size_max",
&buffer_bytes_max);
if (ret) {
pr_err("%s: read buffer size max failed\n",
__func__);
return ret;
}
ret = of_property_read_u32_array(pdev->dev.of_node,
"qcom,hw_period_byte_size",
periods_bytes, 2);
if (ret) {
pr_err("%s: read period byte size failed\n",
__func__);
return ret;
}
ret = of_property_read_u32_array(pdev->dev.of_node,
"qcom,hw_period_count_size",
periods_count, 2);
if (ret) {
pr_err("%s: read period count size failed\n",
__func__);
return ret;
}
pdata->hw_params.info = pcm_info;
pdata->hw_params.buffer_bytes_max = buffer_bytes_max;
pdata->hw_params.period_bytes_min = periods_bytes[0];
pdata->hw_params.period_bytes_max = periods_bytes[1];
pdata->hw_params.periods_min = periods_count[0];
pdata->hw_params.periods_max = periods_count[1];
return ret;
}
struct msm_common_pdata *msm_common_get_pdata(struct snd_soc_card *card)
{
struct msm_asoc_mach_data *pdata = snd_soc_card_get_drvdata(card);
@@ -1518,6 +1591,14 @@ static int msm_asoc_machine_probe(struct platform_device *pdev)
}
}
ret = msm_get_hwparams(pdev);
if (ret) {
dev_err(&pdev->dev,
"%s: hwparams get failed with %d\n",
__func__, ret);
goto err;
}
dev_info(&pdev->dev, "Sound card %s registered\n",
card->name);
pr_err("Sound card %s registered\n",