2019-06-04 11:11:33 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2012-10-11 06:54:02 +04:00
/*
* wm_adsp . h - - Wolfson ADSP support
*
* Copyright 2012 Wolfson Microelectronics plc
*
* Author : Mark Brown < broonie @ opensource . wolfsonmicro . com >
*/
# ifndef __WM_ADSP_H
# define __WM_ADSP_H
2021-09-13 19:00:57 +03:00
# include <linux/firmware/cirrus/cs_dsp.h>
# include <linux/firmware/cirrus/wmfw.h>
2012-10-11 06:54:02 +04:00
# include <sound/soc.h>
# include <sound/soc-dapm.h>
2015-12-15 14:29:45 +03:00
# include <sound/compress_driver.h>
2012-10-11 06:54:02 +04:00
2016-05-13 18:45:17 +03:00
/* Return values for wm_adsp_compr_handle_irq */
# define WM_ADSP_COMPR_OK 0
# define WM_ADSP_COMPR_VOICE_TRIGGER 1
2015-12-15 14:29:45 +03:00
struct wm_adsp_compr ;
2015-12-15 14:29:46 +03:00
struct wm_adsp_compr_buf ;
2015-06-11 13:32:32 +03:00
2021-09-13 19:00:55 +03:00
struct wm_adsp {
struct cs_dsp cs_dsp ;
const char * part ;
const char * fwf_name ;
2022-03-03 18:50:16 +03:00
const char * system_name ;
2021-09-13 19:00:55 +03:00
struct snd_soc_component * component ;
unsigned int sys_config_size ;
int fw ;
struct work_struct boot_work ;
bool preloaded ;
bool fatal_error ;
struct list_head compr_list ;
struct list_head buffer_list ;
2022-01-05 14:30:24 +03:00
/*
* Flag indicating the preloader widget only needs power toggled
* on state change rather than held on for the duration of the
* preload , useful for devices that can retain firmware memory
* across power down .
*/
bool toggle_preload ;
2012-10-11 06:54:02 +04:00
} ;
# define WM_ADSP1(wname, num) \
2013-06-19 21:34:02 +04:00
SND_SOC_DAPM_PGA_E ( wname , SND_SOC_NOPM , num , 0 , NULL , 0 , \
wm_adsp1_event , SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD )
2012-10-11 06:54:02 +04:00
2017-01-06 17:24:41 +03:00
# define WM_ADSP2_PRELOAD_SWITCH(wname, num) \
SOC_SINGLE_EXT ( wname " Preload Switch " , SND_SOC_NOPM , num , 1 , 0 , \
wm_adsp2_preloader_get , wm_adsp2_preloader_put )
2016-01-21 20:53:02 +03:00
# define WM_ADSP2(wname, num, event_fn) \
2017-01-06 17:24:41 +03:00
SND_SOC_DAPM_SPK ( wname " Preload " , NULL ) , \
2016-09-20 15:52:31 +03:00
{ . id = snd_soc_dapm_supply , . name = wname " Preloader " , \
2015-06-02 13:53:34 +03:00
. reg = SND_SOC_NOPM , . shift = num , . event = event_fn , \
2016-09-26 12:15:24 +03:00
. event_flags = SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD , \
2016-09-20 15:52:31 +03:00
. subseq = 100 , /* Ensure we run after SYSCLK supply widget */ } , \
2014-01-08 21:42:19 +04:00
{ . id = snd_soc_dapm_out_drv , . name = wname , \
2019-03-19 14:52:12 +03:00
. reg = SND_SOC_NOPM , . shift = num , . event = wm_adsp_event , \
2014-01-08 21:42:19 +04:00
. event_flags = SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD }
2012-10-11 06:54:02 +04:00
2018-08-08 19:13:38 +03:00
# define WM_ADSP_FW_CONTROL(dspname, num) \
SOC_ENUM_EXT ( dspname " Firmware " , wm_adsp_fw_enum [ num ] , \
wm_adsp_fw_get , wm_adsp_fw_put )
extern const struct soc_enum wm_adsp_fw_enum [ ] ;
2013-01-12 02:58:28 +04:00
2015-04-13 15:27:54 +03:00
int wm_adsp1_init ( struct wm_adsp * dsp ) ;
2015-06-02 13:53:34 +03:00
int wm_adsp2_init ( struct wm_adsp * dsp ) ;
2016-04-27 16:58:27 +03:00
void wm_adsp2_remove ( struct wm_adsp * dsp ) ;
2018-02-13 05:03:12 +03:00
int wm_adsp2_component_probe ( struct wm_adsp * dsp , struct snd_soc_component * component ) ;
int wm_adsp2_component_remove ( struct wm_adsp * dsp , struct snd_soc_component * component ) ;
2019-03-19 14:52:13 +03:00
int wm_halo_init ( struct wm_adsp * dsp ) ;
2012-10-11 06:54:02 +04:00
int wm_adsp1_event ( struct snd_soc_dapm_widget * w ,
struct snd_kcontrol * kcontrol , int event ) ;
2019-03-19 14:52:09 +03:00
2019-03-19 14:52:12 +03:00
int wm_adsp_early_event ( struct snd_soc_dapm_widget * w ,
struct snd_kcontrol * kcontrol , int event ) ;
2017-04-05 13:08:00 +03:00
2019-07-25 19:39:29 +03:00
irqreturn_t wm_adsp2_bus_error ( int irq , void * data ) ;
irqreturn_t wm_halo_bus_error ( int irq , void * data ) ;
2019-03-19 14:52:15 +03:00
irqreturn_t wm_halo_wdt_expire ( int irq , void * data ) ;
2017-04-05 13:08:00 +03:00
2019-03-19 14:52:12 +03:00
int wm_adsp_event ( struct snd_soc_dapm_widget * w ,
struct snd_kcontrol * kcontrol , int event ) ;
2012-10-11 06:54:02 +04:00
2019-03-19 14:52:09 +03:00
int wm_adsp2_set_dspclk ( struct snd_soc_dapm_widget * w , unsigned int freq ) ;
2017-01-06 17:24:41 +03:00
int wm_adsp2_preloader_get ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol ) ;
int wm_adsp2_preloader_put ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol ) ;
2018-08-08 19:13:38 +03:00
int wm_adsp_fw_get ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol ) ;
int wm_adsp_fw_put ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol ) ;
2017-01-06 17:24:41 +03:00
2016-11-29 13:46:21 +03:00
int wm_adsp_compr_open ( struct wm_adsp * dsp , struct snd_compr_stream * stream ) ;
2020-04-20 10:08:13 +03:00
int wm_adsp_compr_free ( struct snd_soc_component * component ,
struct snd_compr_stream * stream ) ;
int wm_adsp_compr_set_params ( struct snd_soc_component * component ,
struct snd_compr_stream * stream ,
2016-11-29 13:46:21 +03:00
struct snd_compr_params * params ) ;
2020-04-20 10:08:13 +03:00
int wm_adsp_compr_get_caps ( struct snd_soc_component * component ,
struct snd_compr_stream * stream ,
2016-11-29 13:46:21 +03:00
struct snd_compr_caps * caps ) ;
2020-04-20 10:08:13 +03:00
int wm_adsp_compr_trigger ( struct snd_soc_component * component ,
struct snd_compr_stream * stream , int cmd ) ;
2016-11-29 13:46:21 +03:00
int wm_adsp_compr_handle_irq ( struct wm_adsp * dsp ) ;
2020-04-20 10:08:13 +03:00
int wm_adsp_compr_pointer ( struct snd_soc_component * component ,
struct snd_compr_stream * stream ,
2016-11-29 13:46:21 +03:00
struct snd_compr_tstamp * tstamp ) ;
2020-04-20 10:08:13 +03:00
int wm_adsp_compr_copy ( struct snd_soc_component * component ,
struct snd_compr_stream * stream ,
2016-11-29 13:46:21 +03:00
char __user * buf , size_t count ) ;
2019-11-15 22:54:13 +03:00
int wm_adsp_write_ctl ( struct wm_adsp * dsp , const char * name , int type ,
unsigned int alg , void * buf , size_t len ) ;
int wm_adsp_read_ctl ( struct wm_adsp * dsp , const char * name , int type ,
unsigned int alg , void * buf , size_t len ) ;
2015-12-15 14:29:45 +03:00
2012-10-11 06:54:02 +04:00
# endif