2021-11-17 02:37:20 -07:00
|
|
|
// SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause)
|
|
|
|
//
|
|
|
|
// This file is provided under a dual BSD/GPLv2 license. When using or
|
|
|
|
// redistributing this file, you may do so under either license.
|
|
|
|
//
|
2023-12-06 04:06:12 -07:00
|
|
|
// Copyright(c) 2021, 2023 Advanced Micro Devices, Inc.
|
2021-11-17 02:37:20 -07:00
|
|
|
//
|
|
|
|
// Authors: Ajit Kumar Pandey <AjitKumar.Pandey@amd.com>
|
|
|
|
//
|
|
|
|
|
|
|
|
/* ACP machine configuration module */
|
|
|
|
|
|
|
|
#include <linux/acpi.h>
|
|
|
|
#include <linux/bits.h>
|
|
|
|
#include <linux/dmi.h>
|
|
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/pci.h>
|
|
|
|
|
|
|
|
#include "../sof/amd/acp.h"
|
|
|
|
#include "mach-config.h"
|
|
|
|
|
2023-12-06 21:55:01 -07:00
|
|
|
#define ACP_7_0_REV 0x70
|
|
|
|
|
2021-11-17 02:37:20 -07:00
|
|
|
static int acp_quirk_data;
|
|
|
|
|
|
|
|
static const struct config_entry config_table[] = {
|
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_SOF,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_MATCH(DMI_SYS_VENDOR, "AMD"),
|
|
|
|
DMI_MATCH(DMI_PRODUCT_NAME, "Majolica-CZN"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2021-12-21 09:18:08 -07:00
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_SOF,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_MATCH(DMI_SYS_VENDOR, "Google"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2023-12-06 04:06:12 -07:00
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_MATCH(DMI_SYS_VENDOR, "Valve"),
|
|
|
|
DMI_MATCH(DMI_PRODUCT_NAME, "Jupiter"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2023-07-07 05:07:30 -07:00
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_SOF,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_MATCH(DMI_SYS_VENDOR, "Valve"),
|
|
|
|
DMI_MATCH(DMI_PRODUCT_NAME, "Galileo"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2023-08-29 15:01:16 -07:00
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "HUAWEI"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "KLVL-WXXW"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "M1010"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "HUAWEI"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "KLVL-WXX9"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "M1010"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "HUAWEI"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "BOM-WXX9"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "M1010"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2023-12-02 15:29:51 -07:00
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "HUAWEI"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "HVY-WXX9"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "M1010"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2023-08-29 15:01:16 -07:00
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "HUAWEI"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "HVY-WXX9"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "M1020"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.flags = FLAG_AMD_LEGACY,
|
|
|
|
.device = ACP_PCI_DEV_ID,
|
|
|
|
.dmi_table = (const struct dmi_system_id []) {
|
|
|
|
{
|
|
|
|
.matches = {
|
|
|
|
DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "HUAWEI"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "HVY-WXX9"),
|
|
|
|
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "M1040"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
},
|
2021-11-17 02:37:20 -07:00
|
|
|
};
|
|
|
|
|
2023-12-06 21:55:01 -07:00
|
|
|
static int snd_amd_acp_acpi_find_config(struct pci_dev *pci)
|
|
|
|
{
|
|
|
|
const union acpi_object *obj;
|
|
|
|
int acp_flag = FLAG_AMD_LEGACY_ONLY_DMIC;
|
|
|
|
|
|
|
|
if (!acpi_dev_get_property(ACPI_COMPANION(&pci->dev), "acp-audio-config-flag",
|
|
|
|
ACPI_TYPE_INTEGER, &obj))
|
|
|
|
acp_flag = obj->integer.value;
|
|
|
|
|
|
|
|
return acp_flag;
|
|
|
|
}
|
|
|
|
|
2021-11-17 02:37:20 -07:00
|
|
|
int snd_amd_acp_find_config(struct pci_dev *pci)
|
|
|
|
{
|
|
|
|
const struct config_entry *table = config_table;
|
|
|
|
u16 device = pci->device;
|
|
|
|
int i;
|
|
|
|
|
2023-12-06 21:55:01 -07:00
|
|
|
/* Do not enable FLAGS on older platforms with Rev Id zero
|
|
|
|
* For platforms which has ACP 7.0 or higher, read the acp
|
|
|
|
* config flag from BIOS ACPI table and for older platforms
|
|
|
|
* read it from DMI tables.
|
|
|
|
*/
|
2021-12-21 09:18:08 -07:00
|
|
|
if (!pci->revision)
|
|
|
|
return 0;
|
2023-12-06 21:55:01 -07:00
|
|
|
else if (pci->revision >= ACP_7_0_REV)
|
|
|
|
return snd_amd_acp_acpi_find_config(pci);
|
2021-12-21 09:18:08 -07:00
|
|
|
|
2021-11-17 02:37:20 -07:00
|
|
|
for (i = 0; i < ARRAY_SIZE(config_table); i++, table++) {
|
|
|
|
if (table->device != device)
|
|
|
|
continue;
|
|
|
|
if (table->dmi_table && !dmi_check_system(table->dmi_table))
|
|
|
|
continue;
|
|
|
|
acp_quirk_data = table->flags;
|
|
|
|
return table->flags;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(snd_amd_acp_find_config);
|
|
|
|
|
2021-12-21 09:18:08 -07:00
|
|
|
static struct snd_soc_acpi_codecs amp_rt1019 = {
|
|
|
|
.num_codecs = 1,
|
|
|
|
.codecs = {"10EC1019"}
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct snd_soc_acpi_codecs amp_max = {
|
|
|
|
.num_codecs = 1,
|
|
|
|
.codecs = {"MX98360A"}
|
|
|
|
};
|
|
|
|
|
2023-07-07 05:07:29 -07:00
|
|
|
static struct snd_soc_acpi_codecs amp_max98388 = {
|
|
|
|
.num_codecs = 1,
|
|
|
|
.codecs = {"ADS8388"}
|
|
|
|
};
|
|
|
|
|
2021-11-17 02:37:20 -07:00
|
|
|
struct snd_soc_acpi_mach snd_soc_acpi_amd_sof_machines[] = {
|
2021-12-21 09:18:08 -07:00
|
|
|
{
|
|
|
|
.id = "10EC5682",
|
|
|
|
.drv_name = "rt5682-rt1019",
|
|
|
|
.pdata = (void *)&acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_rt1019,
|
|
|
|
.fw_filename = "sof-rn.ri",
|
2021-12-21 09:18:09 -07:00
|
|
|
.sof_tplg_filename = "sof-rn-rt5682-rt1019.tplg",
|
2021-12-21 09:18:08 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
.id = "10EC5682",
|
|
|
|
.drv_name = "rt5682-max",
|
|
|
|
.pdata = (void *)&acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_max,
|
|
|
|
.fw_filename = "sof-rn.ri",
|
2021-12-21 09:18:09 -07:00
|
|
|
.sof_tplg_filename = "sof-rn-rt5682-max98360.tplg",
|
2021-12-21 09:18:08 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
.id = "RTL5682",
|
|
|
|
.drv_name = "rt5682s-max",
|
|
|
|
.pdata = (void *)&acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_max,
|
|
|
|
.fw_filename = "sof-rn.ri",
|
2021-12-21 09:18:09 -07:00
|
|
|
.sof_tplg_filename = "sof-rn-rt5682-max98360.tplg",
|
2021-12-21 09:18:08 -07:00
|
|
|
},
|
2022-01-22 12:46:59 -07:00
|
|
|
{
|
|
|
|
.id = "RTL5682",
|
|
|
|
.drv_name = "rt5682s-rt1019",
|
|
|
|
.pdata = (void *)&acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_rt1019,
|
|
|
|
.fw_filename = "sof-rn.ri",
|
|
|
|
.sof_tplg_filename = "sof-rn-rt5682-rt1019.tplg",
|
|
|
|
},
|
2021-11-17 02:37:20 -07:00
|
|
|
{
|
|
|
|
.id = "AMDI1019",
|
|
|
|
.drv_name = "renoir-dsp",
|
|
|
|
.pdata = (void *)&acp_quirk_data,
|
|
|
|
.fw_filename = "sof-rn.ri",
|
|
|
|
.sof_tplg_filename = "sof-acp.tplg",
|
|
|
|
},
|
|
|
|
{},
|
|
|
|
};
|
|
|
|
EXPORT_SYMBOL(snd_soc_acpi_amd_sof_machines);
|
|
|
|
|
2023-07-07 05:07:29 -07:00
|
|
|
struct snd_soc_acpi_mach snd_soc_acpi_amd_vangogh_sof_machines[] = {
|
|
|
|
{
|
|
|
|
.id = "NVTN2020",
|
|
|
|
.drv_name = "nau8821-max",
|
|
|
|
.pdata = &acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_max98388,
|
|
|
|
.fw_filename = "sof-vangogh.ri",
|
|
|
|
.sof_tplg_filename = "sof-vangogh-nau8821-max.tplg",
|
|
|
|
},
|
|
|
|
{},
|
|
|
|
};
|
|
|
|
EXPORT_SYMBOL(snd_soc_acpi_amd_vangogh_sof_machines);
|
|
|
|
|
2022-05-31 05:08:11 -07:00
|
|
|
struct snd_soc_acpi_mach snd_soc_acpi_amd_rmb_sof_machines[] = {
|
|
|
|
{
|
|
|
|
.id = "AMDI1019",
|
|
|
|
.drv_name = "rmb-dsp",
|
|
|
|
.pdata = &acp_quirk_data,
|
|
|
|
.fw_filename = "sof-rmb.ri",
|
|
|
|
.sof_tplg_filename = "sof-acp-rmb.tplg",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.id = "10508825",
|
|
|
|
.drv_name = "nau8825-max",
|
|
|
|
.pdata = &acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_max,
|
|
|
|
.fw_filename = "sof-rmb.ri",
|
|
|
|
.sof_tplg_filename = "sof-rmb-nau8825-max98360.tplg",
|
|
|
|
},
|
2022-05-31 05:08:12 -07:00
|
|
|
{
|
|
|
|
.id = "RTL5682",
|
|
|
|
.drv_name = "rt5682s-hs-rt1019",
|
|
|
|
.pdata = &acp_quirk_data,
|
|
|
|
.machine_quirk = snd_soc_acpi_codec_list,
|
|
|
|
.quirk_data = &_rt1019,
|
|
|
|
.fw_filename = "sof-rmb.ri",
|
|
|
|
.sof_tplg_filename = "sof-rmb-rt5682s-rt1019.tplg",
|
|
|
|
},
|
2022-05-31 05:08:11 -07:00
|
|
|
{},
|
|
|
|
};
|
|
|
|
EXPORT_SYMBOL(snd_soc_acpi_amd_rmb_sof_machines);
|
|
|
|
|
2023-10-19 23:28:11 -07:00
|
|
|
struct snd_soc_acpi_mach snd_soc_acpi_amd_acp63_sof_machines[] = {
|
|
|
|
{
|
|
|
|
.id = "AMDI1019",
|
|
|
|
.drv_name = "acp63-dsp",
|
|
|
|
.pdata = &acp_quirk_data,
|
|
|
|
.fw_filename = "sof-acp_6_3.ri",
|
|
|
|
.sof_tplg_filename = "sof-acp_6_3.tplg",
|
|
|
|
},
|
|
|
|
{},
|
|
|
|
};
|
|
|
|
EXPORT_SYMBOL(snd_soc_acpi_amd_acp63_sof_machines);
|
|
|
|
|
2024-08-22 22:37:38 -07:00
|
|
|
struct snd_soc_acpi_mach snd_soc_acpi_amd_acp70_sof_machines[] = {
|
|
|
|
{
|
|
|
|
.id = "AMDI1010",
|
|
|
|
.drv_name = "acp70-dsp",
|
|
|
|
.pdata = &acp_quirk_data,
|
|
|
|
.fw_filename = "sof-acp_7_0.ri",
|
|
|
|
.sof_tplg_filename = "sof-acp_7_0.tplg",
|
|
|
|
},
|
|
|
|
{},
|
|
|
|
};
|
|
|
|
EXPORT_SYMBOL(snd_soc_acpi_amd_acp70_sof_machines);
|
|
|
|
|
2023-12-09 13:32:22 -07:00
|
|
|
MODULE_DESCRIPTION("AMD ACP Machine Configuration Module");
|
2021-11-17 02:37:20 -07:00
|
|
|
MODULE_LICENSE("Dual BSD/GPL");
|