2015-05-29 19:06:14 +01:00
/*
* linux / sound / soc - topology . h - - ALSA SoC Firmware Controls and DAPM
*
* Copyright ( C ) 2012 Texas Instruments Inc .
* Copyright ( C ) 2015 Intel Corporation .
*
* 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 .
*
* Simple file API to load FW that includes mixers , coefficients , DAPM graphs ,
* algorithms , equalisers , DAIs , widgets , FE caps , BE caps , codec link caps etc .
*/
# ifndef __LINUX_SND_SOC_TPLG_H
# define __LINUX_SND_SOC_TPLG_H
# include <sound/asoc.h>
# include <linux/list.h>
struct firmware ;
struct snd_kcontrol ;
struct snd_soc_tplg_pcm_be ;
struct snd_ctl_elem_value ;
struct snd_ctl_elem_info ;
struct snd_soc_dapm_widget ;
struct snd_soc_component ;
struct snd_soc_tplg_pcm_fe ;
struct snd_soc_dapm_context ;
struct snd_soc_card ;
2017-06-06 15:55:04 +01:00
struct snd_kcontrol_new ;
struct snd_soc_dai_link ;
2015-05-29 19:06:14 +01:00
/* object scan be loaded and unloaded in groups with identfying indexes */
# define SND_SOC_TPLG_INDEX_ALL 0 /* ID that matches all FW objects */
/* dynamic object type */
enum snd_soc_dobj_type {
SND_SOC_DOBJ_NONE = 0 , /* object is not dynamic */
SND_SOC_DOBJ_MIXER ,
SND_SOC_DOBJ_ENUM ,
SND_SOC_DOBJ_BYTES ,
SND_SOC_DOBJ_PCM ,
SND_SOC_DOBJ_DAI_LINK ,
SND_SOC_DOBJ_CODEC_LINK ,
SND_SOC_DOBJ_WIDGET ,
} ;
/* dynamic control object */
struct snd_soc_dobj_control {
struct snd_kcontrol * kcontrol ;
char * * dtexts ;
unsigned long * dvalues ;
} ;
/* dynamic widget object */
struct snd_soc_dobj_widget {
2016-11-25 16:09:17 +08:00
unsigned int kcontrol_type ; /* kcontrol type: mixer, enum, bytes */
2015-05-29 19:06:14 +01:00
} ;
/* generic dynamic object - all dynamic objects belong to this struct */
struct snd_soc_dobj {
enum snd_soc_dobj_type type ;
unsigned int index ; /* objects can belong in different groups */
struct list_head list ;
struct snd_soc_tplg_ops * ops ;
union {
struct snd_soc_dobj_control control ;
struct snd_soc_dobj_widget widget ;
} ;
void * private ; /* core does not touch this */
} ;
/*
* Kcontrol operations - used to map handlers onto firmware based controls .
*/
struct snd_soc_tplg_kcontrol_ops {
u32 id ;
int ( * get ) ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol ) ;
int ( * put ) ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol ) ;
int ( * info ) ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_info * uinfo ) ;
} ;
2015-08-18 18:12:20 +08:00
/* Bytes ext operations, for TLV byte controls */
struct snd_soc_tplg_bytes_ext_ops {
u32 id ;
2015-11-09 23:20:00 +05:30
int ( * get ) ( struct snd_kcontrol * kcontrol , unsigned int __user * bytes ,
unsigned int size ) ;
int ( * put ) ( struct snd_kcontrol * kcontrol ,
const unsigned int __user * bytes , unsigned int size ) ;
2015-08-18 18:12:20 +08:00
} ;
2015-05-29 19:06:14 +01:00
/*
* DAPM widget event handlers - used to map handlers onto widgets .
*/
struct snd_soc_tplg_widget_events {
u16 type ;
int ( * event_handler ) ( struct snd_soc_dapm_widget * w ,
struct snd_kcontrol * k , int event ) ;
} ;
/*
* Public API - Used by component drivers to load and unload dynamic objects
* and their resources .
*/
struct snd_soc_tplg_ops {
/* external kcontrol init - used for any driver specific init */
int ( * control_load ) ( struct snd_soc_component * ,
struct snd_kcontrol_new * , struct snd_soc_tplg_ctl_hdr * ) ;
int ( * control_unload ) ( struct snd_soc_component * ,
struct snd_soc_dobj * ) ;
/* external widget init - used for any driver specific init */
int ( * widget_load ) ( struct snd_soc_component * ,
struct snd_soc_dapm_widget * ,
struct snd_soc_tplg_dapm_widget * ) ;
2017-06-09 15:43:23 +01:00
int ( * widget_ready ) ( struct snd_soc_component * ,
struct snd_soc_dapm_widget * ,
struct snd_soc_tplg_dapm_widget * ) ;
2015-05-29 19:06:14 +01:00
int ( * widget_unload ) ( struct snd_soc_component * ,
struct snd_soc_dobj * ) ;
2016-01-15 16:13:28 +08:00
/* FE DAI - used for any driver specific init */
int ( * dai_load ) ( struct snd_soc_component * ,
struct snd_soc_dai_driver * dai_drv ) ;
int ( * dai_unload ) ( struct snd_soc_component * ,
2015-05-29 19:06:14 +01:00
struct snd_soc_dobj * ) ;
2016-01-15 16:13:37 +08:00
/* DAI link - used for any driver specific init */
int ( * link_load ) ( struct snd_soc_component * ,
struct snd_soc_dai_link * link ) ;
int ( * link_unload ) ( struct snd_soc_component * ,
struct snd_soc_dobj * ) ;
2015-05-29 19:06:14 +01:00
/* callback to handle vendor bespoke data */
int ( * vendor_load ) ( struct snd_soc_component * ,
struct snd_soc_tplg_hdr * ) ;
int ( * vendor_unload ) ( struct snd_soc_component * ,
struct snd_soc_tplg_hdr * ) ;
/* completion - called at completion of firmware loading */
void ( * complete ) ( struct snd_soc_component * ) ;
/* manifest - optional to inform component of manifest */
int ( * manifest ) ( struct snd_soc_component * ,
struct snd_soc_tplg_manifest * ) ;
2015-08-18 18:11:51 +08:00
/* vendor specific kcontrol handlers available for binding */
2015-05-29 19:06:14 +01:00
const struct snd_soc_tplg_kcontrol_ops * io_ops ;
int io_ops_count ;
2015-08-18 18:12:20 +08:00
/* vendor specific bytes ext handlers available for binding */
const struct snd_soc_tplg_bytes_ext_ops * bytes_ext_ops ;
int bytes_ext_ops_count ;
2015-05-29 19:06:14 +01:00
} ;
2015-08-15 08:24:20 -07:00
# ifdef CONFIG_SND_SOC_TOPOLOGY
2015-05-29 19:06:14 +01:00
/* gets a pointer to data from the firmware block header */
static inline const void * snd_soc_tplg_get_data ( struct snd_soc_tplg_hdr * hdr )
{
const void * ptr = hdr ;
return ptr + sizeof ( * hdr ) ;
}
/* Dynamic Object loading and removal for component drivers */
int snd_soc_tplg_component_load ( struct snd_soc_component * comp ,
struct snd_soc_tplg_ops * ops , const struct firmware * fw ,
u32 index ) ;
int snd_soc_tplg_component_remove ( struct snd_soc_component * comp , u32 index ) ;
/* Widget removal - widgets also removed wth component API */
void snd_soc_tplg_widget_remove ( struct snd_soc_dapm_widget * w ) ;
void snd_soc_tplg_widget_remove_all ( struct snd_soc_dapm_context * dapm ,
u32 index ) ;
/* Binds event handlers to dynamic widgets */
int snd_soc_tplg_widget_bind_event ( struct snd_soc_dapm_widget * w ,
const struct snd_soc_tplg_widget_events * events , int num_events ,
u16 event_type ) ;
2015-08-15 08:24:20 -07:00
# else
static inline int snd_soc_tplg_component_remove ( struct snd_soc_component * comp ,
u32 index )
{
return 0 ;
}
# endif
2015-05-29 19:06:14 +01:00
# endif