~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/sound/soc-topology.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/sound/soc-topology.h (Version linux-6.12-rc7) and /include/sound/soc-topology.h (Version linux-4.20.17)


  1 /* SPDX-License-Identifier: GPL-2.0                 1 /* SPDX-License-Identifier: GPL-2.0
  2  *                                                  2  *
  3  * linux/sound/soc-topology.h -- ALSA SoC Firm      3  * linux/sound/soc-topology.h -- ALSA SoC Firmware Controls and DAPM
  4  *                                                  4  *
  5  * Copyright (C) 2012 Texas Instruments Inc.        5  * Copyright (C) 2012 Texas Instruments Inc.
  6  * Copyright (C) 2015 Intel Corporation.            6  * Copyright (C) 2015 Intel Corporation.
  7  *                                                  7  *
  8  * Simple file API to load FW that includes mi      8  * Simple file API to load FW that includes mixers, coefficients, DAPM graphs,
  9  * algorithms, equalisers, DAIs, widgets, FE c      9  * algorithms, equalisers, DAIs, widgets, FE caps, BE caps, codec link caps etc.
 10  */                                                10  */
 11                                                    11 
 12 #ifndef __LINUX_SND_SOC_TPLG_H                     12 #ifndef __LINUX_SND_SOC_TPLG_H
 13 #define __LINUX_SND_SOC_TPLG_H                     13 #define __LINUX_SND_SOC_TPLG_H
 14                                                    14 
 15 #include <sound/asoc.h>                            15 #include <sound/asoc.h>
 16 #include <linux/list.h>                            16 #include <linux/list.h>
 17                                                    17 
 18 struct firmware;                                   18 struct firmware;
 19 struct snd_kcontrol;                               19 struct snd_kcontrol;
 20 struct snd_soc_tplg_pcm_be;                        20 struct snd_soc_tplg_pcm_be;
 21 struct snd_ctl_elem_value;                         21 struct snd_ctl_elem_value;
 22 struct snd_ctl_elem_info;                          22 struct snd_ctl_elem_info;
 23 struct snd_soc_dapm_widget;                        23 struct snd_soc_dapm_widget;
 24 struct snd_soc_component;                          24 struct snd_soc_component;
 25 struct snd_soc_tplg_pcm_fe;                        25 struct snd_soc_tplg_pcm_fe;
 26 struct snd_soc_dapm_context;                       26 struct snd_soc_dapm_context;
 27 struct snd_soc_card;                               27 struct snd_soc_card;
 28 struct snd_kcontrol_new;                           28 struct snd_kcontrol_new;
 29 struct snd_soc_dai_link;                           29 struct snd_soc_dai_link;
 30 struct snd_soc_dai_driver;                         30 struct snd_soc_dai_driver;
 31 struct snd_soc_dai;                                31 struct snd_soc_dai;
 32 struct snd_soc_dapm_route;                         32 struct snd_soc_dapm_route;
 33                                                    33 
                                                   >>  34 /* object scan be loaded and unloaded in groups with identfying indexes */
                                                   >>  35 #define SND_SOC_TPLG_INDEX_ALL  0       /* ID that matches all FW objects */
                                                   >>  36 
 34 /* dynamic object type */                          37 /* dynamic object type */
 35 enum snd_soc_dobj_type {                           38 enum snd_soc_dobj_type {
 36         SND_SOC_DOBJ_NONE               = 0,       39         SND_SOC_DOBJ_NONE               = 0,    /* object is not dynamic */
 37         SND_SOC_DOBJ_MIXER,                        40         SND_SOC_DOBJ_MIXER,
 38         SND_SOC_DOBJ_BYTES,                    << 
 39         SND_SOC_DOBJ_ENUM,                         41         SND_SOC_DOBJ_ENUM,
 40         SND_SOC_DOBJ_GRAPH,                    !!  42         SND_SOC_DOBJ_BYTES,
 41         SND_SOC_DOBJ_WIDGET,                   << 
 42         SND_SOC_DOBJ_DAI_LINK,                 << 
 43         SND_SOC_DOBJ_PCM,                          43         SND_SOC_DOBJ_PCM,
                                                   >>  44         SND_SOC_DOBJ_DAI_LINK,
 44         SND_SOC_DOBJ_CODEC_LINK,                   45         SND_SOC_DOBJ_CODEC_LINK,
 45         SND_SOC_DOBJ_BACKEND_LINK,             !!  46         SND_SOC_DOBJ_WIDGET,
 46 };                                                 47 };
 47                                                    48 
 48 /* dynamic control object */                       49 /* dynamic control object */
 49 struct snd_soc_dobj_control {                      50 struct snd_soc_dobj_control {
 50         struct snd_kcontrol *kcontrol;             51         struct snd_kcontrol *kcontrol;
 51         char **dtexts;                             52         char **dtexts;
 52         unsigned long *dvalues;                    53         unsigned long *dvalues;
 53 };                                                 54 };
 54                                                    55 
 55 /* dynamic widget object */                        56 /* dynamic widget object */
 56 struct snd_soc_dobj_widget {                       57 struct snd_soc_dobj_widget {
 57         unsigned int *kcontrol_type;    /* kco !!  58         unsigned int kcontrol_type;     /* kcontrol type: mixer, enum, bytes */
 58 };                                                 59 };
 59                                                    60 
 60 /* generic dynamic object - all dynamic object     61 /* generic dynamic object - all dynamic objects belong to this struct */
 61 struct snd_soc_dobj {                              62 struct snd_soc_dobj {
 62         enum snd_soc_dobj_type type;               63         enum snd_soc_dobj_type type;
 63         unsigned int index;     /* objects can     64         unsigned int index;     /* objects can belong in different groups */
 64         struct list_head list;                     65         struct list_head list;
 65         int (*unload)(struct snd_soc_component !!  66         struct snd_soc_tplg_ops *ops;
 66         union {                                    67         union {
 67                 struct snd_soc_dobj_control co     68                 struct snd_soc_dobj_control control;
 68                 struct snd_soc_dobj_widget wid     69                 struct snd_soc_dobj_widget widget;
 69         };                                         70         };
 70         void *private; /* core does not touch      71         void *private; /* core does not touch this */
 71 };                                                 72 };
 72                                                    73 
 73 /*                                                 74 /*
 74  * Kcontrol operations - used to map handlers      75  * Kcontrol operations - used to map handlers onto firmware based controls.
 75  */                                                76  */
 76 struct snd_soc_tplg_kcontrol_ops {                 77 struct snd_soc_tplg_kcontrol_ops {
 77         u32 id;                                    78         u32 id;
 78         int (*get)(struct snd_kcontrol *kcontr     79         int (*get)(struct snd_kcontrol *kcontrol,
 79                         struct snd_ctl_elem_va     80                         struct snd_ctl_elem_value *ucontrol);
 80         int (*put)(struct snd_kcontrol *kcontr     81         int (*put)(struct snd_kcontrol *kcontrol,
 81                         struct snd_ctl_elem_va     82                         struct snd_ctl_elem_value *ucontrol);
 82         int (*info)(struct snd_kcontrol *kcont     83         int (*info)(struct snd_kcontrol *kcontrol,
 83                 struct snd_ctl_elem_info *uinf     84                 struct snd_ctl_elem_info *uinfo);
 84 };                                                 85 };
 85                                                    86 
 86 /* Bytes ext operations, for TLV byte controls     87 /* Bytes ext operations, for TLV byte controls */
 87 struct snd_soc_tplg_bytes_ext_ops {                88 struct snd_soc_tplg_bytes_ext_ops {
 88         u32 id;                                    89         u32 id;
 89         int (*get)(struct snd_kcontrol *kcontr     90         int (*get)(struct snd_kcontrol *kcontrol, unsigned int __user *bytes,
 90                                                    91                                                         unsigned int size);
 91         int (*put)(struct snd_kcontrol *kcontr     92         int (*put)(struct snd_kcontrol *kcontrol,
 92                         const unsigned int __u     93                         const unsigned int __user *bytes, unsigned int size);
 93 };                                                 94 };
 94                                                    95 
 95 /*                                                 96 /*
 96  * DAPM widget event handlers - used to map ha     97  * DAPM widget event handlers - used to map handlers onto widgets.
 97  */                                                98  */
 98 struct snd_soc_tplg_widget_events {                99 struct snd_soc_tplg_widget_events {
 99         u16 type;                                 100         u16 type;
100         int (*event_handler)(struct snd_soc_da    101         int (*event_handler)(struct snd_soc_dapm_widget *w,
101                         struct snd_kcontrol *k    102                         struct snd_kcontrol *k, int event);
102 };                                                103 };
103                                                   104 
104 /*                                                105 /*
105  * Public API - Used by component drivers to l    106  * Public API - Used by component drivers to load and unload dynamic objects
106  * and their resources.                           107  * and their resources.
107  */                                               108  */
108 struct snd_soc_tplg_ops {                         109 struct snd_soc_tplg_ops {
109                                                   110 
110         /* external kcontrol init - used for a    111         /* external kcontrol init - used for any driver specific init */
111         int (*control_load)(struct snd_soc_com    112         int (*control_load)(struct snd_soc_component *, int index,
112                 struct snd_kcontrol_new *, str    113                 struct snd_kcontrol_new *, struct snd_soc_tplg_ctl_hdr *);
113         int (*control_unload)(struct snd_soc_c    114         int (*control_unload)(struct snd_soc_component *,
114                 struct snd_soc_dobj *);           115                 struct snd_soc_dobj *);
115                                                   116 
116         /* DAPM graph route element loading an    117         /* DAPM graph route element loading and unloading */
117         int (*dapm_route_load)(struct snd_soc_    118         int (*dapm_route_load)(struct snd_soc_component *, int index,
118                 struct snd_soc_dapm_route *rou    119                 struct snd_soc_dapm_route *route);
119         int (*dapm_route_unload)(struct snd_so    120         int (*dapm_route_unload)(struct snd_soc_component *,
120                 struct snd_soc_dobj *);           121                 struct snd_soc_dobj *);
121                                                   122 
122         /* external widget init - used for any    123         /* external widget init - used for any driver specific init */
123         int (*widget_load)(struct snd_soc_comp    124         int (*widget_load)(struct snd_soc_component *, int index,
124                 struct snd_soc_dapm_widget *,     125                 struct snd_soc_dapm_widget *,
125                 struct snd_soc_tplg_dapm_widge    126                 struct snd_soc_tplg_dapm_widget *);
126         int (*widget_ready)(struct snd_soc_com    127         int (*widget_ready)(struct snd_soc_component *, int index,
127                 struct snd_soc_dapm_widget *,     128                 struct snd_soc_dapm_widget *,
128                 struct snd_soc_tplg_dapm_widge    129                 struct snd_soc_tplg_dapm_widget *);
129         int (*widget_unload)(struct snd_soc_co    130         int (*widget_unload)(struct snd_soc_component *,
130                 struct snd_soc_dobj *);           131                 struct snd_soc_dobj *);
131                                                   132 
132         /* FE DAI - used for any driver specif    133         /* FE DAI - used for any driver specific init */
133         int (*dai_load)(struct snd_soc_compone    134         int (*dai_load)(struct snd_soc_component *, int index,
134                 struct snd_soc_dai_driver *dai    135                 struct snd_soc_dai_driver *dai_drv,
135                 struct snd_soc_tplg_pcm *pcm,     136                 struct snd_soc_tplg_pcm *pcm, struct snd_soc_dai *dai);
136                                                   137 
137         int (*dai_unload)(struct snd_soc_compo    138         int (*dai_unload)(struct snd_soc_component *,
138                 struct snd_soc_dobj *);           139                 struct snd_soc_dobj *);
139                                                   140 
140         /* DAI link - used for any driver spec    141         /* DAI link - used for any driver specific init */
141         int (*link_load)(struct snd_soc_compon    142         int (*link_load)(struct snd_soc_component *, int index,
142                 struct snd_soc_dai_link *link,    143                 struct snd_soc_dai_link *link,
143                 struct snd_soc_tplg_link_confi    144                 struct snd_soc_tplg_link_config *cfg);
144         int (*link_unload)(struct snd_soc_comp    145         int (*link_unload)(struct snd_soc_component *,
145                 struct snd_soc_dobj *);           146                 struct snd_soc_dobj *);
146                                                   147 
147         /* callback to handle vendor bespoke d    148         /* callback to handle vendor bespoke data */
148         int (*vendor_load)(struct snd_soc_comp    149         int (*vendor_load)(struct snd_soc_component *, int index,
149                 struct snd_soc_tplg_hdr *);       150                 struct snd_soc_tplg_hdr *);
150         int (*vendor_unload)(struct snd_soc_co    151         int (*vendor_unload)(struct snd_soc_component *,
151                 struct snd_soc_tplg_hdr *);       152                 struct snd_soc_tplg_hdr *);
152                                                   153 
153         /* completion - called at completion o    154         /* completion - called at completion of firmware loading */
154         int (*complete)(struct snd_soc_compone !! 155         void (*complete)(struct snd_soc_component *);
155                                                   156 
156         /* manifest - optional to inform compo    157         /* manifest - optional to inform component of manifest */
157         int (*manifest)(struct snd_soc_compone    158         int (*manifest)(struct snd_soc_component *, int index,
158                 struct snd_soc_tplg_manifest *    159                 struct snd_soc_tplg_manifest *);
159                                                   160 
160         /* vendor specific kcontrol handlers a    161         /* vendor specific kcontrol handlers available for binding */
161         const struct snd_soc_tplg_kcontrol_ops    162         const struct snd_soc_tplg_kcontrol_ops *io_ops;
162         int io_ops_count;                         163         int io_ops_count;
163                                                   164 
164         /* vendor specific bytes ext handlers     165         /* vendor specific bytes ext handlers available for binding */
165         const struct snd_soc_tplg_bytes_ext_op    166         const struct snd_soc_tplg_bytes_ext_ops *bytes_ext_ops;
166         int bytes_ext_ops_count;                  167         int bytes_ext_ops_count;
167 };                                                168 };
168                                                   169 
169 #ifdef CONFIG_SND_SOC_TOPOLOGY                    170 #ifdef CONFIG_SND_SOC_TOPOLOGY
170                                                   171 
171 /* gets a pointer to data from the firmware bl    172 /* gets a pointer to data from the firmware block header */
172 static inline const void *snd_soc_tplg_get_dat    173 static inline const void *snd_soc_tplg_get_data(struct snd_soc_tplg_hdr *hdr)
173 {                                                 174 {
174         const void *ptr = hdr;                    175         const void *ptr = hdr;
175                                                   176 
176         return ptr + sizeof(*hdr);                177         return ptr + sizeof(*hdr);
177 }                                                 178 }
178                                                   179 
179 /* Dynamic Object loading and removal for comp    180 /* Dynamic Object loading and removal for component drivers */
180 int snd_soc_tplg_component_load(struct snd_soc    181 int snd_soc_tplg_component_load(struct snd_soc_component *comp,
181         const struct snd_soc_tplg_ops *ops, co !! 182         struct snd_soc_tplg_ops *ops, const struct firmware *fw,
182 int snd_soc_tplg_component_remove(struct snd_s !! 183         u32 index);
                                                   >> 184 int snd_soc_tplg_component_remove(struct snd_soc_component *comp, u32 index);
                                                   >> 185 
                                                   >> 186 /* Widget removal - widgets also removed wth component API */
                                                   >> 187 void snd_soc_tplg_widget_remove(struct snd_soc_dapm_widget *w);
                                                   >> 188 void snd_soc_tplg_widget_remove_all(struct snd_soc_dapm_context *dapm,
                                                   >> 189         u32 index);
183                                                   190 
184 /* Binds event handlers to dynamic widgets */     191 /* Binds event handlers to dynamic widgets */
185 int snd_soc_tplg_widget_bind_event(struct snd_    192 int snd_soc_tplg_widget_bind_event(struct snd_soc_dapm_widget *w,
186         const struct snd_soc_tplg_widget_event    193         const struct snd_soc_tplg_widget_events *events, int num_events,
187         u16 event_type);                          194         u16 event_type);
188                                                   195 
189 #else                                             196 #else
190                                                   197 
191 static inline int snd_soc_tplg_component_remov !! 198 static inline int snd_soc_tplg_component_remove(struct snd_soc_component *comp,
                                                   >> 199                                                 u32 index)
192 {                                                 200 {
193         return 0;                                 201         return 0;
194 }                                                 202 }
195                                                   203 
196 #endif                                            204 #endif
197                                                   205 
198 #endif                                            206 #endif
199                                                   207 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php