17730bb13SKuninori Morimoto /* SPDX-License-Identifier: GPL-2.0 27730bb13SKuninori Morimoto * 37feb2f78SPierre-Louis Bossart * Copyright (C) 2013-15, Intel Corporation. All rights reserved. 47feb2f78SPierre-Louis Bossart */ 57feb2f78SPierre-Louis Bossart 67feb2f78SPierre-Louis Bossart #ifndef __LINUX_SND_SOC_ACPI_H 77feb2f78SPierre-Louis Bossart #define __LINUX_SND_SOC_ACPI_H 87feb2f78SPierre-Louis Bossart 97feb2f78SPierre-Louis Bossart #include <linux/stddef.h> 107feb2f78SPierre-Louis Bossart #include <linux/acpi.h> 11845ab400SPierre-Louis Bossart #include <linux/mod_devicetable.h> 127feb2f78SPierre-Louis Bossart 137feb2f78SPierre-Louis Bossart struct snd_soc_acpi_package_context { 147feb2f78SPierre-Louis Bossart char *name; /* package name */ 157feb2f78SPierre-Louis Bossart int length; /* number of elements */ 167feb2f78SPierre-Louis Bossart struct acpi_buffer *format; 177feb2f78SPierre-Louis Bossart struct acpi_buffer *state; 187feb2f78SPierre-Louis Bossart bool data_valid; 197feb2f78SPierre-Louis Bossart }; 207feb2f78SPierre-Louis Bossart 212be2d579SPierre-Louis Bossart /* codec name is used in DAIs is i2c-<HID>:00 with HID being 8 chars */ 222be2d579SPierre-Louis Bossart #define SND_ACPI_I2C_ID_LEN (4 + ACPI_ID_LEN + 3 + 1) 232be2d579SPierre-Louis Bossart 247feb2f78SPierre-Louis Bossart #if IS_ENABLED(CONFIG_ACPI) 25*5e484ec1SPierre-Louis Bossart /* acpi match */ 26*5e484ec1SPierre-Louis Bossart struct snd_soc_acpi_mach * 27*5e484ec1SPierre-Louis Bossart snd_soc_acpi_find_machine(struct snd_soc_acpi_mach *machines); 28*5e484ec1SPierre-Louis Bossart 297feb2f78SPierre-Louis Bossart bool snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN], 307feb2f78SPierre-Louis Bossart struct snd_soc_acpi_package_context *ctx); 31*5e484ec1SPierre-Louis Bossart 32*5e484ec1SPierre-Louis Bossart /* check all codecs */ 33*5e484ec1SPierre-Louis Bossart struct snd_soc_acpi_mach *snd_soc_acpi_codec_list(void *arg); 34*5e484ec1SPierre-Louis Bossart 357feb2f78SPierre-Louis Bossart #else 36*5e484ec1SPierre-Louis Bossart /* acpi match */ 37*5e484ec1SPierre-Louis Bossart static inline struct snd_soc_acpi_mach * 38*5e484ec1SPierre-Louis Bossart snd_soc_acpi_find_machine(struct snd_soc_acpi_mach *machines) 39*5e484ec1SPierre-Louis Bossart { 40*5e484ec1SPierre-Louis Bossart return NULL; 41*5e484ec1SPierre-Louis Bossart } 42*5e484ec1SPierre-Louis Bossart 437feb2f78SPierre-Louis Bossart static inline bool 447feb2f78SPierre-Louis Bossart snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN], 457feb2f78SPierre-Louis Bossart struct snd_soc_acpi_package_context *ctx) 467feb2f78SPierre-Louis Bossart { 477feb2f78SPierre-Louis Bossart return false; 487feb2f78SPierre-Louis Bossart } 497feb2f78SPierre-Louis Bossart 50*5e484ec1SPierre-Louis Bossart /* check all codecs */ 51*5e484ec1SPierre-Louis Bossart static inline struct snd_soc_acpi_mach *snd_soc_acpi_codec_list(void *arg) 52*5e484ec1SPierre-Louis Bossart { 53*5e484ec1SPierre-Louis Bossart return NULL; 54*5e484ec1SPierre-Louis Bossart } 55*5e484ec1SPierre-Louis Bossart #endif 567feb2f78SPierre-Louis Bossart 577feb2f78SPierre-Louis Bossart /** 588679284bSPierre-Louis Bossart * snd_soc_acpi_mach_params: interface for machine driver configuration 598679284bSPierre-Louis Bossart * 608679284bSPierre-Louis Bossart * @acpi_ipc_irq_index: used for BYT-CR detection 618679284bSPierre-Louis Bossart * @platform: string used for HDaudio codec support 628679284bSPierre-Louis Bossart * @codec_mask: used for HDAudio support 638679284bSPierre-Louis Bossart */ 648679284bSPierre-Louis Bossart struct snd_soc_acpi_mach_params { 658679284bSPierre-Louis Bossart u32 acpi_ipc_irq_index; 668679284bSPierre-Louis Bossart const char *platform; 678679284bSPierre-Louis Bossart u32 codec_mask; 68b92826faSPierre-Louis Bossart u32 dmic_num; 698679284bSPierre-Louis Bossart }; 708679284bSPierre-Louis Bossart 718679284bSPierre-Louis Bossart /** 727feb2f78SPierre-Louis Bossart * snd_soc_acpi_mach: ACPI-based machine descriptor. Most of the fields are 737feb2f78SPierre-Louis Bossart * related to the hardware, except for the firmware and topology file names. 74976b5a0eSPierre-Louis Bossart * A platform supported by legacy and Sound Open Firmware (SOF) would expose 75976b5a0eSPierre-Louis Bossart * all firmware/topology related fields. 767feb2f78SPierre-Louis Bossart * 777feb2f78SPierre-Louis Bossart * @id: ACPI ID (usually the codec's) used to find a matching machine driver. 787feb2f78SPierre-Louis Bossart * @drv_name: machine driver name 79976b5a0eSPierre-Louis Bossart * @fw_filename: firmware file name. Used when SOF is not enabled. 807feb2f78SPierre-Louis Bossart * @board: board name 817feb2f78SPierre-Louis Bossart * @machine_quirk: pointer to quirk, usually based on DMI information when 827feb2f78SPierre-Louis Bossart * ACPI ID alone is not sufficient, wrong or misleading 837feb2f78SPierre-Louis Bossart * @quirk_data: data used to uniquely identify a machine, usually a list of 847feb2f78SPierre-Louis Bossart * audio codecs whose presence if checked with ACPI 857feb2f78SPierre-Louis Bossart * @pdata: intended for platform data or machine specific-ops. This structure 867feb2f78SPierre-Louis Bossart * is not constant since this field may be updated at run-time 87976b5a0eSPierre-Louis Bossart * @sof_fw_filename: Sound Open Firmware file name, if enabled 88976b5a0eSPierre-Louis Bossart * @sof_tplg_filename: Sound Open Firmware topology file name, if enabled 89976b5a0eSPierre-Louis Bossart * @asoc_plat_name: ASoC platform name, used for binding machine drivers 90976b5a0eSPierre-Louis Bossart * if non NULL 91976b5a0eSPierre-Louis Bossart * @new_mach_data: machine driver private data fixup 927feb2f78SPierre-Louis Bossart */ 937feb2f78SPierre-Louis Bossart /* Descriptor for SST ASoC machine driver */ 947feb2f78SPierre-Louis Bossart struct snd_soc_acpi_mach { 957feb2f78SPierre-Louis Bossart const u8 id[ACPI_ID_LEN]; 967feb2f78SPierre-Louis Bossart const char *drv_name; 977feb2f78SPierre-Louis Bossart const char *fw_filename; 987feb2f78SPierre-Louis Bossart const char *board; 997feb2f78SPierre-Louis Bossart struct snd_soc_acpi_mach * (*machine_quirk)(void *arg); 1007feb2f78SPierre-Louis Bossart const void *quirk_data; 1017feb2f78SPierre-Louis Bossart void *pdata; 1028679284bSPierre-Louis Bossart struct snd_soc_acpi_mach_params mach_params; 103976b5a0eSPierre-Louis Bossart const char *sof_fw_filename; 104976b5a0eSPierre-Louis Bossart const char *sof_tplg_filename; 105976b5a0eSPierre-Louis Bossart const char *asoc_plat_name; 106976b5a0eSPierre-Louis Bossart struct platform_device * (*new_mach_data)(void *pdata); 1077feb2f78SPierre-Louis Bossart }; 1087feb2f78SPierre-Louis Bossart 1097feb2f78SPierre-Louis Bossart #define SND_SOC_ACPI_MAX_CODECS 3 1107feb2f78SPierre-Louis Bossart 1117feb2f78SPierre-Louis Bossart /** 1127feb2f78SPierre-Louis Bossart * struct snd_soc_acpi_codecs: Structure to hold secondary codec information 1137feb2f78SPierre-Louis Bossart * apart from the matched one, this data will be passed to the quirk function 1147feb2f78SPierre-Louis Bossart * to match with the ACPI detected devices 1157feb2f78SPierre-Louis Bossart * 1167feb2f78SPierre-Louis Bossart * @num_codecs: number of secondary codecs used in the platform 1177feb2f78SPierre-Louis Bossart * @codecs: holds the codec IDs 1187feb2f78SPierre-Louis Bossart * 1197feb2f78SPierre-Louis Bossart */ 1207feb2f78SPierre-Louis Bossart struct snd_soc_acpi_codecs { 1217feb2f78SPierre-Louis Bossart int num_codecs; 1227feb2f78SPierre-Louis Bossart u8 codecs[SND_SOC_ACPI_MAX_CODECS][ACPI_ID_LEN]; 1237feb2f78SPierre-Louis Bossart }; 1247feb2f78SPierre-Louis Bossart 1257feb2f78SPierre-Louis Bossart #endif 126