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 >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
# ifndef __WM_ADSP_H
# define __WM_ADSP_H
# 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
# include "wmfw.h"
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
2017-04-05 13:08:00 +03:00
# define WM_ADSP2_REGION_0 BIT(0)
# define WM_ADSP2_REGION_1 BIT(1)
# define WM_ADSP2_REGION_2 BIT(2)
# define WM_ADSP2_REGION_3 BIT(3)
# define WM_ADSP2_REGION_4 BIT(4)
# define WM_ADSP2_REGION_5 BIT(5)
# define WM_ADSP2_REGION_6 BIT(6)
# define WM_ADSP2_REGION_7 BIT(7)
# define WM_ADSP2_REGION_8 BIT(8)
# define WM_ADSP2_REGION_9 BIT(9)
# define WM_ADSP2_REGION_1_9 (WM_ADSP2_REGION_1 | \
WM_ADSP2_REGION_2 | WM_ADSP2_REGION_3 | \
WM_ADSP2_REGION_4 | WM_ADSP2_REGION_5 | \
WM_ADSP2_REGION_6 | WM_ADSP2_REGION_7 | \
WM_ADSP2_REGION_8 | WM_ADSP2_REGION_9 )
# define WM_ADSP2_REGION_ALL (WM_ADSP2_REGION_0 | WM_ADSP2_REGION_1_9)
2012-10-11 06:54:02 +04:00
struct wm_adsp_region {
int type ;
unsigned int base ;
} ;
2013-01-08 20:09:31 +04:00
struct wm_adsp_alg_region {
struct list_head list ;
unsigned int alg ;
int type ;
unsigned int base ;
} ;
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 ;
2019-03-19 14:52:12 +03:00
struct wm_adsp_ops ;
2015-12-15 14:29:45 +03:00
2012-10-11 06:54:02 +04:00
struct wm_adsp {
const char * part ;
2018-08-08 19:13:39 +03:00
const char * name ;
const char * fwf_name ;
2017-04-05 13:07:59 +03:00
int rev ;
2012-10-11 06:54:02 +04:00
int num ;
int type ;
struct device * dev ;
struct regmap * regmap ;
2018-02-13 05:03:12 +03:00
struct snd_soc_component * component ;
2012-10-11 06:54:02 +04:00
2019-03-19 14:52:12 +03:00
struct wm_adsp_ops * ops ;
2018-02-16 17:36:10 +03:00
unsigned int base ;
unsigned int sysclk_reg ;
unsigned int sysclk_mask ;
unsigned int sysclk_shift ;
2012-10-11 06:54:02 +04:00
2013-01-08 20:09:31 +04:00
struct list_head alg_regions ;
2015-12-08 19:08:25 +03:00
unsigned int fw_id ;
unsigned int fw_id_version ;
2013-03-05 18:39:54 +04:00
2012-10-11 06:54:02 +04:00
const struct wm_adsp_region * mem ;
int num_mems ;
2012-11-28 21:20:32 +04:00
2013-01-12 02:58:28 +04:00
int fw ;
2015-04-13 15:28:02 +03:00
int fw_ver ;
2016-09-20 15:52:32 +03:00
2017-01-06 17:24:41 +03:00
bool preloaded ;
2016-09-20 15:52:32 +03:00
bool booted ;
2015-09-27 01:04:07 +03:00
bool running ;
2019-03-19 14:52:07 +03:00
bool fatal_error ;
2013-01-12 02:58:28 +04:00
2013-07-29 16:51:59 +04:00
struct list_head ctl_list ;
2014-01-08 21:42:18 +04:00
struct work_struct boot_work ;
2015-06-11 13:32:32 +03:00
2019-02-22 13:04:20 +03:00
struct list_head compr_list ;
struct list_head buffer_list ;
2015-12-15 14:29:45 +03:00
2015-12-08 19:08:26 +03:00
struct mutex pwr_lock ;
2017-04-05 13:08:00 +03:00
unsigned int lock_regions ;
2015-06-11 13:32:32 +03:00
# ifdef CONFIG_DEBUG_FS
struct dentry * debugfs_root ;
char * wmfw_file_name ;
char * bin_file_name ;
# endif
2012-10-11 06:54:02 +04:00
} ;
2019-03-19 14:52:12 +03:00
struct wm_adsp_ops {
bool ( * validate_version ) ( struct wm_adsp * dsp , unsigned int version ) ;
unsigned int ( * parse_sizes ) ( struct wm_adsp * dsp ,
const char * const file ,
unsigned int pos ,
const struct firmware * firmware ) ;
int ( * setup_algs ) ( struct wm_adsp * dsp ) ;
void ( * show_fw_status ) ( struct wm_adsp * dsp ) ;
void ( * stop_watchdog ) ( struct wm_adsp * dsp ) ;
int ( * enable_memory ) ( struct wm_adsp * dsp ) ;
void ( * disable_memory ) ( struct wm_adsp * dsp ) ;
int ( * lock_memory ) ( struct wm_adsp * dsp , unsigned int lock_regions ) ;
int ( * enable_core ) ( struct wm_adsp * dsp ) ;
void ( * disable_core ) ( struct wm_adsp * dsp ) ;
int ( * start_core ) ( struct wm_adsp * dsp ) ;
void ( * stop_core ) ( struct wm_adsp * dsp ) ;
} ;
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 ) ;
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
irqreturn_t wm_adsp2_bus_error ( struct wm_adsp * adsp ) ;
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 ) ;
int wm_adsp_compr_free ( struct snd_compr_stream * stream ) ;
int wm_adsp_compr_set_params ( struct snd_compr_stream * stream ,
struct snd_compr_params * params ) ;
int wm_adsp_compr_get_caps ( struct snd_compr_stream * stream ,
struct snd_compr_caps * caps ) ;
int wm_adsp_compr_trigger ( struct snd_compr_stream * stream , int cmd ) ;
int wm_adsp_compr_handle_irq ( struct wm_adsp * dsp ) ;
int wm_adsp_compr_pointer ( struct snd_compr_stream * stream ,
struct snd_compr_tstamp * tstamp ) ;
int wm_adsp_compr_copy ( struct snd_compr_stream * stream ,
char __user * buf , size_t count ) ;
2015-12-15 14:29:45 +03:00
2012-10-11 06:54:02 +04:00
# endif