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) 257feb2f78SPierre-Louis Bossart bool snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN], 267feb2f78SPierre-Louis Bossart struct snd_soc_acpi_package_context *ctx); 277feb2f78SPierre-Louis Bossart #else 287feb2f78SPierre-Louis Bossart static inline bool 297feb2f78SPierre-Louis Bossart snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN], 307feb2f78SPierre-Louis Bossart struct snd_soc_acpi_package_context *ctx) 317feb2f78SPierre-Louis Bossart { 327feb2f78SPierre-Louis Bossart return false; 337feb2f78SPierre-Louis Bossart } 347feb2f78SPierre-Louis Bossart #endif 357feb2f78SPierre-Louis Bossart 367feb2f78SPierre-Louis Bossart /* acpi match */ 377feb2f78SPierre-Louis Bossart struct snd_soc_acpi_mach * 387feb2f78SPierre-Louis Bossart snd_soc_acpi_find_machine(struct snd_soc_acpi_mach *machines); 397feb2f78SPierre-Louis Bossart 407feb2f78SPierre-Louis Bossart /** 41*8679284bSPierre-Louis Bossart * snd_soc_acpi_mach_params: interface for machine driver configuration 42*8679284bSPierre-Louis Bossart * 43*8679284bSPierre-Louis Bossart * @acpi_ipc_irq_index: used for BYT-CR detection 44*8679284bSPierre-Louis Bossart * @platform: string used for HDaudio codec support 45*8679284bSPierre-Louis Bossart * @codec_mask: used for HDAudio support 46*8679284bSPierre-Louis Bossart */ 47*8679284bSPierre-Louis Bossart struct snd_soc_acpi_mach_params { 48*8679284bSPierre-Louis Bossart u32 acpi_ipc_irq_index; 49*8679284bSPierre-Louis Bossart const char *platform; 50*8679284bSPierre-Louis Bossart u32 codec_mask; 51*8679284bSPierre-Louis Bossart }; 52*8679284bSPierre-Louis Bossart 53*8679284bSPierre-Louis Bossart /** 547feb2f78SPierre-Louis Bossart * snd_soc_acpi_mach: ACPI-based machine descriptor. Most of the fields are 557feb2f78SPierre-Louis Bossart * related to the hardware, except for the firmware and topology file names. 56976b5a0eSPierre-Louis Bossart * A platform supported by legacy and Sound Open Firmware (SOF) would expose 57976b5a0eSPierre-Louis Bossart * all firmware/topology related fields. 587feb2f78SPierre-Louis Bossart * 597feb2f78SPierre-Louis Bossart * @id: ACPI ID (usually the codec's) used to find a matching machine driver. 607feb2f78SPierre-Louis Bossart * @drv_name: machine driver name 61976b5a0eSPierre-Louis Bossart * @fw_filename: firmware file name. Used when SOF is not enabled. 627feb2f78SPierre-Louis Bossart * @board: board name 637feb2f78SPierre-Louis Bossart * @machine_quirk: pointer to quirk, usually based on DMI information when 647feb2f78SPierre-Louis Bossart * ACPI ID alone is not sufficient, wrong or misleading 657feb2f78SPierre-Louis Bossart * @quirk_data: data used to uniquely identify a machine, usually a list of 667feb2f78SPierre-Louis Bossart * audio codecs whose presence if checked with ACPI 677feb2f78SPierre-Louis Bossart * @pdata: intended for platform data or machine specific-ops. This structure 687feb2f78SPierre-Louis Bossart * is not constant since this field may be updated at run-time 69976b5a0eSPierre-Louis Bossart * @sof_fw_filename: Sound Open Firmware file name, if enabled 70976b5a0eSPierre-Louis Bossart * @sof_tplg_filename: Sound Open Firmware topology file name, if enabled 71976b5a0eSPierre-Louis Bossart * @asoc_plat_name: ASoC platform name, used for binding machine drivers 72976b5a0eSPierre-Louis Bossart * if non NULL 73976b5a0eSPierre-Louis Bossart * @new_mach_data: machine driver private data fixup 747feb2f78SPierre-Louis Bossart */ 757feb2f78SPierre-Louis Bossart /* Descriptor for SST ASoC machine driver */ 767feb2f78SPierre-Louis Bossart struct snd_soc_acpi_mach { 777feb2f78SPierre-Louis Bossart const u8 id[ACPI_ID_LEN]; 787feb2f78SPierre-Louis Bossart const char *drv_name; 797feb2f78SPierre-Louis Bossart const char *fw_filename; 807feb2f78SPierre-Louis Bossart const char *board; 817feb2f78SPierre-Louis Bossart struct snd_soc_acpi_mach * (*machine_quirk)(void *arg); 827feb2f78SPierre-Louis Bossart const void *quirk_data; 837feb2f78SPierre-Louis Bossart void *pdata; 84*8679284bSPierre-Louis Bossart struct snd_soc_acpi_mach_params mach_params; 85976b5a0eSPierre-Louis Bossart const char *sof_fw_filename; 86976b5a0eSPierre-Louis Bossart const char *sof_tplg_filename; 87976b5a0eSPierre-Louis Bossart const char *asoc_plat_name; 88976b5a0eSPierre-Louis Bossart struct platform_device * (*new_mach_data)(void *pdata); 897feb2f78SPierre-Louis Bossart }; 907feb2f78SPierre-Louis Bossart 917feb2f78SPierre-Louis Bossart #define SND_SOC_ACPI_MAX_CODECS 3 927feb2f78SPierre-Louis Bossart 937feb2f78SPierre-Louis Bossart /** 947feb2f78SPierre-Louis Bossart * struct snd_soc_acpi_codecs: Structure to hold secondary codec information 957feb2f78SPierre-Louis Bossart * apart from the matched one, this data will be passed to the quirk function 967feb2f78SPierre-Louis Bossart * to match with the ACPI detected devices 977feb2f78SPierre-Louis Bossart * 987feb2f78SPierre-Louis Bossart * @num_codecs: number of secondary codecs used in the platform 997feb2f78SPierre-Louis Bossart * @codecs: holds the codec IDs 1007feb2f78SPierre-Louis Bossart * 1017feb2f78SPierre-Louis Bossart */ 1027feb2f78SPierre-Louis Bossart struct snd_soc_acpi_codecs { 1037feb2f78SPierre-Louis Bossart int num_codecs; 1047feb2f78SPierre-Louis Bossart u8 codecs[SND_SOC_ACPI_MAX_CODECS][ACPI_ID_LEN]; 1057feb2f78SPierre-Louis Bossart }; 1067feb2f78SPierre-Louis Bossart 1077feb2f78SPierre-Louis Bossart /* check all codecs */ 1087feb2f78SPierre-Louis Bossart struct snd_soc_acpi_mach *snd_soc_acpi_codec_list(void *arg); 1097feb2f78SPierre-Louis Bossart 1107feb2f78SPierre-Louis Bossart #endif 111