ASoC: Fixes for v5.11
More fixes for v5.11, almost all driver specific issues including new device IDs - there's one error handling fix for the topology stuff too. -----BEGIN PGP SIGNATURE----- iQEzBAABCgAdFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAmAQCxMACgkQJNaLcl1U h9CmOwf8DWMyWBjrGyWQj6x428W+3abz/rIdyjA09H6cZoriZ9nLqerDQLmFrh/u jFvCSdla0FDE8uw33nWp9KC5KBH99JdKE9uGTMhwn/kQuOackrw6tRw7SUOwykGr MfT7Dlge8P3lwjV7/s/VrXpy0I/RTUbw1fELMn8ArqcQxO5qV32JFOWOAYIcwH+l vAPFP8ZR/aJJ42nT5TZdQTc2gEchE2KJGhmgWNu6hWLHxznW36lYIf+76DWoEcI7 pdD8MmRVyutsauaOdJj3y7LJrmUyE/f6vS9opSfiskKAvd8fq5TMP+wzMvYVwpsP 5MJVW1uVIOYzsb1DRMridM43SRon+g== =L8rT -----END PGP SIGNATURE----- Merge tag 'asoc-fix-v5.11-rc5' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus ASoC: Fixes for v5.11 More fixes for v5.11, almost all driver specific issues including new device IDs - there's one error handling fix for the topology stuff too.
This commit is contained in:
commit
49951ae308
@ -7,8 +7,8 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||
title: Mediatek MT8192 with MT6359, RT1015 and RT5682 ASoC sound card driver
|
||||
|
||||
maintainers:
|
||||
- Jiaxin Yu <jiaxin.yu@mediatek.com>
|
||||
- Shane Chien <shane.chien@mediatek.com>
|
||||
- Jiaxin Yu <jiaxin.yu@mediatek.com>
|
||||
- Shane Chien <shane.chien@mediatek.com>
|
||||
|
||||
description:
|
||||
This binding describes the MT8192 sound card.
|
||||
|
@ -2,9 +2,8 @@
|
||||
#ifndef __DT_APQ8016_LPASS_H
|
||||
#define __DT_APQ8016_LPASS_H
|
||||
|
||||
#define MI2S_PRIMARY 0
|
||||
#define MI2S_SECONDARY 1
|
||||
#define MI2S_TERTIARY 2
|
||||
#define MI2S_QUATERNARY 3
|
||||
#include <dt-bindings/sound/qcom,lpass.h>
|
||||
|
||||
/* NOTE: Use qcom,lpass.h to define any AIF ID's for LPASS */
|
||||
|
||||
#endif /* __DT_APQ8016_LPASS_H */
|
||||
|
15
include/dt-bindings/sound/qcom,lpass.h
Normal file
15
include/dt-bindings/sound/qcom,lpass.h
Normal file
@ -0,0 +1,15 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
#ifndef __DT_QCOM_LPASS_H
|
||||
#define __DT_QCOM_LPASS_H
|
||||
|
||||
#define MI2S_PRIMARY 0
|
||||
#define MI2S_SECONDARY 1
|
||||
#define MI2S_TERTIARY 2
|
||||
#define MI2S_QUATERNARY 3
|
||||
#define MI2S_QUINARY 4
|
||||
|
||||
#define LPASS_DP_RX 5
|
||||
|
||||
#define LPASS_MCLK0 0
|
||||
|
||||
#endif /* __DT_QCOM_LPASS_H */
|
@ -2,10 +2,8 @@
|
||||
#ifndef __DT_SC7180_LPASS_H
|
||||
#define __DT_SC7180_LPASS_H
|
||||
|
||||
#define MI2S_PRIMARY 0
|
||||
#define MI2S_SECONDARY 1
|
||||
#define LPASS_DP_RX 2
|
||||
#include <dt-bindings/sound/qcom,lpass.h>
|
||||
|
||||
#define LPASS_MCLK0 0
|
||||
/* NOTE: Use qcom,lpass.h to define any AIF ID's for LPASS */
|
||||
|
||||
#endif /* __DT_APQ8016_LPASS_H */
|
||||
|
@ -165,10 +165,24 @@ static int rn_acp_deinit(void __iomem *acp_base)
|
||||
|
||||
static const struct dmi_system_id rn_acp_quirk_table[] = {
|
||||
{
|
||||
/* Lenovo IdeaPad Flex 5 14ARE05, IdeaPad 5 15ARE05 */
|
||||
/* Lenovo IdeaPad S340-14API */
|
||||
.matches = {
|
||||
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "LENOVO"),
|
||||
DMI_EXACT_MATCH(DMI_BOARD_NAME, "LNVNB161216"),
|
||||
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "81NB"),
|
||||
}
|
||||
},
|
||||
{
|
||||
/* Lenovo IdeaPad Flex 5 14ARE05 */
|
||||
.matches = {
|
||||
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "LENOVO"),
|
||||
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "81X2"),
|
||||
}
|
||||
},
|
||||
{
|
||||
/* Lenovo IdeaPad 5 15ARE05 */
|
||||
.matches = {
|
||||
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "LENOVO"),
|
||||
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "81YQ"),
|
||||
}
|
||||
},
|
||||
{
|
||||
|
@ -595,18 +595,10 @@ static struct snd_soc_dai_driver ak4497_dai = {
|
||||
.ops = &ak4458_dai_ops,
|
||||
};
|
||||
|
||||
static void ak4458_power_off(struct ak4458_priv *ak4458)
|
||||
static void ak4458_reset(struct ak4458_priv *ak4458, bool active)
|
||||
{
|
||||
if (ak4458->reset_gpiod) {
|
||||
gpiod_set_value_cansleep(ak4458->reset_gpiod, 0);
|
||||
usleep_range(1000, 2000);
|
||||
}
|
||||
}
|
||||
|
||||
static void ak4458_power_on(struct ak4458_priv *ak4458)
|
||||
{
|
||||
if (ak4458->reset_gpiod) {
|
||||
gpiod_set_value_cansleep(ak4458->reset_gpiod, 1);
|
||||
gpiod_set_value_cansleep(ak4458->reset_gpiod, active);
|
||||
usleep_range(1000, 2000);
|
||||
}
|
||||
}
|
||||
@ -620,7 +612,7 @@ static int ak4458_init(struct snd_soc_component *component)
|
||||
if (ak4458->mute_gpiod)
|
||||
gpiod_set_value_cansleep(ak4458->mute_gpiod, 1);
|
||||
|
||||
ak4458_power_on(ak4458);
|
||||
ak4458_reset(ak4458, false);
|
||||
|
||||
ret = snd_soc_component_update_bits(component, AK4458_00_CONTROL1,
|
||||
0x80, 0x80); /* ACKS bit = 1; 10000000 */
|
||||
@ -650,7 +642,7 @@ static void ak4458_remove(struct snd_soc_component *component)
|
||||
{
|
||||
struct ak4458_priv *ak4458 = snd_soc_component_get_drvdata(component);
|
||||
|
||||
ak4458_power_off(ak4458);
|
||||
ak4458_reset(ak4458, true);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_PM
|
||||
@ -660,7 +652,7 @@ static int __maybe_unused ak4458_runtime_suspend(struct device *dev)
|
||||
|
||||
regcache_cache_only(ak4458->regmap, true);
|
||||
|
||||
ak4458_power_off(ak4458);
|
||||
ak4458_reset(ak4458, true);
|
||||
|
||||
if (ak4458->mute_gpiod)
|
||||
gpiod_set_value_cansleep(ak4458->mute_gpiod, 0);
|
||||
@ -685,8 +677,8 @@ static int __maybe_unused ak4458_runtime_resume(struct device *dev)
|
||||
if (ak4458->mute_gpiod)
|
||||
gpiod_set_value_cansleep(ak4458->mute_gpiod, 1);
|
||||
|
||||
ak4458_power_off(ak4458);
|
||||
ak4458_power_on(ak4458);
|
||||
ak4458_reset(ak4458, true);
|
||||
ak4458_reset(ak4458, false);
|
||||
|
||||
regcache_cache_only(ak4458->regmap, false);
|
||||
regcache_mark_dirty(ak4458->regmap);
|
||||
|
@ -2031,11 +2031,14 @@ static struct wm_coeff_ctl *wm_adsp_get_ctl(struct wm_adsp *dsp,
|
||||
unsigned int alg)
|
||||
{
|
||||
struct wm_coeff_ctl *pos, *rslt = NULL;
|
||||
const char *fw_txt = wm_adsp_fw_text[dsp->fw];
|
||||
|
||||
list_for_each_entry(pos, &dsp->ctl_list, list) {
|
||||
if (!pos->subname)
|
||||
continue;
|
||||
if (strncmp(pos->subname, name, pos->subname_len) == 0 &&
|
||||
strncmp(pos->fw_name, fw_txt,
|
||||
SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 0 &&
|
||||
pos->alg_region.alg == alg &&
|
||||
pos->alg_region.type == type) {
|
||||
rslt = pos;
|
||||
|
@ -67,6 +67,16 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
|
||||
.driver_data = (void *)(SOF_RT711_JD_SRC_JD2 |
|
||||
SOF_RT715_DAI_ID_FIX),
|
||||
},
|
||||
{
|
||||
.callback = sof_sdw_quirk_cb,
|
||||
.matches = {
|
||||
DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc"),
|
||||
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A5E")
|
||||
},
|
||||
.driver_data = (void *)(SOF_RT711_JD_SRC_JD2 |
|
||||
SOF_RT715_DAI_ID_FIX |
|
||||
SOF_SDW_FOUR_SPK),
|
||||
},
|
||||
{
|
||||
.callback = sof_sdw_quirk_cb,
|
||||
.matches = {
|
||||
|
@ -3619,19 +3619,20 @@ static void skl_tplg_complete(struct snd_soc_component *component)
|
||||
|
||||
list_for_each_entry(dobj, &component->dobj_list, list) {
|
||||
struct snd_kcontrol *kcontrol = dobj->control.kcontrol;
|
||||
struct soc_enum *se =
|
||||
(struct soc_enum *)kcontrol->private_value;
|
||||
char **texts = dobj->control.dtexts;
|
||||
struct soc_enum *se;
|
||||
char **texts;
|
||||
char chan_text[4];
|
||||
|
||||
if (dobj->type != SND_SOC_DOBJ_ENUM ||
|
||||
dobj->control.kcontrol->put !=
|
||||
skl_tplg_multi_config_set_dmic)
|
||||
if (dobj->type != SND_SOC_DOBJ_ENUM || !kcontrol ||
|
||||
kcontrol->put != skl_tplg_multi_config_set_dmic)
|
||||
continue;
|
||||
|
||||
se = (struct soc_enum *)kcontrol->private_value;
|
||||
texts = dobj->control.dtexts;
|
||||
sprintf(chan_text, "c%d", mach->mach_params.dmic_num);
|
||||
|
||||
for (i = 0; i < se->items; i++) {
|
||||
struct snd_ctl_elem_value val;
|
||||
struct snd_ctl_elem_value val = {};
|
||||
|
||||
if (strstr(texts[i], chan_text)) {
|
||||
val.value.enumerated.item[0] = i;
|
||||
|
@ -532,6 +532,7 @@ static struct snd_soc_dai_link mt8183_da7219_dai_links[] = {
|
||||
.dpcm_playback = 1,
|
||||
.ignore_suspend = 1,
|
||||
.be_hw_params_fixup = mt8183_i2s_hw_params_fixup,
|
||||
.ignore = 1,
|
||||
.init = mt8183_da7219_max98357_hdmi_init,
|
||||
SND_SOC_DAILINK_REG(tdm),
|
||||
},
|
||||
@ -754,8 +755,10 @@ static int mt8183_da7219_max98357_dev_probe(struct platform_device *pdev)
|
||||
}
|
||||
}
|
||||
|
||||
if (hdmi_codec && strcmp(dai_link->name, "TDM") == 0)
|
||||
if (hdmi_codec && strcmp(dai_link->name, "TDM") == 0) {
|
||||
dai_link->codecs->of_node = hdmi_codec;
|
||||
dai_link->ignore = 0;
|
||||
}
|
||||
|
||||
if (!dai_link->platforms->name)
|
||||
dai_link->platforms->of_node = platform_node;
|
||||
|
@ -515,6 +515,7 @@ static struct snd_soc_dai_link mt8183_mt6358_ts3a227_dai_links[] = {
|
||||
.ignore_suspend = 1,
|
||||
.be_hw_params_fixup = mt8183_i2s_hw_params_fixup,
|
||||
.ops = &mt8183_mt6358_tdm_ops,
|
||||
.ignore = 1,
|
||||
.init = mt8183_mt6358_ts3a227_max98357_hdmi_init,
|
||||
SND_SOC_DAILINK_REG(tdm),
|
||||
},
|
||||
@ -661,8 +662,10 @@ mt8183_mt6358_ts3a227_max98357_dev_probe(struct platform_device *pdev)
|
||||
SND_SOC_DAIFMT_CBM_CFM;
|
||||
}
|
||||
|
||||
if (hdmi_codec && strcmp(dai_link->name, "TDM") == 0)
|
||||
if (hdmi_codec && strcmp(dai_link->name, "TDM") == 0) {
|
||||
dai_link->codecs->of_node = hdmi_codec;
|
||||
dai_link->ignore = 0;
|
||||
}
|
||||
|
||||
if (!dai_link->platforms->name)
|
||||
dai_link->platforms->of_node = platform_node;
|
||||
|
@ -401,6 +401,53 @@ static const struct snd_soc_ops mt8192_mt6359_rt1015_rt5682_capture1_ops = {
|
||||
.startup = mt8192_mt6359_rt1015_rt5682_cap1_startup,
|
||||
};
|
||||
|
||||
static int
|
||||
mt8192_mt6359_rt5682_startup(struct snd_pcm_substream *substream)
|
||||
{
|
||||
static const unsigned int channels[] = {
|
||||
1, 2
|
||||
};
|
||||
static const struct snd_pcm_hw_constraint_list constraints_channels = {
|
||||
.count = ARRAY_SIZE(channels),
|
||||
.list = channels,
|
||||
.mask = 0,
|
||||
};
|
||||
static const unsigned int rates[] = {
|
||||
48000
|
||||
};
|
||||
static const struct snd_pcm_hw_constraint_list constraints_rates = {
|
||||
.count = ARRAY_SIZE(rates),
|
||||
.list = rates,
|
||||
.mask = 0,
|
||||
};
|
||||
|
||||
struct snd_soc_pcm_runtime *rtd = asoc_substream_to_rtd(substream);
|
||||
struct snd_pcm_runtime *runtime = substream->runtime;
|
||||
int ret;
|
||||
|
||||
ret = snd_pcm_hw_constraint_list(runtime, 0,
|
||||
SNDRV_PCM_HW_PARAM_CHANNELS,
|
||||
&constraints_channels);
|
||||
if (ret < 0) {
|
||||
dev_err(rtd->dev, "hw_constraint_list channels failed\n");
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = snd_pcm_hw_constraint_list(runtime, 0,
|
||||
SNDRV_PCM_HW_PARAM_RATE,
|
||||
&constraints_rates);
|
||||
if (ret < 0) {
|
||||
dev_err(rtd->dev, "hw_constraint_list rate failed\n");
|
||||
return ret;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct snd_soc_ops mt8192_mt6359_rt5682_ops = {
|
||||
.startup = mt8192_mt6359_rt5682_startup,
|
||||
};
|
||||
|
||||
/* FE */
|
||||
SND_SOC_DAILINK_DEFS(playback1,
|
||||
DAILINK_COMP_ARRAY(COMP_CPU("DL1")),
|
||||
@ -648,6 +695,7 @@ static struct snd_soc_dai_link mt8192_mt6359_dai_links[] = {
|
||||
SND_SOC_DPCM_TRIGGER_PRE},
|
||||
.dynamic = 1,
|
||||
.dpcm_playback = 1,
|
||||
.ops = &mt8192_mt6359_rt5682_ops,
|
||||
SND_SOC_DAILINK_REG(playback3),
|
||||
},
|
||||
{
|
||||
@ -721,6 +769,7 @@ static struct snd_soc_dai_link mt8192_mt6359_dai_links[] = {
|
||||
SND_SOC_DPCM_TRIGGER_PRE},
|
||||
.dynamic = 1,
|
||||
.dpcm_capture = 1,
|
||||
.ops = &mt8192_mt6359_rt5682_ops,
|
||||
SND_SOC_DAILINK_REG(capture2),
|
||||
},
|
||||
{
|
||||
|
@ -344,8 +344,30 @@ int asoc_qcom_lpass_cpu_dai_probe(struct snd_soc_dai *dai)
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(asoc_qcom_lpass_cpu_dai_probe);
|
||||
|
||||
static int asoc_qcom_of_xlate_dai_name(struct snd_soc_component *component,
|
||||
struct of_phandle_args *args,
|
||||
const char **dai_name)
|
||||
{
|
||||
struct lpass_data *drvdata = snd_soc_component_get_drvdata(component);
|
||||
struct lpass_variant *variant = drvdata->variant;
|
||||
int id = args->args[0];
|
||||
int ret = -EINVAL;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < variant->num_dai; i++) {
|
||||
if (variant->dai_driver[i].id == id) {
|
||||
*dai_name = variant->dai_driver[i].name;
|
||||
ret = 0;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver lpass_cpu_comp_driver = {
|
||||
.name = "lpass-cpu",
|
||||
.of_xlate_dai_name = asoc_qcom_of_xlate_dai_name,
|
||||
};
|
||||
|
||||
static bool lpass_cpu_regmap_writeable(struct device *dev, unsigned int reg)
|
||||
|
@ -131,7 +131,7 @@ static struct lpass_variant ipq806x_data = {
|
||||
.micmode = REG_FIELD_ID(0x0010, 4, 7, 5, 0x4),
|
||||
.micmono = REG_FIELD_ID(0x0010, 3, 3, 5, 0x4),
|
||||
.wssrc = REG_FIELD_ID(0x0010, 2, 2, 5, 0x4),
|
||||
.bitwidth = REG_FIELD_ID(0x0010, 0, 0, 5, 0x4),
|
||||
.bitwidth = REG_FIELD_ID(0x0010, 0, 1, 5, 0x4),
|
||||
|
||||
.rdma_dyncclk = REG_FIELD_ID(0x6000, 12, 12, 4, 0x1000),
|
||||
.rdma_bursten = REG_FIELD_ID(0x6000, 11, 11, 4, 0x1000),
|
||||
|
@ -133,7 +133,7 @@
|
||||
#define LPAIF_WRDMAPERCNT_REG(v, chan) LPAIF_WRDMA_REG_ADDR(v, 0x14, (chan))
|
||||
|
||||
#define LPAIF_INTFDMA_REG(v, chan, reg, dai_id) \
|
||||
((v->dai_driver[dai_id].id == LPASS_DP_RX) ? \
|
||||
((dai_id == LPASS_DP_RX) ? \
|
||||
LPAIF_HDMI_RDMA##reg##_REG(v, chan) : \
|
||||
LPAIF_RDMA##reg##_REG(v, chan))
|
||||
|
||||
|
@ -257,6 +257,9 @@ static int lpass_platform_pcmops_hw_params(struct snd_soc_component *component,
|
||||
break;
|
||||
case MI2S_PRIMARY:
|
||||
case MI2S_SECONDARY:
|
||||
case MI2S_TERTIARY:
|
||||
case MI2S_QUATERNARY:
|
||||
case MI2S_QUINARY:
|
||||
ret = regmap_fields_write(dmactl->intf, id,
|
||||
LPAIF_DMACTL_AUDINTF(dma_port));
|
||||
if (ret) {
|
||||
@ -507,6 +510,9 @@ static int lpass_platform_pcmops_trigger(struct snd_soc_component *component,
|
||||
break;
|
||||
case MI2S_PRIMARY:
|
||||
case MI2S_SECONDARY:
|
||||
case MI2S_TERTIARY:
|
||||
case MI2S_QUATERNARY:
|
||||
case MI2S_QUINARY:
|
||||
reg_irqclr = LPAIF_IRQCLEAR_REG(v, LPAIF_IRQ_PORT_HOST);
|
||||
val_irqclr = LPAIF_IRQ_ALL(ch);
|
||||
|
||||
@ -559,6 +565,9 @@ static int lpass_platform_pcmops_trigger(struct snd_soc_component *component,
|
||||
break;
|
||||
case MI2S_PRIMARY:
|
||||
case MI2S_SECONDARY:
|
||||
case MI2S_TERTIARY:
|
||||
case MI2S_QUATERNARY:
|
||||
case MI2S_QUINARY:
|
||||
reg_irqen = LPAIF_IRQEN_REG(v, LPAIF_IRQ_PORT_HOST);
|
||||
val_mask = LPAIF_IRQ_ALL(ch);
|
||||
val_irqen = 0;
|
||||
@ -655,6 +664,9 @@ static irqreturn_t lpass_dma_interrupt_handler(
|
||||
break;
|
||||
case MI2S_PRIMARY:
|
||||
case MI2S_SECONDARY:
|
||||
case MI2S_TERTIARY:
|
||||
case MI2S_QUATERNARY:
|
||||
case MI2S_QUINARY:
|
||||
map = drvdata->lpaif_map;
|
||||
reg = LPAIF_IRQCLEAR_REG(v, LPAIF_IRQ_PORT_HOST);
|
||||
val = 0;
|
||||
|
@ -20,7 +20,7 @@
|
||||
#include "lpass.h"
|
||||
|
||||
static struct snd_soc_dai_driver sc7180_lpass_cpu_dai_driver[] = {
|
||||
[MI2S_PRIMARY] = {
|
||||
{
|
||||
.id = MI2S_PRIMARY,
|
||||
.name = "Primary MI2S",
|
||||
.playback = {
|
||||
@ -44,9 +44,7 @@ static struct snd_soc_dai_driver sc7180_lpass_cpu_dai_driver[] = {
|
||||
},
|
||||
.probe = &asoc_qcom_lpass_cpu_dai_probe,
|
||||
.ops = &asoc_qcom_lpass_cpu_dai_ops,
|
||||
},
|
||||
|
||||
[MI2S_SECONDARY] = {
|
||||
}, {
|
||||
.id = MI2S_SECONDARY,
|
||||
.name = "Secondary MI2S",
|
||||
.playback = {
|
||||
@ -60,8 +58,7 @@ static struct snd_soc_dai_driver sc7180_lpass_cpu_dai_driver[] = {
|
||||
},
|
||||
.probe = &asoc_qcom_lpass_cpu_dai_probe,
|
||||
.ops = &asoc_qcom_lpass_cpu_dai_ops,
|
||||
},
|
||||
[LPASS_DP_RX] = {
|
||||
}, {
|
||||
.id = LPASS_DP_RX,
|
||||
.name = "Hdmi",
|
||||
.playback = {
|
||||
@ -174,7 +171,7 @@ static struct lpass_variant sc7180_data = {
|
||||
.rdma_channels = 5,
|
||||
.hdmi_rdma_reg_base = 0x64000,
|
||||
.hdmi_rdma_reg_stride = 0x1000,
|
||||
.hdmi_rdma_channels = 4,
|
||||
.hdmi_rdma_channels = 3,
|
||||
.dmactl_audif_start = 1,
|
||||
.wrdma_reg_base = 0x18000,
|
||||
.wrdma_reg_stride = 0x1000,
|
||||
|
@ -12,7 +12,7 @@
|
||||
#include <linux/compiler.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/regmap.h>
|
||||
#include <dt-bindings/sound/sc7180-lpass.h>
|
||||
#include <dt-bindings/sound/qcom,lpass.h>
|
||||
#include "lpass-hdmi.h"
|
||||
|
||||
#define LPASS_AHBIX_CLOCK_FREQUENCY 131072000
|
||||
|
@ -447,7 +447,7 @@ static void remove_dai(struct snd_soc_component *comp,
|
||||
{
|
||||
struct snd_soc_dai_driver *dai_drv =
|
||||
container_of(dobj, struct snd_soc_dai_driver, dobj);
|
||||
struct snd_soc_dai *dai;
|
||||
struct snd_soc_dai *dai, *_dai;
|
||||
|
||||
if (pass != SOC_TPLG_PASS_PCM_DAI)
|
||||
return;
|
||||
@ -455,9 +455,9 @@ static void remove_dai(struct snd_soc_component *comp,
|
||||
if (dobj->ops && dobj->ops->dai_unload)
|
||||
dobj->ops->dai_unload(comp, dobj);
|
||||
|
||||
for_each_component_dais(comp, dai)
|
||||
for_each_component_dais_safe(comp, dai, _dai)
|
||||
if (dai->driver == dai_drv)
|
||||
dai->driver = NULL;
|
||||
snd_soc_unregister_dai(dai);
|
||||
|
||||
list_del(&dobj->list);
|
||||
}
|
||||
@ -902,7 +902,7 @@ static int soc_tplg_denum_create_values(struct soc_tplg *tplg, struct soc_enum *
|
||||
return -EINVAL;
|
||||
|
||||
se->dobj.control.dvalues = devm_kcalloc(tplg->dev, le32_to_cpu(ec->items),
|
||||
sizeof(u32),
|
||||
sizeof(*se->dobj.control.dvalues),
|
||||
GFP_KERNEL);
|
||||
if (!se->dobj.control.dvalues)
|
||||
return -ENOMEM;
|
||||
@ -1742,7 +1742,7 @@ static int soc_tplg_dai_create(struct soc_tplg *tplg,
|
||||
list_add(&dai_drv->dobj.list, &tplg->comp->dobj_list);
|
||||
|
||||
/* register the DAI to the component */
|
||||
dai = devm_snd_soc_register_dai(tplg->dev, tplg->comp, dai_drv, false);
|
||||
dai = snd_soc_register_dai(tplg->comp, dai_drv, false);
|
||||
if (!dai)
|
||||
return -ENOMEM;
|
||||
|
||||
@ -1750,6 +1750,7 @@ static int soc_tplg_dai_create(struct soc_tplg *tplg,
|
||||
ret = snd_soc_dapm_new_dai_widgets(dapm, dai);
|
||||
if (ret != 0) {
|
||||
dev_err(dai->dev, "Failed to create DAI widgets %d\n", ret);
|
||||
snd_soc_unregister_dai(dai);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -355,7 +355,7 @@ config SND_SOC_SOF_HDA
|
||||
|
||||
config SND_SOC_SOF_INTEL_SOUNDWIRE_LINK
|
||||
bool "SOF support for SoundWire"
|
||||
depends on SOUNDWIRE && ACPI
|
||||
depends on ACPI
|
||||
help
|
||||
This adds support for SoundWire with Sound Open Firmware
|
||||
for Intel(R) platforms.
|
||||
@ -371,6 +371,7 @@ config SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE
|
||||
|
||||
config SND_SOC_SOF_INTEL_SOUNDWIRE
|
||||
tristate
|
||||
select SOUNDWIRE
|
||||
select SOUNDWIRE_INTEL
|
||||
help
|
||||
This option is not user-selectable but automagically handled by
|
||||
|
@ -131,12 +131,13 @@ static int sof_acpi_probe(struct platform_device *pdev)
|
||||
if (!id)
|
||||
return -ENODEV;
|
||||
|
||||
ret = snd_intel_acpi_dsp_driver_probe(dev, id->id);
|
||||
if (ret != SND_INTEL_DSP_DRIVER_ANY && ret != SND_INTEL_DSP_DRIVER_SOF) {
|
||||
dev_dbg(dev, "SOF ACPI driver not selected, aborting probe\n");
|
||||
return -ENODEV;
|
||||
if (IS_REACHABLE(CONFIG_SND_INTEL_DSP_CONFIG)) {
|
||||
ret = snd_intel_acpi_dsp_driver_probe(dev, id->id);
|
||||
if (ret != SND_INTEL_DSP_DRIVER_ANY && ret != SND_INTEL_DSP_DRIVER_SOF) {
|
||||
dev_dbg(dev, "SOF ACPI driver not selected, aborting probe\n");
|
||||
return -ENODEV;
|
||||
}
|
||||
}
|
||||
|
||||
dev_dbg(dev, "ACPI DSP detected");
|
||||
|
||||
sof_pdata = devm_kzalloc(dev, sizeof(*sof_pdata), GFP_KERNEL);
|
||||
|
@ -344,10 +344,12 @@ static int sof_pci_probe(struct pci_dev *pci,
|
||||
const struct snd_sof_dsp_ops *ops;
|
||||
int ret;
|
||||
|
||||
ret = snd_intel_dsp_driver_probe(pci);
|
||||
if (ret != SND_INTEL_DSP_DRIVER_ANY && ret != SND_INTEL_DSP_DRIVER_SOF) {
|
||||
dev_dbg(&pci->dev, "SOF PCI driver not selected, aborting probe\n");
|
||||
return -ENODEV;
|
||||
if (IS_REACHABLE(CONFIG_SND_INTEL_DSP_CONFIG)) {
|
||||
ret = snd_intel_dsp_driver_probe(pci);
|
||||
if (ret != SND_INTEL_DSP_DRIVER_ANY && ret != SND_INTEL_DSP_DRIVER_SOF) {
|
||||
dev_dbg(&pci->dev, "SOF PCI driver not selected, aborting probe\n");
|
||||
return -ENODEV;
|
||||
}
|
||||
}
|
||||
dev_dbg(&pci->dev, "PCI DSP detected");
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user