[Sound-open-firmware] SoF support for 8086:9d71?
Pierre-Louis Bossart
pierre-louis.bossart at linux.intel.com
Tue Dec 15 18:21:19 CET 2020
On 12/14/20 9:54 PM, Kai-Heng Feng wrote:
>
>
> On Mon, Dec 14, 2020 at 13:33, Pierre-Louis Bossart
> <pierre-louis.bossart at linux.intel.com> wrote:
>>
>>> On more recent kernels legacy HDA stops working for device 8086:9d71:
>>> [ 47.211381] snd_hda_intel 0000:00:1f.3: DSP detected with PCI
>>> class/subclass/prog-if info 0x040100
>>> [ 47.211383] snd_hda_intel 0000:00:1f.3: Digital mics found on
>>> Skylake+ platform, using SST driver
>>>
>>> However, only legacy HDA supports it:
>>> 00:1f.3 Multimedia audio controller [0401]: Intel Corporation
>>> Sunrise Point-LP HD Audio [8086:9d71] (rev 21)
>>> ..
>>> Kernel modules: snd_hda_intel
>>>
>>> Ubuntu kernel doesn't select SND_SOC_INTEL_SKYLAKE, which builds
>>> snd-soc-skl, because based on the Kconfig description SOF should
>>> support it.
>>>
>>> I wonder if SND_SOC_INTEL_SKYLAKE should be select again?
>>
>> SOF does not support Skylake and Kabylake, and only the Up2 board for
>> APL. I am not sure what you mean by 'recent' kernels since this
>> dynamic selection has been in place for a year now?
>
> Ubuntu kernel only changed this in 20.10 release.
>
>>
>> At any rate, to make this work again:
>>
>> 1. You can select SND_SOC_INTEL_SKYLAKE or alternatively to be more
>> accurate:
>>
>> SND_SOC_INTEL_SKL
>> SND_SOC_INTEL_APL
>> SND_SOC_INTEL_KBL
>>
>> There are known issues with Conexant codecs, typically on HP devices,
>> only Realtek codecs are supported.
>
> Right, so we can't really enable this for generic distros like Ubuntu.
>
> Let me think of a more generic solution.
Re-thinking about this, I actually don't know how this problem occurred:
the tables are conditionally built so you would only select SST if you
had the drivers compiled in.
see sound/hda/intel-dsp-config.c:
/* Kabylake-LP */
#if IS_ENABLED(CONFIG_SND_SOC_INTEL_KBL)
{
.flags = FLAG_SST,
.device = 0x9d71,
.dmi_table = (const struct dmi_system_id []) {
{
.ident = "Google Chromebooks",
.matches = {
DMI_MATCH(DMI_SYS_VENDOR, "Google"),
}
},
{}
}
},
{
.flags = FLAG_SST | FLAG_SST_ONLY_IF_DMIC,
.device = 0x9d71,
},
#endif
Something's not adding up here.
More information about the Alsa-devel
mailing list