1 /**************************************************************************** 2 **************************************************************************** 3 *** 4 *** This header was automatically generated from a Linux kernel header 5 *** of the same name, to make information necessary for userspace to 6 *** call into the kernel available to libc. It contains only constants, 7 *** structures, and macros generated from the original header, and thus, 8 *** contains no copyrightable information. 9 *** 10 *** To edit the content of this header, modify the corresponding 11 *** source file (e.g. under external/kernel-headers/original/) then 12 *** run bionic/libc/kernel/tools/update_all.py 13 *** 14 *** Any manual change here will be lost the next time this script will 15 *** be run. You've been warned! 16 *** 17 **************************************************************************** 18 ****************************************************************************/ 19 #ifndef __LINUX_UAPI_SND_ASOC_H 20 #define __LINUX_UAPI_SND_ASOC_H 21 #include <linux/types.h> 22 #include <sound/asound.h> 23 #define SND_SOC_TPLG_MAX_CHAN 8 24 #define SND_SOC_TPLG_MAX_FORMATS 16 25 #define SND_SOC_TPLG_STREAM_CONFIG_MAX 8 26 #define SND_SOC_TPLG_HW_CONFIG_MAX 8 27 #define SND_SOC_TPLG_CTL_VOLSW 1 28 #define SND_SOC_TPLG_CTL_VOLSW_SX 2 29 #define SND_SOC_TPLG_CTL_VOLSW_XR_SX 3 30 #define SND_SOC_TPLG_CTL_ENUM 4 31 #define SND_SOC_TPLG_CTL_BYTES 5 32 #define SND_SOC_TPLG_CTL_ENUM_VALUE 6 33 #define SND_SOC_TPLG_CTL_RANGE 7 34 #define SND_SOC_TPLG_CTL_STROBE 8 35 #define SND_SOC_TPLG_DAPM_CTL_VOLSW 64 36 #define SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE 65 37 #define SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT 66 38 #define SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE 67 39 #define SND_SOC_TPLG_DAPM_CTL_PIN 68 40 #define SND_SOC_TPLG_DAPM_INPUT 0 41 #define SND_SOC_TPLG_DAPM_OUTPUT 1 42 #define SND_SOC_TPLG_DAPM_MUX 2 43 #define SND_SOC_TPLG_DAPM_MIXER 3 44 #define SND_SOC_TPLG_DAPM_PGA 4 45 #define SND_SOC_TPLG_DAPM_OUT_DRV 5 46 #define SND_SOC_TPLG_DAPM_ADC 6 47 #define SND_SOC_TPLG_DAPM_DAC 7 48 #define SND_SOC_TPLG_DAPM_SWITCH 8 49 #define SND_SOC_TPLG_DAPM_PRE 9 50 #define SND_SOC_TPLG_DAPM_POST 10 51 #define SND_SOC_TPLG_DAPM_AIF_IN 11 52 #define SND_SOC_TPLG_DAPM_AIF_OUT 12 53 #define SND_SOC_TPLG_DAPM_DAI_IN 13 54 #define SND_SOC_TPLG_DAPM_DAI_OUT 14 55 #define SND_SOC_TPLG_DAPM_DAI_LINK 15 56 #define SND_SOC_TPLG_DAPM_BUFFER 16 57 #define SND_SOC_TPLG_DAPM_SCHEDULER 17 58 #define SND_SOC_TPLG_DAPM_EFFECT 18 59 #define SND_SOC_TPLG_DAPM_SIGGEN 19 60 #define SND_SOC_TPLG_DAPM_SRC 20 61 #define SND_SOC_TPLG_DAPM_ASRC 21 62 #define SND_SOC_TPLG_DAPM_ENCODER 22 63 #define SND_SOC_TPLG_DAPM_DECODER 23 64 #define SND_SOC_TPLG_DAPM_LAST SND_SOC_TPLG_DAPM_DECODER 65 #define SND_SOC_TPLG_MAGIC 0x41536F43 66 #define SND_SOC_TPLG_NUM_TEXTS 16 67 #define SND_SOC_TPLG_ABI_VERSION 0x5 68 #define SND_SOC_TPLG_ABI_VERSION_MIN 0x4 69 #define SND_SOC_TPLG_TLV_SIZE 32 70 #define SND_SOC_TPLG_TYPE_MIXER 1 71 #define SND_SOC_TPLG_TYPE_BYTES 2 72 #define SND_SOC_TPLG_TYPE_ENUM 3 73 #define SND_SOC_TPLG_TYPE_DAPM_GRAPH 4 74 #define SND_SOC_TPLG_TYPE_DAPM_WIDGET 5 75 #define SND_SOC_TPLG_TYPE_DAI_LINK 6 76 #define SND_SOC_TPLG_TYPE_PCM 7 77 #define SND_SOC_TPLG_TYPE_MANIFEST 8 78 #define SND_SOC_TPLG_TYPE_CODEC_LINK 9 79 #define SND_SOC_TPLG_TYPE_BACKEND_LINK 10 80 #define SND_SOC_TPLG_TYPE_PDATA 11 81 #define SND_SOC_TPLG_TYPE_DAI 12 82 #define SND_SOC_TPLG_TYPE_MAX SND_SOC_TPLG_TYPE_DAI 83 #define SND_SOC_TPLG_TYPE_VENDOR_FW 1000 84 #define SND_SOC_TPLG_TYPE_VENDOR_CONFIG 1001 85 #define SND_SOC_TPLG_TYPE_VENDOR_COEFF 1002 86 #define SND_SOC_TPLG_TYPEVENDOR_CODEC 1003 87 #define SND_SOC_TPLG_STREAM_PLAYBACK 0 88 #define SND_SOC_TPLG_STREAM_CAPTURE 1 89 #define SND_SOC_TPLG_TUPLE_TYPE_UUID 0 90 #define SND_SOC_TPLG_TUPLE_TYPE_STRING 1 91 #define SND_SOC_TPLG_TUPLE_TYPE_BOOL 2 92 #define SND_SOC_TPLG_TUPLE_TYPE_BYTE 3 93 #define SND_SOC_TPLG_TUPLE_TYPE_WORD 4 94 #define SND_SOC_TPLG_TUPLE_TYPE_SHORT 5 95 #define SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_RATES (1 << 0) 96 #define SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_CHANNELS (1 << 1) 97 #define SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_SAMPLEBITS (1 << 2) 98 #define SND_SOC_TPLG_DAI_CLK_GATE_UNDEFINED 0 99 #define SND_SOC_TPLG_DAI_CLK_GATE_GATED 1 100 #define SND_SOC_TPLG_DAI_CLK_GATE_CONT 2 101 #define SND_SOC_TPLG_MCLK_CO 0 102 #define SND_SOC_TPLG_MCLK_CI 1 103 #define SND_SOC_DAI_FORMAT_I2S 1 104 #define SND_SOC_DAI_FORMAT_RIGHT_J 2 105 #define SND_SOC_DAI_FORMAT_LEFT_J 3 106 #define SND_SOC_DAI_FORMAT_DSP_A 4 107 #define SND_SOC_DAI_FORMAT_DSP_B 5 108 #define SND_SOC_DAI_FORMAT_AC97 6 109 #define SND_SOC_DAI_FORMAT_PDM 7 110 #define SND_SOC_DAI_FORMAT_MSB SND_SOC_DAI_FORMAT_LEFT_J 111 #define SND_SOC_DAI_FORMAT_LSB SND_SOC_DAI_FORMAT_RIGHT_J 112 #define SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_RATES (1 << 0) 113 #define SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_CHANNELS (1 << 1) 114 #define SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_SAMPLEBITS (1 << 2) 115 #define SND_SOC_TPLG_LNK_FLGBIT_VOICE_WAKEUP (1 << 3) 116 #define SND_SOC_TPLG_BCLK_CM 0 117 #define SND_SOC_TPLG_BCLK_CS 1 118 #define SND_SOC_TPLG_FSYNC_CM 0 119 #define SND_SOC_TPLG_FSYNC_CS 1 120 struct snd_soc_tplg_hdr { 121 __le32 magic; 122 __le32 abi; 123 __le32 version; 124 __le32 type; 125 __le32 size; 126 __le32 vendor_type; 127 __le32 payload_size; 128 __le32 index; 129 __le32 count; 130 } __attribute__((packed)); 131 struct snd_soc_tplg_vendor_uuid_elem { 132 __le32 token; 133 char uuid[16]; 134 } __attribute__((packed)); 135 struct snd_soc_tplg_vendor_value_elem { 136 __le32 token; 137 __le32 value; 138 } __attribute__((packed)); 139 struct snd_soc_tplg_vendor_string_elem { 140 __le32 token; 141 char string[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 142 } __attribute__((packed)); 143 struct snd_soc_tplg_vendor_array { 144 __le32 size; 145 __le32 type; 146 __le32 num_elems; 147 union { 148 struct snd_soc_tplg_vendor_uuid_elem uuid[0]; 149 struct snd_soc_tplg_vendor_value_elem value[0]; 150 struct snd_soc_tplg_vendor_string_elem string[0]; 151 }; 152 } __attribute__((packed)); 153 struct snd_soc_tplg_private { 154 __le32 size; 155 union { 156 char data[0]; 157 struct snd_soc_tplg_vendor_array array[0]; 158 }; 159 } __attribute__((packed)); 160 struct snd_soc_tplg_tlv_dbscale { 161 __le32 min; 162 __le32 step; 163 __le32 mute; 164 } __attribute__((packed)); 165 struct snd_soc_tplg_ctl_tlv { 166 __le32 size; 167 __le32 type; 168 union { 169 __le32 data[SND_SOC_TPLG_TLV_SIZE]; 170 struct snd_soc_tplg_tlv_dbscale scale; 171 }; 172 } __attribute__((packed)); 173 struct snd_soc_tplg_channel { 174 __le32 size; 175 __le32 reg; 176 __le32 shift; 177 __le32 id; 178 } __attribute__((packed)); 179 struct snd_soc_tplg_io_ops { 180 __le32 get; 181 __le32 put; 182 __le32 info; 183 } __attribute__((packed)); 184 struct snd_soc_tplg_ctl_hdr { 185 __le32 size; 186 __le32 type; 187 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 188 __le32 access; 189 struct snd_soc_tplg_io_ops ops; 190 struct snd_soc_tplg_ctl_tlv tlv; 191 } __attribute__((packed)); 192 struct snd_soc_tplg_stream_caps { 193 __le32 size; 194 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 195 __le64 formats; 196 __le32 rates; 197 __le32 rate_min; 198 __le32 rate_max; 199 __le32 channels_min; 200 __le32 channels_max; 201 __le32 periods_min; 202 __le32 periods_max; 203 __le32 period_size_min; 204 __le32 period_size_max; 205 __le32 buffer_size_min; 206 __le32 buffer_size_max; 207 __le32 sig_bits; 208 } __attribute__((packed)); 209 struct snd_soc_tplg_stream { 210 __le32 size; 211 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 212 __le64 format; 213 __le32 rate; 214 __le32 period_bytes; 215 __le32 buffer_bytes; 216 __le32 channels; 217 } __attribute__((packed)); 218 struct snd_soc_tplg_hw_config { 219 __le32 size; 220 __le32 id; 221 __le32 fmt; 222 __u8 clock_gated; 223 __u8 invert_bclk; 224 __u8 invert_fsync; 225 __u8 bclk_master; 226 __u8 fsync_master; 227 __u8 mclk_direction; 228 __le16 reserved; 229 __le32 mclk_rate; 230 __le32 bclk_rate; 231 __le32 fsync_rate; 232 __le32 tdm_slots; 233 __le32 tdm_slot_width; 234 __le32 tx_slots; 235 __le32 rx_slots; 236 __le32 tx_channels; 237 __le32 tx_chanmap[SND_SOC_TPLG_MAX_CHAN]; 238 __le32 rx_channels; 239 __le32 rx_chanmap[SND_SOC_TPLG_MAX_CHAN]; 240 } __attribute__((packed)); 241 struct snd_soc_tplg_manifest { 242 __le32 size; 243 __le32 control_elems; 244 __le32 widget_elems; 245 __le32 graph_elems; 246 __le32 pcm_elems; 247 __le32 dai_link_elems; 248 __le32 dai_elems; 249 __le32 reserved[20]; 250 struct snd_soc_tplg_private priv; 251 } __attribute__((packed)); 252 struct snd_soc_tplg_mixer_control { 253 struct snd_soc_tplg_ctl_hdr hdr; 254 __le32 size; 255 __le32 min; 256 __le32 max; 257 __le32 platform_max; 258 __le32 invert; 259 __le32 num_channels; 260 struct snd_soc_tplg_channel channel[SND_SOC_TPLG_MAX_CHAN]; 261 struct snd_soc_tplg_private priv; 262 } __attribute__((packed)); 263 struct snd_soc_tplg_enum_control { 264 struct snd_soc_tplg_ctl_hdr hdr; 265 __le32 size; 266 __le32 num_channels; 267 struct snd_soc_tplg_channel channel[SND_SOC_TPLG_MAX_CHAN]; 268 __le32 items; 269 __le32 mask; 270 __le32 count; 271 char texts[SND_SOC_TPLG_NUM_TEXTS][SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 272 __le32 values[SND_SOC_TPLG_NUM_TEXTS * SNDRV_CTL_ELEM_ID_NAME_MAXLEN / 4]; 273 struct snd_soc_tplg_private priv; 274 } __attribute__((packed)); 275 struct snd_soc_tplg_bytes_control { 276 struct snd_soc_tplg_ctl_hdr hdr; 277 __le32 size; 278 __le32 max; 279 __le32 mask; 280 __le32 base; 281 __le32 num_regs; 282 struct snd_soc_tplg_io_ops ext_ops; 283 struct snd_soc_tplg_private priv; 284 } __attribute__((packed)); 285 struct snd_soc_tplg_dapm_graph_elem { 286 char sink[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 287 char control[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 288 char source[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 289 } __attribute__((packed)); 290 struct snd_soc_tplg_dapm_widget { 291 __le32 size; 292 __le32 id; 293 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 294 char sname[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 295 __le32 reg; 296 __le32 shift; 297 __le32 mask; 298 __le32 subseq; 299 __le32 invert; 300 __le32 ignore_suspend; 301 __le16 event_flags; 302 __le16 event_type; 303 __le32 num_kcontrols; 304 struct snd_soc_tplg_private priv; 305 } __attribute__((packed)); 306 struct snd_soc_tplg_pcm { 307 __le32 size; 308 char pcm_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 309 char dai_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 310 __le32 pcm_id; 311 __le32 dai_id; 312 __le32 playback; 313 __le32 capture; 314 __le32 compress; 315 struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; 316 __le32 num_streams; 317 struct snd_soc_tplg_stream_caps caps[2]; 318 __le32 flag_mask; 319 __le32 flags; 320 struct snd_soc_tplg_private priv; 321 } __attribute__((packed)); 322 struct snd_soc_tplg_link_config { 323 __le32 size; 324 __le32 id; 325 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 326 char stream_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 327 struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; 328 __le32 num_streams; 329 struct snd_soc_tplg_hw_config hw_config[SND_SOC_TPLG_HW_CONFIG_MAX]; 330 __le32 num_hw_configs; 331 __le32 default_hw_config_id; 332 __le32 flag_mask; 333 __le32 flags; 334 struct snd_soc_tplg_private priv; 335 } __attribute__((packed)); 336 struct snd_soc_tplg_dai { 337 __le32 size; 338 char dai_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 339 __le32 dai_id; 340 __le32 playback; 341 __le32 capture; 342 struct snd_soc_tplg_stream_caps caps[2]; 343 __le32 flag_mask; 344 __le32 flags; 345 struct snd_soc_tplg_private priv; 346 } __attribute__((packed)); 347 struct snd_soc_tplg_manifest_v4 { 348 __le32 size; 349 __le32 control_elems; 350 __le32 widget_elems; 351 __le32 graph_elems; 352 __le32 pcm_elems; 353 __le32 dai_link_elems; 354 struct snd_soc_tplg_private priv; 355 } __packed; 356 struct snd_soc_tplg_stream_caps_v4 { 357 __le32 size; 358 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 359 __le64 formats; 360 __le32 rates; 361 __le32 rate_min; 362 __le32 rate_max; 363 __le32 channels_min; 364 __le32 channels_max; 365 __le32 periods_min; 366 __le32 periods_max; 367 __le32 period_size_min; 368 __le32 period_size_max; 369 __le32 buffer_size_min; 370 __le32 buffer_size_max; 371 } __packed; 372 struct snd_soc_tplg_pcm_v4 { 373 __le32 size; 374 char pcm_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 375 char dai_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 376 __le32 pcm_id; 377 __le32 dai_id; 378 __le32 playback; 379 __le32 capture; 380 __le32 compress; 381 struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; 382 __le32 num_streams; 383 struct snd_soc_tplg_stream_caps_v4 caps[2]; 384 } __packed; 385 struct snd_soc_tplg_link_config_v4 { 386 __le32 size; 387 __le32 id; 388 struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; 389 __le32 num_streams; 390 } __packed; 391 #endif 392