mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-08 21:53:54 +08:00
Merge series "ASoC: Intel: machine driver updates for 5.9" from Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>:
Small patchset to harden the SoundWire machine driver, change bad
HIDs, update PLL settings and avoid memory leaks. Given that the
SoundWire core parts are not upstream it's probably not necessary to
provide the patches to stable branches.
Bard Liao (1):
ASoC: Intel: sof_sdw_rt711: remove hard-coded codec name
Kai Vehmanen (2):
ASoC: Intel: sof_sdw: add support for systems without i915 audio
ASoC: Intel: sof_sdw: avoid crash if invalid DSP topology loaded
Libin Yang (1):
ASoC: Intel: common: change match table ehl-rt5660
Pierre-Louis Bossart (1):
ASoC: Intel: sof_sdw_rt711: remove properties in card remove
Yong Zhi (1):
ASoC: intel: board: sof_rt5682: Update rt1015 pll input clk freq
sound/soc/intel/boards/sof_rt5682.c | 9 +++++-
sound/soc/intel/boards/sof_sdw.c | 31 +++++++++++++------
sound/soc/intel/boards/sof_sdw_common.h | 2 ++
sound/soc/intel/boards/sof_sdw_hdmi.c | 6 ++++
sound/soc/intel/boards/sof_sdw_rt711.c | 17 +++++++++-
.../intel/common/soc-acpi-intel-ehl-match.c | 2 +-
6 files changed, 54 insertions(+), 13 deletions(-)
base-commit: 22e9b54307
--
2.25.1
This commit is contained in:
commit
b518202033
@ -284,8 +284,15 @@ static int sof_rt1015_hw_params(struct snd_pcm_substream *substream,
|
||||
return 0;
|
||||
|
||||
for_each_rtd_codec_dais(rtd, i, codec_dai) {
|
||||
/* Set tdm/i2s1 master bclk ratio */
|
||||
ret = snd_soc_dai_set_bclk_ratio(codec_dai, 64);
|
||||
if (ret < 0) {
|
||||
dev_err(card->dev, "failed to set bclk ratio\n");
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = snd_soc_dai_set_pll(codec_dai, 0, RT1015_PLL_S_BCLK,
|
||||
params_rate(params) * 50,
|
||||
params_rate(params) * 64,
|
||||
params_rate(params) * 256);
|
||||
if (ret < 0) {
|
||||
dev_err(card->dev, "failed to set pll\n");
|
||||
|
@ -217,6 +217,7 @@ static struct sof_sdw_codec_info codec_info_list[] = {
|
||||
.direction = {true, true},
|
||||
.dai_name = "rt711-aif1",
|
||||
.init = sof_sdw_rt711_init,
|
||||
.exit = sof_sdw_rt711_exit,
|
||||
},
|
||||
{
|
||||
.id = 0x1308,
|
||||
@ -698,11 +699,14 @@ static inline int get_next_be_id(struct snd_soc_dai_link *links,
|
||||
return links[be_id - 1].id + 1;
|
||||
}
|
||||
|
||||
#define IDISP_CODEC_MASK 0x4
|
||||
|
||||
static int sof_card_dai_links_create(struct device *dev,
|
||||
struct snd_soc_acpi_mach *mach,
|
||||
struct snd_soc_card *card)
|
||||
{
|
||||
int ssp_num, sdw_be_num = 0, hdmi_num = 0, dmic_num;
|
||||
struct mc_private *ctx = snd_soc_card_get_drvdata(card);
|
||||
struct snd_soc_dai_link_component *idisp_components;
|
||||
struct snd_soc_dai_link_component *ssp_components;
|
||||
struct snd_soc_acpi_mach_params *mach_params;
|
||||
@ -746,12 +750,15 @@ static int sof_card_dai_links_create(struct device *dev,
|
||||
return ret;
|
||||
}
|
||||
|
||||
if (mach_params->codec_mask & IDISP_CODEC_MASK)
|
||||
ctx->idisp_codec = true;
|
||||
|
||||
/* enable dmic01 & dmic16k */
|
||||
dmic_num = (sof_sdw_quirk & SOF_SDW_PCH_DMIC) ? 2 : 0;
|
||||
comp_num += dmic_num;
|
||||
|
||||
dev_dbg(dev, "sdw %d, ssp %d, dmic %d, hdmi %d", sdw_be_num, ssp_num,
|
||||
dmic_num, hdmi_num);
|
||||
dmic_num, ctx->idisp_codec ? hdmi_num : 0);
|
||||
|
||||
/* allocate BE dailinks */
|
||||
num_links = comp_num + sdw_be_num;
|
||||
@ -900,13 +907,18 @@ DMIC:
|
||||
if (!name)
|
||||
return -ENOMEM;
|
||||
|
||||
idisp_components[i].name = "ehdaudio0D2";
|
||||
idisp_components[i].dai_name = devm_kasprintf(dev,
|
||||
GFP_KERNEL,
|
||||
"intel-hdmi-hifi%d",
|
||||
i + 1);
|
||||
if (!idisp_components[i].dai_name)
|
||||
return -ENOMEM;
|
||||
if (ctx->idisp_codec) {
|
||||
idisp_components[i].name = "ehdaudio0D2";
|
||||
idisp_components[i].dai_name = devm_kasprintf(dev,
|
||||
GFP_KERNEL,
|
||||
"intel-hdmi-hifi%d",
|
||||
i + 1);
|
||||
if (!idisp_components[i].dai_name)
|
||||
return -ENOMEM;
|
||||
} else {
|
||||
idisp_components[i].name = "snd-soc-dummy";
|
||||
idisp_components[i].dai_name = "snd-soc-dummy-dai";
|
||||
}
|
||||
|
||||
cpu_name = devm_kasprintf(dev, GFP_KERNEL,
|
||||
"iDisp%d Pin", i + 1);
|
||||
@ -981,6 +993,7 @@ static int mc_probe(struct platform_device *pdev)
|
||||
INIT_LIST_HEAD(&ctx->hdmi_pcm_list);
|
||||
|
||||
card->dev = &pdev->dev;
|
||||
snd_soc_card_set_drvdata(card, ctx);
|
||||
|
||||
mach = pdev->dev.platform_data;
|
||||
ret = sof_card_dai_links_create(&pdev->dev, mach,
|
||||
@ -990,8 +1003,6 @@ static int mc_probe(struct platform_device *pdev)
|
||||
|
||||
ctx->common_hdmi_codec_drv = mach->mach_params.common_hdmi_codec_drv;
|
||||
|
||||
snd_soc_card_set_drvdata(card, ctx);
|
||||
|
||||
/*
|
||||
* the default amp_num is zero for each codec and
|
||||
* amp_num will only be increased for active amp
|
||||
|
@ -70,6 +70,7 @@ struct sof_sdw_codec_info {
|
||||
struct mc_private {
|
||||
struct list_head hdmi_pcm_list;
|
||||
bool common_hdmi_codec_drv;
|
||||
bool idisp_codec;
|
||||
struct snd_soc_jack sdw_headset;
|
||||
};
|
||||
|
||||
@ -91,6 +92,7 @@ int sof_sdw_rt711_init(const struct snd_soc_acpi_link_adr *link,
|
||||
struct snd_soc_dai_link *dai_links,
|
||||
struct sof_sdw_codec_info *info,
|
||||
bool playback);
|
||||
int sof_sdw_rt711_exit(struct device *dev, struct snd_soc_dai_link *dai_link);
|
||||
|
||||
/* RT700 support */
|
||||
int sof_sdw_rt700_init(const struct snd_soc_acpi_link_adr *link,
|
||||
|
@ -52,6 +52,12 @@ int sof_sdw_hdmi_card_late_probe(struct snd_soc_card *card)
|
||||
int err, i = 0;
|
||||
char jack_name[NAME_SIZE];
|
||||
|
||||
if (!ctx->idisp_codec)
|
||||
return 0;
|
||||
|
||||
if (list_empty(&ctx->hdmi_pcm_list))
|
||||
return -EINVAL;
|
||||
|
||||
pcm = list_first_entry(&ctx->hdmi_pcm_list, struct hdmi_pcm,
|
||||
head);
|
||||
component = pcm->codec_dai->component;
|
||||
|
@ -133,6 +133,21 @@ static int rt711_rtd_init(struct snd_soc_pcm_runtime *rtd)
|
||||
return ret;
|
||||
}
|
||||
|
||||
int sof_sdw_rt711_exit(struct device *dev, struct snd_soc_dai_link *dai_link)
|
||||
{
|
||||
struct device *sdw_dev;
|
||||
|
||||
sdw_dev = bus_find_device_by_name(&sdw_bus_type, NULL,
|
||||
dai_link->codecs[0].name);
|
||||
if (!sdw_dev)
|
||||
return -EINVAL;
|
||||
|
||||
device_remove_properties(sdw_dev);
|
||||
put_device(sdw_dev);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sof_sdw_rt711_init(const struct snd_soc_acpi_link_adr *link,
|
||||
struct snd_soc_dai_link *dai_links,
|
||||
struct sof_sdw_codec_info *info,
|
||||
@ -147,7 +162,7 @@ int sof_sdw_rt711_init(const struct snd_soc_acpi_link_adr *link,
|
||||
if (!playback)
|
||||
return 0;
|
||||
|
||||
ret = rt711_add_codec_device_props("sdw:0:25d:711:0");
|
||||
ret = rt711_add_codec_device_props(dai_links->codecs[0].name);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user