144 lines
3.1 KiB
C
144 lines
3.1 KiB
C
|
// SPDX-License-Identifier: GPL-2.0-only
|
||
|
/*
|
||
|
* soc-acpi-intel-lnl-match.c - tables and support for LNL ACPI enumeration.
|
||
|
*
|
||
|
* Copyright (c) 2023, Intel Corporation. All rights reserved.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include <sound/soc-acpi.h>
|
||
|
#include <sound/soc-acpi-intel-match.h>
|
||
|
#include "soc-acpi-intel-sdw-mockup-match.h"
|
||
|
|
||
|
struct snd_soc_acpi_mach snd_soc_acpi_intel_lnl_machines[] = {
|
||
|
{},
|
||
|
};
|
||
|
EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_lnl_machines);
|
||
|
|
||
|
static const struct snd_soc_acpi_endpoint single_endpoint = {
|
||
|
.num = 0,
|
||
|
.aggregated = 0,
|
||
|
.group_position = 0,
|
||
|
.group_id = 0,
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_endpoint spk_l_endpoint = {
|
||
|
.num = 0,
|
||
|
.aggregated = 1,
|
||
|
.group_position = 0,
|
||
|
.group_id = 1,
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_endpoint spk_r_endpoint = {
|
||
|
.num = 0,
|
||
|
.aggregated = 1,
|
||
|
.group_position = 1,
|
||
|
.group_id = 1,
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_adr_device rt711_sdca_0_adr[] = {
|
||
|
{
|
||
|
.adr = 0x000030025D071101ull,
|
||
|
.num_endpoints = 1,
|
||
|
.endpoints = &single_endpoint,
|
||
|
.name_prefix = "rt711"
|
||
|
}
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_adr_device rt1316_2_group1_adr[] = {
|
||
|
{
|
||
|
.adr = 0x000230025D131601ull,
|
||
|
.num_endpoints = 1,
|
||
|
.endpoints = &spk_l_endpoint,
|
||
|
.name_prefix = "rt1316-1"
|
||
|
}
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_adr_device rt1316_3_group1_adr[] = {
|
||
|
{
|
||
|
.adr = 0x000331025D131601ull,
|
||
|
.num_endpoints = 1,
|
||
|
.endpoints = &spk_r_endpoint,
|
||
|
.name_prefix = "rt1316-2"
|
||
|
}
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_adr_device rt714_1_adr[] = {
|
||
|
{
|
||
|
.adr = 0x000130025D071401ull,
|
||
|
.num_endpoints = 1,
|
||
|
.endpoints = &single_endpoint,
|
||
|
.name_prefix = "rt714"
|
||
|
}
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_link_adr lnl_rvp[] = {
|
||
|
{
|
||
|
.mask = BIT(0),
|
||
|
.num_adr = ARRAY_SIZE(rt711_sdca_0_adr),
|
||
|
.adr_d = rt711_sdca_0_adr,
|
||
|
},
|
||
|
{}
|
||
|
};
|
||
|
|
||
|
static const struct snd_soc_acpi_link_adr lnl_3_in_1_sdca[] = {
|
||
|
{
|
||
|
.mask = BIT(0),
|
||
|
.num_adr = ARRAY_SIZE(rt711_sdca_0_adr),
|
||
|
.adr_d = rt711_sdca_0_adr,
|
||
|
},
|
||
|
{
|
||
|
.mask = BIT(2),
|
||
|
.num_adr = ARRAY_SIZE(rt1316_2_group1_adr),
|
||
|
.adr_d = rt1316_2_group1_adr,
|
||
|
},
|
||
|
{
|
||
|
.mask = BIT(3),
|
||
|
.num_adr = ARRAY_SIZE(rt1316_3_group1_adr),
|
||
|
.adr_d = rt1316_3_group1_adr,
|
||
|
},
|
||
|
{
|
||
|
.mask = BIT(1),
|
||
|
.num_adr = ARRAY_SIZE(rt714_1_adr),
|
||
|
.adr_d = rt714_1_adr,
|
||
|
},
|
||
|
{}
|
||
|
};
|
||
|
|
||
|
/* this table is used when there is no I2S codec present */
|
||
|
struct snd_soc_acpi_mach snd_soc_acpi_intel_lnl_sdw_machines[] = {
|
||
|
/* mockup tests need to be first */
|
||
|
{
|
||
|
.link_mask = GENMASK(3, 0),
|
||
|
.links = sdw_mockup_headset_2amps_mic,
|
||
|
.drv_name = "sof_sdw",
|
||
|
.sof_tplg_filename = "sof-lnl-rt711-rt1308-rt715.tplg",
|
||
|
},
|
||
|
{
|
||
|
.link_mask = BIT(0) | BIT(1) | BIT(3),
|
||
|
.links = sdw_mockup_headset_1amp_mic,
|
||
|
.drv_name = "sof_sdw",
|
||
|
.sof_tplg_filename = "sof-lnl-rt711-rt1308-mono-rt715.tplg",
|
||
|
},
|
||
|
{
|
||
|
.link_mask = GENMASK(2, 0),
|
||
|
.links = sdw_mockup_mic_headset_1amp,
|
||
|
.drv_name = "sof_sdw",
|
||
|
.sof_tplg_filename = "sof-lnl-rt715-rt711-rt1308-mono.tplg",
|
||
|
},
|
||
|
{
|
||
|
.link_mask = GENMASK(3, 0),
|
||
|
.links = lnl_3_in_1_sdca,
|
||
|
.drv_name = "sof_sdw",
|
||
|
.sof_tplg_filename = "sof-lnl-rt711-l0-rt1316-l23-rt714-l1.tplg",
|
||
|
},
|
||
|
{
|
||
|
.link_mask = BIT(0),
|
||
|
.links = lnl_rvp,
|
||
|
.drv_name = "sof_sdw",
|
||
|
.sof_tplg_filename = "sof-lnl-rt711.tplg",
|
||
|
},
|
||
|
{},
|
||
|
};
|
||
|
EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_lnl_sdw_machines);
|