1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * soc-acpi-intel-cml-match.c - tables and support for CML ACPI enumeration. 4 * 5 * Copyright (c) 2019, Intel Corporation. 6 * 7 */ 8 9 #include <sound/soc-acpi.h> 10 #include <sound/soc-acpi-intel-match.h> 11 12 static const struct snd_soc_acpi_codecs essx_83x6 = { 13 .num_codecs = 3, 14 .codecs = { "ESSX8316", "ESSX8326", "ESSX8336"}, 15 }; 16 17 static const struct snd_soc_acpi_codecs rt1011_spk_codecs = { 18 .num_codecs = 1, 19 .codecs = {"10EC1011"} 20 }; 21 22 static const struct snd_soc_acpi_codecs rt1015_spk_codecs = { 23 .num_codecs = 1, 24 .codecs = {"10EC1015"} 25 }; 26 27 static const struct snd_soc_acpi_codecs max98357a_spk_codecs = { 28 .num_codecs = 1, 29 .codecs = {"MX98357A"} 30 }; 31 32 static const struct snd_soc_acpi_codecs max98390_spk_codecs = { 33 .num_codecs = 1, 34 .codecs = {"MX98390"} 35 }; 36 37 /* 38 * The order of the three entries with .id = "10EC5682" matters 39 * here, because DSDT tables expose an ACPI HID for the MAX98357A 40 * speaker amplifier which is not populated on the board. 41 */ 42 struct snd_soc_acpi_mach snd_soc_acpi_intel_cml_machines[] = { 43 { 44 .id = "10EC5682", 45 .drv_name = "cml_rt1011_rt5682", 46 .machine_quirk = snd_soc_acpi_codec_list, 47 .quirk_data = &rt1011_spk_codecs, 48 .sof_tplg_filename = "sof-cml-rt1011-rt5682.tplg", 49 }, 50 { 51 .id = "10EC5682", 52 .drv_name = "cml_rt1015_rt5682", 53 .machine_quirk = snd_soc_acpi_codec_list, 54 .quirk_data = &rt1015_spk_codecs, 55 .sof_tplg_filename = "sof-cml-rt1011-rt5682.tplg", 56 }, 57 { 58 .id = "10EC5682", 59 .drv_name = "sof_rt5682", 60 .machine_quirk = snd_soc_acpi_codec_list, 61 .quirk_data = &max98357a_spk_codecs, 62 .sof_tplg_filename = "sof-cml-rt5682-max98357a.tplg", 63 }, 64 { 65 .id = "10EC5682", 66 .drv_name = "sof_rt5682", 67 .sof_tplg_filename = "sof-cml-rt5682.tplg", 68 }, 69 { 70 .id = "DLGS7219", 71 .drv_name = "cml_da7219_mx98357a", 72 .machine_quirk = snd_soc_acpi_codec_list, 73 .quirk_data = &max98357a_spk_codecs, 74 .sof_tplg_filename = "sof-cml-da7219-max98357a.tplg", 75 }, 76 { 77 .id = "DLGS7219", 78 .drv_name = "cml_da7219_mx98357a", 79 .machine_quirk = snd_soc_acpi_codec_list, 80 .quirk_data = &max98390_spk_codecs, 81 .sof_tplg_filename = "sof-cml-da7219-max98390.tplg", 82 }, 83 { 84 .comp_ids = &essx_83x6, 85 .drv_name = "sof-essx8336", 86 .sof_tplg_filename = "sof-cml-es8336", /* the tplg suffix is added at run time */ 87 .tplg_quirk_mask = SND_SOC_ACPI_TPLG_INTEL_SSP_NUMBER | 88 SND_SOC_ACPI_TPLG_INTEL_SSP_MSB | 89 SND_SOC_ACPI_TPLG_INTEL_DMIC_NUMBER, 90 }, 91 {}, 92 }; 93 EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_cml_machines); 94 95 static const struct snd_soc_acpi_endpoint single_endpoint = { 96 .num = 0, 97 .aggregated = 0, 98 .group_position = 0, 99 .group_id = 0, 100 }; 101 102 static const struct snd_soc_acpi_endpoint spk_l_endpoint = { 103 .num = 0, 104 .aggregated = 1, 105 .group_position = 0, 106 .group_id = 1, 107 }; 108 109 static const struct snd_soc_acpi_endpoint spk_r_endpoint = { 110 .num = 0, 111 .aggregated = 1, 112 .group_position = 1, 113 .group_id = 1, 114 }; 115 116 static const struct snd_soc_acpi_adr_device rt700_1_adr[] = { 117 { 118 .adr = 0x000110025D070000ull, 119 .num_endpoints = 1, 120 .endpoints = &single_endpoint, 121 .name_prefix = "rt700" 122 } 123 }; 124 125 static const struct snd_soc_acpi_link_adr cml_rvp[] = { 126 { 127 .mask = BIT(1), 128 .num_adr = ARRAY_SIZE(rt700_1_adr), 129 .adr_d = rt700_1_adr, 130 }, 131 {} 132 }; 133 134 static const struct snd_soc_acpi_adr_device rt711_0_adr[] = { 135 { 136 .adr = 0x000020025D071100ull, 137 .num_endpoints = 1, 138 .endpoints = &single_endpoint, 139 .name_prefix = "rt711" 140 } 141 }; 142 143 static const struct snd_soc_acpi_adr_device rt1308_1_single_adr[] = { 144 { 145 .adr = 0x000120025D130800ull, 146 .num_endpoints = 1, 147 .endpoints = &single_endpoint, 148 .name_prefix = "rt1308-1" 149 } 150 }; 151 152 static const struct snd_soc_acpi_adr_device rt1308_1_group1_adr[] = { 153 { 154 .adr = 0x000120025D130800ull, 155 .num_endpoints = 1, 156 .endpoints = &spk_l_endpoint, 157 .name_prefix = "rt1308-1" 158 } 159 }; 160 161 static const struct snd_soc_acpi_adr_device rt1308_2_group1_adr[] = { 162 { 163 .adr = 0x000220025D130800ull, 164 .num_endpoints = 1, 165 .endpoints = &spk_r_endpoint, 166 .name_prefix = "rt1308-2" 167 } 168 }; 169 170 static const struct snd_soc_acpi_adr_device rt715_3_adr[] = { 171 { 172 .adr = 0x000320025D071500ull, 173 .num_endpoints = 1, 174 .endpoints = &single_endpoint, 175 .name_prefix = "rt715" 176 } 177 }; 178 179 static const struct snd_soc_acpi_adr_device rt711_sdca_0_adr[] = { 180 { 181 .adr = 0x000030025D071101ull, 182 .num_endpoints = 1, 183 .endpoints = &single_endpoint, 184 .name_prefix = "rt711" 185 } 186 }; 187 188 static const struct snd_soc_acpi_adr_device rt1316_1_group1_adr[] = { 189 { 190 .adr = 0x000131025D131601ull, /* unique ID is set for some reason */ 191 .num_endpoints = 1, 192 .endpoints = &spk_l_endpoint, 193 .name_prefix = "rt1316-1" 194 } 195 }; 196 197 static const struct snd_soc_acpi_adr_device rt1316_2_group1_adr[] = { 198 { 199 .adr = 0x000230025D131601ull, 200 .num_endpoints = 1, 201 .endpoints = &spk_r_endpoint, 202 .name_prefix = "rt1316-2" 203 } 204 }; 205 206 static const struct snd_soc_acpi_adr_device rt714_3_adr[] = { 207 { 208 .adr = 0x000330025D071401ull, 209 .num_endpoints = 1, 210 .endpoints = &single_endpoint, 211 .name_prefix = "rt714" 212 } 213 }; 214 215 static const struct snd_soc_acpi_link_adr cml_3_in_1_default[] = { 216 { 217 .mask = BIT(0), 218 .num_adr = ARRAY_SIZE(rt711_0_adr), 219 .adr_d = rt711_0_adr, 220 }, 221 { 222 .mask = BIT(1), 223 .num_adr = ARRAY_SIZE(rt1308_1_group1_adr), 224 .adr_d = rt1308_1_group1_adr, 225 }, 226 { 227 .mask = BIT(2), 228 .num_adr = ARRAY_SIZE(rt1308_2_group1_adr), 229 .adr_d = rt1308_2_group1_adr, 230 }, 231 { 232 .mask = BIT(3), 233 .num_adr = ARRAY_SIZE(rt715_3_adr), 234 .adr_d = rt715_3_adr, 235 }, 236 {} 237 }; 238 239 static const struct snd_soc_acpi_link_adr cml_3_in_1_mono_amp[] = { 240 { 241 .mask = BIT(0), 242 .num_adr = ARRAY_SIZE(rt711_0_adr), 243 .adr_d = rt711_0_adr, 244 }, 245 { 246 .mask = BIT(1), 247 .num_adr = ARRAY_SIZE(rt1308_1_single_adr), 248 .adr_d = rt1308_1_single_adr, 249 }, 250 { 251 .mask = BIT(3), 252 .num_adr = ARRAY_SIZE(rt715_3_adr), 253 .adr_d = rt715_3_adr, 254 }, 255 {} 256 }; 257 258 static const struct snd_soc_acpi_link_adr cml_3_in_1_sdca[] = { 259 { 260 .mask = BIT(0), 261 .num_adr = ARRAY_SIZE(rt711_sdca_0_adr), 262 .adr_d = rt711_sdca_0_adr, 263 }, 264 { 265 .mask = BIT(1), 266 .num_adr = ARRAY_SIZE(rt1316_1_group1_adr), 267 .adr_d = rt1316_1_group1_adr, 268 }, 269 { 270 .mask = BIT(2), 271 .num_adr = ARRAY_SIZE(rt1316_2_group1_adr), 272 .adr_d = rt1316_2_group1_adr, 273 }, 274 { 275 .mask = BIT(3), 276 .num_adr = ARRAY_SIZE(rt714_3_adr), 277 .adr_d = rt714_3_adr, 278 }, 279 {} 280 }; 281 282 struct snd_soc_acpi_mach snd_soc_acpi_intel_cml_sdw_machines[] = { 283 { 284 .link_mask = 0xF, /* 4 active links required */ 285 .links = cml_3_in_1_default, 286 .drv_name = "sof_sdw", 287 .sof_tplg_filename = "sof-cml-rt711-rt1308-rt715.tplg", 288 }, 289 { 290 .link_mask = 0xF, /* 4 active links required */ 291 .links = cml_3_in_1_sdca, 292 .drv_name = "sof_sdw", 293 .sof_tplg_filename = "sof-cml-rt711-rt1316-rt714.tplg", 294 }, 295 { 296 /* 297 * link_mask should be 0xB, but all links are enabled by BIOS. 298 * This entry will be selected if there is no rt1308 exposed 299 * on link2 since it will fail to match the above entry. 300 */ 301 .link_mask = 0xF, 302 .links = cml_3_in_1_mono_amp, 303 .drv_name = "sof_sdw", 304 .sof_tplg_filename = "sof-cml-rt711-rt1308-mono-rt715.tplg", 305 }, 306 { 307 .link_mask = 0x2, /* RT700 connected on Link1 */ 308 .links = cml_rvp, 309 .drv_name = "sof_sdw", 310 .sof_tplg_filename = "sof-cml-rt700.tplg", 311 }, 312 {} 313 }; 314 EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_cml_sdw_machines); 315