2020-05-01 09:58:50 -05:00
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
2019-04-12 11:05:06 -05:00
/*
* This file is provided under a dual BSD / GPLv2 license . When using or
* redistributing this file , you may do so under either license .
*
* Copyright ( c ) 2018 Intel Corporation . All rights reserved .
*
* Author : Liam Girdwood < liam . r . girdwood @ linux . intel . com >
*/
# ifndef __INCLUDE_SOUND_SOF_H
# define __INCLUDE_SOUND_SOF_H
# include <linux/pci.h>
2019-04-12 11:05:17 -05:00
# include <sound/soc.h>
2019-04-12 11:05:06 -05:00
# include <sound/soc-acpi.h>
struct snd_sof_dsp_ops ;
/*
* SOF Platform data .
*/
struct snd_sof_pdata {
const struct firmware * fw ;
const char * name ;
const char * platform ;
struct device * dev ;
2020-04-15 15:27:55 -05:00
/* indicate how many first bytes shouldn't be loaded into DSP memory. */
size_t fw_offset ;
2019-04-12 11:05:06 -05:00
/*
* notification callback used if the hardware initialization
* can take time or is handled in a workqueue . This callback
* can be used by the caller to e . g . enable runtime_pm
* or limit functionality until all low - level inits are
* complete .
*/
void ( * sof_probe_complete ) ( struct device * dev ) ;
/* descriptor */
const struct sof_dev_desc * desc ;
/* firmware and topology filenames */
const char * fw_filename_prefix ;
const char * fw_filename ;
const char * tplg_filename_prefix ;
const char * tplg_filename ;
/* machine */
struct platform_device * pdev_mach ;
const struct snd_soc_acpi_mach * machine ;
void * hw_pdata ;
} ;
/*
* Descriptor used for setting up SOF platform data . This is used when
* ACPI / PCI data is missing or mapped differently .
*/
struct sof_dev_desc {
/* list of machines using this configuration */
struct snd_soc_acpi_mach * machines ;
2019-09-16 16:42:41 -05:00
/* alternate list of machines using this configuration */
struct snd_soc_acpi_mach * alt_machines ;
2020-09-21 13:50:38 +03:00
bool use_acpi_target_states ;
2019-04-12 11:05:06 -05:00
/* Platform resource indexes in BAR / ACPI resources. */
/* Must set to -1 if not used - add new items to end */
int resindex_lpe_base ;
int resindex_pcicfg_base ;
int resindex_imr_base ;
int irqindex_host_ipc ;
int resindex_dma_base ;
/* DMA only valid when resindex_dma_base != -1*/
int dma_engine ;
int dma_size ;
/* IPC timeouts in ms */
int ipc_timeout ;
int boot_timeout ;
/* chip information for dsp */
const void * chip_info ;
/* defaults for no codec mode */
const char * nocodec_tplg_filename ;
/* defaults paths for firmware and topology files */
const char * default_fw_path ;
const char * default_tplg_path ;
2019-12-04 15:15:50 -06:00
/* default firmware name */
const char * default_fw_filename ;
2019-04-12 11:05:06 -05:00
const struct snd_sof_dsp_ops * ops ;
} ;
2021-03-19 14:49:49 +02:00
int sof_dai_get_mclk ( struct snd_soc_pcm_runtime * rtd ) ;
2020-11-20 16:16:53 +02:00
2019-04-12 11:05:06 -05:00
# endif