// SPDX-License-Identifier: GPL-2.0-only /* * soc-acpi-intel-nvl-match.c - tables and support for NVL ACPI enumeration. * * Copyright (c) 2025, Intel Corporation. * */ #include #include #include "soc-acpi-intel-sdw-mockup-match.h" struct snd_soc_acpi_mach snd_soc_acpi_intel_nvl_machines[] = { {}, }; EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_nvl_machines); /* * Multi-function codecs with three endpoints created for * headset, amp and dmic functions. */ static const struct snd_soc_acpi_endpoint rt_mf_endpoints[] = { { .num = 0, .aggregated = 0, .group_position = 0, .group_id = 0, }, { .num = 1, .aggregated = 0, .group_position = 0, .group_id = 0, }, { .num = 2, .aggregated = 0, .group_position = 0, .group_id = 0, }, }; static const struct snd_soc_acpi_adr_device rt722_3_single_adr[] = { { .adr = 0x000330025d072201ull, .num_endpoints = ARRAY_SIZE(rt_mf_endpoints), .endpoints = rt_mf_endpoints, .name_prefix = "rt722" } }; static const struct snd_soc_acpi_link_adr nvl_rt722_l3[] = { { .mask = BIT(3), .num_adr = ARRAY_SIZE(rt722_3_single_adr), .adr_d = rt722_3_single_adr, }, {} }; /* this table is used when there is no I2S codec present */ struct snd_soc_acpi_mach snd_soc_acpi_intel_nvl_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-nvl-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-nvl-rt711-rt1308-mono-rt715.tplg", }, { .link_mask = GENMASK(2, 0), .links = sdw_mockup_mic_headset_1amp, .drv_name = "sof_sdw", .sof_tplg_filename = "sof-nvl-rt715-rt711-rt1308-mono.tplg", }, { .link_mask = BIT(3), .links = nvl_rt722_l3, .drv_name = "sof_sdw", .sof_tplg_filename = "sof-nvl-rt722.tplg", }, {}, }; EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_nvl_sdw_machines);