blob: b0e47c163f5a2534c75477d33b9b24757e23b8d0 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
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 _UAPI__SOUND_ASOUND_H
20#define _UAPI__SOUND_ASOUND_H
Christopher Ferris106b3a82016-08-24 12:15:38 -070021#ifdef __linux__
Ben Cheng655a7c02013-10-16 16:09:24 -070022#include <linux/types.h>
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -070023#include <asm/byteorder.h>
Christopher Ferris106b3a82016-08-24 12:15:38 -070024#else
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -070025#include <endian.h>
Christopher Ferris106b3a82016-08-24 12:15:38 -070026#include <sys/ioctl.h>
27#endif
Christopher Ferris05d08e92016-02-04 13:16:38 -080028#include <stdlib.h>
Christopher Ferris24f97eb2019-05-20 12:58:13 -070029#include <time.h>
Christopher Ferris05d08e92016-02-04 13:16:38 -080030#define SNDRV_PROTOCOL_VERSION(major,minor,subminor) (((major) << 16) | ((minor) << 8) | (subminor))
Tao Baod7db5942015-01-28 10:07:51 -080031#define SNDRV_PROTOCOL_MAJOR(version) (((version) >> 16) & 0xffff)
32#define SNDRV_PROTOCOL_MINOR(version) (((version) >> 8) & 0xff)
33#define SNDRV_PROTOCOL_MICRO(version) ((version) & 0xff)
Christopher Ferris05d08e92016-02-04 13:16:38 -080034#define SNDRV_PROTOCOL_INCOMPATIBLE(kversion,uversion) (SNDRV_PROTOCOL_MAJOR(kversion) != SNDRV_PROTOCOL_MAJOR(uversion) || (SNDRV_PROTOCOL_MAJOR(kversion) == SNDRV_PROTOCOL_MAJOR(uversion) && SNDRV_PROTOCOL_MINOR(kversion) != SNDRV_PROTOCOL_MINOR(uversion)))
Christopher Ferris1ed55342022-03-22 16:06:25 -070035#define AES_IEC958_STATUS_SIZE 24
Ben Cheng655a7c02013-10-16 16:09:24 -070036struct snd_aes_iec958 {
Christopher Ferris1ed55342022-03-22 16:06:25 -070037 unsigned char status[AES_IEC958_STATUS_SIZE];
Tao Baod7db5942015-01-28 10:07:51 -080038 unsigned char subcode[147];
Christopher Ferris05d08e92016-02-04 13:16:38 -080039 unsigned char pad;
Tao Baod7db5942015-01-28 10:07:51 -080040 unsigned char dig_subframe[4];
Ben Cheng655a7c02013-10-16 16:09:24 -070041};
42struct snd_cea_861_aud_if {
Christopher Ferris05d08e92016-02-04 13:16:38 -080043 unsigned char db1_ct_cc;
Tao Baod7db5942015-01-28 10:07:51 -080044 unsigned char db2_sf_ss;
45 unsigned char db3;
46 unsigned char db4_ca;
Christopher Ferris05d08e92016-02-04 13:16:38 -080047 unsigned char db5_dminh_lsv;
Ben Cheng655a7c02013-10-16 16:09:24 -070048};
49#define SNDRV_HWDEP_VERSION SNDRV_PROTOCOL_VERSION(1, 0, 1)
50enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -080051 SNDRV_HWDEP_IFACE_OPL2 = 0,
Tao Baod7db5942015-01-28 10:07:51 -080052 SNDRV_HWDEP_IFACE_OPL3,
53 SNDRV_HWDEP_IFACE_OPL4,
54 SNDRV_HWDEP_IFACE_SB16CSP,
Christopher Ferris05d08e92016-02-04 13:16:38 -080055 SNDRV_HWDEP_IFACE_EMU10K1,
Tao Baod7db5942015-01-28 10:07:51 -080056 SNDRV_HWDEP_IFACE_YSS225,
57 SNDRV_HWDEP_IFACE_ICS2115,
58 SNDRV_HWDEP_IFACE_SSCAPE,
Christopher Ferris05d08e92016-02-04 13:16:38 -080059 SNDRV_HWDEP_IFACE_VX,
Tao Baod7db5942015-01-28 10:07:51 -080060 SNDRV_HWDEP_IFACE_MIXART,
61 SNDRV_HWDEP_IFACE_USX2Y,
62 SNDRV_HWDEP_IFACE_EMUX_WAVETABLE,
Christopher Ferris05d08e92016-02-04 13:16:38 -080063 SNDRV_HWDEP_IFACE_BLUETOOTH,
Tao Baod7db5942015-01-28 10:07:51 -080064 SNDRV_HWDEP_IFACE_USX2Y_PCM,
65 SNDRV_HWDEP_IFACE_PCXHR,
66 SNDRV_HWDEP_IFACE_SB_RC,
Christopher Ferris05d08e92016-02-04 13:16:38 -080067 SNDRV_HWDEP_IFACE_HDA,
Tao Baod7db5942015-01-28 10:07:51 -080068 SNDRV_HWDEP_IFACE_USB_STREAM,
69 SNDRV_HWDEP_IFACE_FW_DICE,
70 SNDRV_HWDEP_IFACE_FW_FIREWORKS,
Christopher Ferris05d08e92016-02-04 13:16:38 -080071 SNDRV_HWDEP_IFACE_FW_BEBOB,
72 SNDRV_HWDEP_IFACE_FW_OXFW,
73 SNDRV_HWDEP_IFACE_FW_DIGI00X,
74 SNDRV_HWDEP_IFACE_FW_TASCAM,
Christopher Ferris6a9755d2017-01-13 14:09:31 -080075 SNDRV_HWDEP_IFACE_LINE6,
Christopher Ferris525ce912017-07-26 13:12:53 -070076 SNDRV_HWDEP_IFACE_FW_MOTU,
77 SNDRV_HWDEP_IFACE_FW_FIREFACE,
78 SNDRV_HWDEP_IFACE_LAST = SNDRV_HWDEP_IFACE_FW_FIREFACE
Christopher Ferrisba8d4f42014-09-03 19:56:49 -070079};
Christopher Ferris38062f92014-07-09 15:33:25 -070080struct snd_hwdep_info {
Christopher Ferris6a9755d2017-01-13 14:09:31 -080081 unsigned int device;
Tao Baod7db5942015-01-28 10:07:51 -080082 int card;
83 unsigned char id[64];
84 unsigned char name[80];
Christopher Ferris6a9755d2017-01-13 14:09:31 -080085 int iface;
Tao Baod7db5942015-01-28 10:07:51 -080086 unsigned char reserved[64];
Ben Cheng655a7c02013-10-16 16:09:24 -070087};
Christopher Ferris38062f92014-07-09 15:33:25 -070088struct snd_hwdep_dsp_status {
Christopher Ferris6a9755d2017-01-13 14:09:31 -080089 unsigned int version;
Tao Baod7db5942015-01-28 10:07:51 -080090 unsigned char id[32];
91 unsigned int num_dsps;
92 unsigned int dsp_loaded;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080093 unsigned int chip_ready;
Tao Baod7db5942015-01-28 10:07:51 -080094 unsigned char reserved[16];
Ben Cheng655a7c02013-10-16 16:09:24 -070095};
Christopher Ferris38062f92014-07-09 15:33:25 -070096struct snd_hwdep_dsp_image {
Christopher Ferris6a9755d2017-01-13 14:09:31 -080097 unsigned int index;
Tao Baod7db5942015-01-28 10:07:51 -080098 unsigned char name[64];
99 unsigned char __user * image;
100 size_t length;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800101 unsigned long driver_data;
Ben Cheng655a7c02013-10-16 16:09:24 -0700102};
Tao Baod7db5942015-01-28 10:07:51 -0800103#define SNDRV_HWDEP_IOCTL_PVERSION _IOR('H', 0x00, int)
104#define SNDRV_HWDEP_IOCTL_INFO _IOR('H', 0x01, struct snd_hwdep_info)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800105#define SNDRV_HWDEP_IOCTL_DSP_STATUS _IOR('H', 0x02, struct snd_hwdep_dsp_status)
Ben Cheng655a7c02013-10-16 16:09:24 -0700106#define SNDRV_HWDEP_IOCTL_DSP_LOAD _IOW('H', 0x03, struct snd_hwdep_dsp_image)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700107#define SNDRV_PCM_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 15)
Christopher Ferris38062f92014-07-09 15:33:25 -0700108typedef unsigned long snd_pcm_uframes_t;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800109typedef signed long snd_pcm_sframes_t;
Ben Cheng655a7c02013-10-16 16:09:24 -0700110enum {
Tao Baod7db5942015-01-28 10:07:51 -0800111 SNDRV_PCM_CLASS_GENERIC = 0,
112 SNDRV_PCM_CLASS_MULTI,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800113 SNDRV_PCM_CLASS_MODEM,
Tao Baod7db5942015-01-28 10:07:51 -0800114 SNDRV_PCM_CLASS_DIGITIZER,
115 SNDRV_PCM_CLASS_LAST = SNDRV_PCM_CLASS_DIGITIZER,
Christopher Ferris38062f92014-07-09 15:33:25 -0700116};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800117enum {
Tao Baod7db5942015-01-28 10:07:51 -0800118 SNDRV_PCM_SUBCLASS_GENERIC_MIX = 0,
119 SNDRV_PCM_SUBCLASS_MULTI_MIX,
120 SNDRV_PCM_SUBCLASS_LAST = SNDRV_PCM_SUBCLASS_MULTI_MIX,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800121};
Ben Cheng655a7c02013-10-16 16:09:24 -0700122enum {
Tao Baod7db5942015-01-28 10:07:51 -0800123 SNDRV_PCM_STREAM_PLAYBACK = 0,
124 SNDRV_PCM_STREAM_CAPTURE,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800125 SNDRV_PCM_STREAM_LAST = SNDRV_PCM_STREAM_CAPTURE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700126};
127typedef int __bitwise snd_pcm_access_t;
Christopher Ferris38062f92014-07-09 15:33:25 -0700128#define SNDRV_PCM_ACCESS_MMAP_INTERLEAVED ((__force snd_pcm_access_t) 0)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800129#define SNDRV_PCM_ACCESS_MMAP_NONINTERLEAVED ((__force snd_pcm_access_t) 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700130#define SNDRV_PCM_ACCESS_MMAP_COMPLEX ((__force snd_pcm_access_t) 2)
131#define SNDRV_PCM_ACCESS_RW_INTERLEAVED ((__force snd_pcm_access_t) 3)
Christopher Ferris38062f92014-07-09 15:33:25 -0700132#define SNDRV_PCM_ACCESS_RW_NONINTERLEAVED ((__force snd_pcm_access_t) 4)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800133#define SNDRV_PCM_ACCESS_LAST SNDRV_PCM_ACCESS_RW_NONINTERLEAVED
Ben Cheng655a7c02013-10-16 16:09:24 -0700134typedef int __bitwise snd_pcm_format_t;
135#define SNDRV_PCM_FORMAT_S8 ((__force snd_pcm_format_t) 0)
Christopher Ferris38062f92014-07-09 15:33:25 -0700136#define SNDRV_PCM_FORMAT_U8 ((__force snd_pcm_format_t) 1)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800137#define SNDRV_PCM_FORMAT_S16_LE ((__force snd_pcm_format_t) 2)
Ben Cheng655a7c02013-10-16 16:09:24 -0700138#define SNDRV_PCM_FORMAT_S16_BE ((__force snd_pcm_format_t) 3)
139#define SNDRV_PCM_FORMAT_U16_LE ((__force snd_pcm_format_t) 4)
Christopher Ferris38062f92014-07-09 15:33:25 -0700140#define SNDRV_PCM_FORMAT_U16_BE ((__force snd_pcm_format_t) 5)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800141#define SNDRV_PCM_FORMAT_S24_LE ((__force snd_pcm_format_t) 6)
Ben Cheng655a7c02013-10-16 16:09:24 -0700142#define SNDRV_PCM_FORMAT_S24_BE ((__force snd_pcm_format_t) 7)
143#define SNDRV_PCM_FORMAT_U24_LE ((__force snd_pcm_format_t) 8)
Christopher Ferris38062f92014-07-09 15:33:25 -0700144#define SNDRV_PCM_FORMAT_U24_BE ((__force snd_pcm_format_t) 9)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800145#define SNDRV_PCM_FORMAT_S32_LE ((__force snd_pcm_format_t) 10)
Ben Cheng655a7c02013-10-16 16:09:24 -0700146#define SNDRV_PCM_FORMAT_S32_BE ((__force snd_pcm_format_t) 11)
147#define SNDRV_PCM_FORMAT_U32_LE ((__force snd_pcm_format_t) 12)
Christopher Ferris38062f92014-07-09 15:33:25 -0700148#define SNDRV_PCM_FORMAT_U32_BE ((__force snd_pcm_format_t) 13)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800149#define SNDRV_PCM_FORMAT_FLOAT_LE ((__force snd_pcm_format_t) 14)
Ben Cheng655a7c02013-10-16 16:09:24 -0700150#define SNDRV_PCM_FORMAT_FLOAT_BE ((__force snd_pcm_format_t) 15)
151#define SNDRV_PCM_FORMAT_FLOAT64_LE ((__force snd_pcm_format_t) 16)
Christopher Ferris38062f92014-07-09 15:33:25 -0700152#define SNDRV_PCM_FORMAT_FLOAT64_BE ((__force snd_pcm_format_t) 17)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800153#define SNDRV_PCM_FORMAT_IEC958_SUBFRAME_LE ((__force snd_pcm_format_t) 18)
Ben Cheng655a7c02013-10-16 16:09:24 -0700154#define SNDRV_PCM_FORMAT_IEC958_SUBFRAME_BE ((__force snd_pcm_format_t) 19)
155#define SNDRV_PCM_FORMAT_MU_LAW ((__force snd_pcm_format_t) 20)
Christopher Ferris38062f92014-07-09 15:33:25 -0700156#define SNDRV_PCM_FORMAT_A_LAW ((__force snd_pcm_format_t) 21)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800157#define SNDRV_PCM_FORMAT_IMA_ADPCM ((__force snd_pcm_format_t) 22)
Ben Cheng655a7c02013-10-16 16:09:24 -0700158#define SNDRV_PCM_FORMAT_MPEG ((__force snd_pcm_format_t) 23)
159#define SNDRV_PCM_FORMAT_GSM ((__force snd_pcm_format_t) 24)
Christopher Ferris76a1d452018-06-27 14:12:29 -0700160#define SNDRV_PCM_FORMAT_S20_LE ((__force snd_pcm_format_t) 25)
161#define SNDRV_PCM_FORMAT_S20_BE ((__force snd_pcm_format_t) 26)
162#define SNDRV_PCM_FORMAT_U20_LE ((__force snd_pcm_format_t) 27)
163#define SNDRV_PCM_FORMAT_U20_BE ((__force snd_pcm_format_t) 28)
Christopher Ferris38062f92014-07-09 15:33:25 -0700164#define SNDRV_PCM_FORMAT_SPECIAL ((__force snd_pcm_format_t) 31)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800165#define SNDRV_PCM_FORMAT_S24_3LE ((__force snd_pcm_format_t) 32)
Ben Cheng655a7c02013-10-16 16:09:24 -0700166#define SNDRV_PCM_FORMAT_S24_3BE ((__force snd_pcm_format_t) 33)
167#define SNDRV_PCM_FORMAT_U24_3LE ((__force snd_pcm_format_t) 34)
Christopher Ferris38062f92014-07-09 15:33:25 -0700168#define SNDRV_PCM_FORMAT_U24_3BE ((__force snd_pcm_format_t) 35)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800169#define SNDRV_PCM_FORMAT_S20_3LE ((__force snd_pcm_format_t) 36)
Ben Cheng655a7c02013-10-16 16:09:24 -0700170#define SNDRV_PCM_FORMAT_S20_3BE ((__force snd_pcm_format_t) 37)
171#define SNDRV_PCM_FORMAT_U20_3LE ((__force snd_pcm_format_t) 38)
Christopher Ferris38062f92014-07-09 15:33:25 -0700172#define SNDRV_PCM_FORMAT_U20_3BE ((__force snd_pcm_format_t) 39)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800173#define SNDRV_PCM_FORMAT_S18_3LE ((__force snd_pcm_format_t) 40)
Ben Cheng655a7c02013-10-16 16:09:24 -0700174#define SNDRV_PCM_FORMAT_S18_3BE ((__force snd_pcm_format_t) 41)
175#define SNDRV_PCM_FORMAT_U18_3LE ((__force snd_pcm_format_t) 42)
Christopher Ferris38062f92014-07-09 15:33:25 -0700176#define SNDRV_PCM_FORMAT_U18_3BE ((__force snd_pcm_format_t) 43)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800177#define SNDRV_PCM_FORMAT_G723_24 ((__force snd_pcm_format_t) 44)
Ben Cheng655a7c02013-10-16 16:09:24 -0700178#define SNDRV_PCM_FORMAT_G723_24_1B ((__force snd_pcm_format_t) 45)
179#define SNDRV_PCM_FORMAT_G723_40 ((__force snd_pcm_format_t) 46)
Christopher Ferris38062f92014-07-09 15:33:25 -0700180#define SNDRV_PCM_FORMAT_G723_40_1B ((__force snd_pcm_format_t) 47)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800181#define SNDRV_PCM_FORMAT_DSD_U8 ((__force snd_pcm_format_t) 48)
Ben Cheng655a7c02013-10-16 16:09:24 -0700182#define SNDRV_PCM_FORMAT_DSD_U16_LE ((__force snd_pcm_format_t) 49)
Christopher Ferris82d75042015-01-26 10:57:07 -0800183#define SNDRV_PCM_FORMAT_DSD_U32_LE ((__force snd_pcm_format_t) 50)
184#define SNDRV_PCM_FORMAT_DSD_U16_BE ((__force snd_pcm_format_t) 51)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800185#define SNDRV_PCM_FORMAT_DSD_U32_BE ((__force snd_pcm_format_t) 52)
Christopher Ferris82d75042015-01-26 10:57:07 -0800186#define SNDRV_PCM_FORMAT_LAST SNDRV_PCM_FORMAT_DSD_U32_BE
Christopher Ferris76a1d452018-06-27 14:12:29 -0700187#define SNDRV_PCM_FORMAT_FIRST SNDRV_PCM_FORMAT_S8
Christopher Ferris38062f92014-07-09 15:33:25 -0700188#ifdef SNDRV_LITTLE_ENDIAN
Ben Cheng655a7c02013-10-16 16:09:24 -0700189#define SNDRV_PCM_FORMAT_S16 SNDRV_PCM_FORMAT_S16_LE
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800190#define SNDRV_PCM_FORMAT_U16 SNDRV_PCM_FORMAT_U16_LE
Ben Cheng655a7c02013-10-16 16:09:24 -0700191#define SNDRV_PCM_FORMAT_S24 SNDRV_PCM_FORMAT_S24_LE
Christopher Ferris38062f92014-07-09 15:33:25 -0700192#define SNDRV_PCM_FORMAT_U24 SNDRV_PCM_FORMAT_U24_LE
Ben Cheng655a7c02013-10-16 16:09:24 -0700193#define SNDRV_PCM_FORMAT_S32 SNDRV_PCM_FORMAT_S32_LE
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800194#define SNDRV_PCM_FORMAT_U32 SNDRV_PCM_FORMAT_U32_LE
Ben Cheng655a7c02013-10-16 16:09:24 -0700195#define SNDRV_PCM_FORMAT_FLOAT SNDRV_PCM_FORMAT_FLOAT_LE
Christopher Ferris38062f92014-07-09 15:33:25 -0700196#define SNDRV_PCM_FORMAT_FLOAT64 SNDRV_PCM_FORMAT_FLOAT64_LE
Ben Cheng655a7c02013-10-16 16:09:24 -0700197#define SNDRV_PCM_FORMAT_IEC958_SUBFRAME SNDRV_PCM_FORMAT_IEC958_SUBFRAME_LE
Christopher Ferris76a1d452018-06-27 14:12:29 -0700198#define SNDRV_PCM_FORMAT_S20 SNDRV_PCM_FORMAT_S20_LE
199#define SNDRV_PCM_FORMAT_U20 SNDRV_PCM_FORMAT_U20_LE
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800200#endif
Ben Cheng655a7c02013-10-16 16:09:24 -0700201#ifdef SNDRV_BIG_ENDIAN
Christopher Ferris38062f92014-07-09 15:33:25 -0700202#define SNDRV_PCM_FORMAT_S16 SNDRV_PCM_FORMAT_S16_BE
Ben Cheng655a7c02013-10-16 16:09:24 -0700203#define SNDRV_PCM_FORMAT_U16 SNDRV_PCM_FORMAT_U16_BE
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800204#define SNDRV_PCM_FORMAT_S24 SNDRV_PCM_FORMAT_S24_BE
Ben Cheng655a7c02013-10-16 16:09:24 -0700205#define SNDRV_PCM_FORMAT_U24 SNDRV_PCM_FORMAT_U24_BE
Christopher Ferris38062f92014-07-09 15:33:25 -0700206#define SNDRV_PCM_FORMAT_S32 SNDRV_PCM_FORMAT_S32_BE
Ben Cheng655a7c02013-10-16 16:09:24 -0700207#define SNDRV_PCM_FORMAT_U32 SNDRV_PCM_FORMAT_U32_BE
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800208#define SNDRV_PCM_FORMAT_FLOAT SNDRV_PCM_FORMAT_FLOAT_BE
Ben Cheng655a7c02013-10-16 16:09:24 -0700209#define SNDRV_PCM_FORMAT_FLOAT64 SNDRV_PCM_FORMAT_FLOAT64_BE
Christopher Ferris38062f92014-07-09 15:33:25 -0700210#define SNDRV_PCM_FORMAT_IEC958_SUBFRAME SNDRV_PCM_FORMAT_IEC958_SUBFRAME_BE
Christopher Ferris76a1d452018-06-27 14:12:29 -0700211#define SNDRV_PCM_FORMAT_S20 SNDRV_PCM_FORMAT_S20_BE
212#define SNDRV_PCM_FORMAT_U20 SNDRV_PCM_FORMAT_U20_BE
Ben Cheng655a7c02013-10-16 16:09:24 -0700213#endif
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800214typedef int __bitwise snd_pcm_subformat_t;
Ben Cheng655a7c02013-10-16 16:09:24 -0700215#define SNDRV_PCM_SUBFORMAT_STD ((__force snd_pcm_subformat_t) 0)
Christopher Ferris38062f92014-07-09 15:33:25 -0700216#define SNDRV_PCM_SUBFORMAT_LAST SNDRV_PCM_SUBFORMAT_STD
Ben Cheng655a7c02013-10-16 16:09:24 -0700217#define SNDRV_PCM_INFO_MMAP 0x00000001
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800218#define SNDRV_PCM_INFO_MMAP_VALID 0x00000002
Ben Cheng655a7c02013-10-16 16:09:24 -0700219#define SNDRV_PCM_INFO_DOUBLE 0x00000004
Christopher Ferris38062f92014-07-09 15:33:25 -0700220#define SNDRV_PCM_INFO_BATCH 0x00000010
Christopher Ferris1308ad32017-11-14 17:32:13 -0800221#define SNDRV_PCM_INFO_SYNC_APPLPTR 0x00000020
Ben Cheng655a7c02013-10-16 16:09:24 -0700222#define SNDRV_PCM_INFO_INTERLEAVED 0x00000100
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800223#define SNDRV_PCM_INFO_NONINTERLEAVED 0x00000200
Ben Cheng655a7c02013-10-16 16:09:24 -0700224#define SNDRV_PCM_INFO_COMPLEX 0x00000400
Christopher Ferris38062f92014-07-09 15:33:25 -0700225#define SNDRV_PCM_INFO_BLOCK_TRANSFER 0x00010000
Ben Cheng655a7c02013-10-16 16:09:24 -0700226#define SNDRV_PCM_INFO_OVERRANGE 0x00020000
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800227#define SNDRV_PCM_INFO_RESUME 0x00040000
Ben Cheng655a7c02013-10-16 16:09:24 -0700228#define SNDRV_PCM_INFO_PAUSE 0x00080000
Christopher Ferris38062f92014-07-09 15:33:25 -0700229#define SNDRV_PCM_INFO_HALF_DUPLEX 0x00100000
Ben Cheng655a7c02013-10-16 16:09:24 -0700230#define SNDRV_PCM_INFO_JOINT_DUPLEX 0x00200000
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800231#define SNDRV_PCM_INFO_SYNC_START 0x00400000
Ben Cheng655a7c02013-10-16 16:09:24 -0700232#define SNDRV_PCM_INFO_NO_PERIOD_WAKEUP 0x00800000
Christopher Ferris38062f92014-07-09 15:33:25 -0700233#define SNDRV_PCM_INFO_HAS_WALL_CLOCK 0x01000000
Christopher Ferris05d08e92016-02-04 13:16:38 -0800234#define SNDRV_PCM_INFO_HAS_LINK_ATIME 0x01000000
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800235#define SNDRV_PCM_INFO_HAS_LINK_ABSOLUTE_ATIME 0x02000000
Christopher Ferris05d08e92016-02-04 13:16:38 -0800236#define SNDRV_PCM_INFO_HAS_LINK_ESTIMATED_ATIME 0x04000000
237#define SNDRV_PCM_INFO_HAS_LINK_SYNCHRONIZED_ATIME 0x08000000
Christopher Ferris2abfa9e2021-11-01 16:26:06 -0700238#define SNDRV_PCM_INFO_EXPLICIT_SYNC 0x10000000
Christopher Ferris1ed55342022-03-22 16:06:25 -0700239#define SNDRV_PCM_INFO_NO_REWINDS 0x20000000
Christopher Ferris05d08e92016-02-04 13:16:38 -0800240#define SNDRV_PCM_INFO_DRAIN_TRIGGER 0x40000000
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800241#define SNDRV_PCM_INFO_FIFO_IN_FRAMES 0x80000000
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700242#if __BITS_PER_LONG == 32 && defined(__USE_TIME_BITS64)
243#define __SND_STRUCT_TIME64
244#endif
Christopher Ferris05d08e92016-02-04 13:16:38 -0800245typedef int __bitwise snd_pcm_state_t;
Ben Cheng655a7c02013-10-16 16:09:24 -0700246#define SNDRV_PCM_STATE_OPEN ((__force snd_pcm_state_t) 0)
Christopher Ferris38062f92014-07-09 15:33:25 -0700247#define SNDRV_PCM_STATE_SETUP ((__force snd_pcm_state_t) 1)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800248#define SNDRV_PCM_STATE_PREPARED ((__force snd_pcm_state_t) 2)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800249#define SNDRV_PCM_STATE_RUNNING ((__force snd_pcm_state_t) 3)
Ben Cheng655a7c02013-10-16 16:09:24 -0700250#define SNDRV_PCM_STATE_XRUN ((__force snd_pcm_state_t) 4)
Christopher Ferris38062f92014-07-09 15:33:25 -0700251#define SNDRV_PCM_STATE_DRAINING ((__force snd_pcm_state_t) 5)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800252#define SNDRV_PCM_STATE_PAUSED ((__force snd_pcm_state_t) 6)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800253#define SNDRV_PCM_STATE_SUSPENDED ((__force snd_pcm_state_t) 7)
Ben Cheng655a7c02013-10-16 16:09:24 -0700254#define SNDRV_PCM_STATE_DISCONNECTED ((__force snd_pcm_state_t) 8)
Christopher Ferris38062f92014-07-09 15:33:25 -0700255#define SNDRV_PCM_STATE_LAST SNDRV_PCM_STATE_DISCONNECTED
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800256enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800257 SNDRV_PCM_MMAP_OFFSET_DATA = 0x00000000,
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700258 SNDRV_PCM_MMAP_OFFSET_STATUS_OLD = 0x80000000,
259 SNDRV_PCM_MMAP_OFFSET_CONTROL_OLD = 0x81000000,
260 SNDRV_PCM_MMAP_OFFSET_STATUS_NEW = 0x82000000,
261 SNDRV_PCM_MMAP_OFFSET_CONTROL_NEW = 0x83000000,
262#ifdef __SND_STRUCT_TIME64
263 SNDRV_PCM_MMAP_OFFSET_STATUS = SNDRV_PCM_MMAP_OFFSET_STATUS_NEW,
264 SNDRV_PCM_MMAP_OFFSET_CONTROL = SNDRV_PCM_MMAP_OFFSET_CONTROL_NEW,
265#else
266 SNDRV_PCM_MMAP_OFFSET_STATUS = SNDRV_PCM_MMAP_OFFSET_STATUS_OLD,
267 SNDRV_PCM_MMAP_OFFSET_CONTROL = SNDRV_PCM_MMAP_OFFSET_CONTROL_OLD,
268#endif
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800269};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800270union snd_pcm_sync_id {
Tao Baod7db5942015-01-28 10:07:51 -0800271 unsigned char id[16];
272 unsigned short id16[8];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800273 unsigned int id32[4];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800274};
Ben Cheng655a7c02013-10-16 16:09:24 -0700275struct snd_pcm_info {
Tao Baod7db5942015-01-28 10:07:51 -0800276 unsigned int device;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800277 unsigned int subdevice;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800278 int stream;
Tao Baod7db5942015-01-28 10:07:51 -0800279 int card;
280 unsigned char id[64];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800281 unsigned char name[80];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800282 unsigned char subname[32];
Tao Baod7db5942015-01-28 10:07:51 -0800283 int dev_class;
284 int dev_subclass;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800285 unsigned int subdevices_count;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800286 unsigned int subdevices_avail;
Tao Baod7db5942015-01-28 10:07:51 -0800287 union snd_pcm_sync_id sync;
288 unsigned char reserved[64];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800289};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800290typedef int snd_pcm_hw_param_t;
Ben Cheng655a7c02013-10-16 16:09:24 -0700291#define SNDRV_PCM_HW_PARAM_ACCESS 0
Christopher Ferris38062f92014-07-09 15:33:25 -0700292#define SNDRV_PCM_HW_PARAM_FORMAT 1
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800293#define SNDRV_PCM_HW_PARAM_SUBFORMAT 2
Christopher Ferris05d08e92016-02-04 13:16:38 -0800294#define SNDRV_PCM_HW_PARAM_FIRST_MASK SNDRV_PCM_HW_PARAM_ACCESS
Ben Cheng655a7c02013-10-16 16:09:24 -0700295#define SNDRV_PCM_HW_PARAM_LAST_MASK SNDRV_PCM_HW_PARAM_SUBFORMAT
Christopher Ferris38062f92014-07-09 15:33:25 -0700296#define SNDRV_PCM_HW_PARAM_SAMPLE_BITS 8
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800297#define SNDRV_PCM_HW_PARAM_FRAME_BITS 9
Christopher Ferris05d08e92016-02-04 13:16:38 -0800298#define SNDRV_PCM_HW_PARAM_CHANNELS 10
Ben Cheng655a7c02013-10-16 16:09:24 -0700299#define SNDRV_PCM_HW_PARAM_RATE 11
Christopher Ferris38062f92014-07-09 15:33:25 -0700300#define SNDRV_PCM_HW_PARAM_PERIOD_TIME 12
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800301#define SNDRV_PCM_HW_PARAM_PERIOD_SIZE 13
Christopher Ferris05d08e92016-02-04 13:16:38 -0800302#define SNDRV_PCM_HW_PARAM_PERIOD_BYTES 14
Ben Cheng655a7c02013-10-16 16:09:24 -0700303#define SNDRV_PCM_HW_PARAM_PERIODS 15
Christopher Ferris38062f92014-07-09 15:33:25 -0700304#define SNDRV_PCM_HW_PARAM_BUFFER_TIME 16
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800305#define SNDRV_PCM_HW_PARAM_BUFFER_SIZE 17
Christopher Ferris05d08e92016-02-04 13:16:38 -0800306#define SNDRV_PCM_HW_PARAM_BUFFER_BYTES 18
Ben Cheng655a7c02013-10-16 16:09:24 -0700307#define SNDRV_PCM_HW_PARAM_TICK_TIME 19
Christopher Ferris38062f92014-07-09 15:33:25 -0700308#define SNDRV_PCM_HW_PARAM_FIRST_INTERVAL SNDRV_PCM_HW_PARAM_SAMPLE_BITS
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800309#define SNDRV_PCM_HW_PARAM_LAST_INTERVAL SNDRV_PCM_HW_PARAM_TICK_TIME
Christopher Ferris05d08e92016-02-04 13:16:38 -0800310#define SNDRV_PCM_HW_PARAMS_NORESAMPLE (1 << 0)
Tao Baod7db5942015-01-28 10:07:51 -0800311#define SNDRV_PCM_HW_PARAMS_EXPORT_BUFFER (1 << 1)
312#define SNDRV_PCM_HW_PARAMS_NO_PERIOD_WAKEUP (1 << 2)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800313struct snd_interval {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800314 unsigned int min, max;
Tao Baod7db5942015-01-28 10:07:51 -0800315 unsigned int openmin : 1, openmax : 1, integer : 1, empty : 1;
Ben Cheng655a7c02013-10-16 16:09:24 -0700316};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800317#define SNDRV_MASK_MAX 256
Christopher Ferris05d08e92016-02-04 13:16:38 -0800318struct snd_mask {
Tao Baod7db5942015-01-28 10:07:51 -0800319 __u32 bits[(SNDRV_MASK_MAX + 31) / 32];
Ben Cheng655a7c02013-10-16 16:09:24 -0700320};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800321struct snd_pcm_hw_params {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800322 unsigned int flags;
Tao Baod7db5942015-01-28 10:07:51 -0800323 struct snd_mask masks[SNDRV_PCM_HW_PARAM_LAST_MASK - SNDRV_PCM_HW_PARAM_FIRST_MASK + 1];
324 struct snd_mask mres[5];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800325 struct snd_interval intervals[SNDRV_PCM_HW_PARAM_LAST_INTERVAL - SNDRV_PCM_HW_PARAM_FIRST_INTERVAL + 1];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800326 struct snd_interval ires[9];
Tao Baod7db5942015-01-28 10:07:51 -0800327 unsigned int rmask;
328 unsigned int cmask;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800329 unsigned int info;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800330 unsigned int msbits;
Tao Baod7db5942015-01-28 10:07:51 -0800331 unsigned int rate_num;
332 unsigned int rate_den;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800333 snd_pcm_uframes_t fifo_size;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800334 unsigned char reserved[64];
Christopher Ferris38062f92014-07-09 15:33:25 -0700335};
Ben Cheng655a7c02013-10-16 16:09:24 -0700336enum {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800337 SNDRV_PCM_TSTAMP_NONE = 0,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800338 SNDRV_PCM_TSTAMP_ENABLE,
Tao Baod7db5942015-01-28 10:07:51 -0800339 SNDRV_PCM_TSTAMP_LAST = SNDRV_PCM_TSTAMP_ENABLE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700340};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800341struct snd_pcm_sw_params {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800342 int tstamp_mode;
Tao Baod7db5942015-01-28 10:07:51 -0800343 unsigned int period_step;
344 unsigned int sleep_min;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800345 snd_pcm_uframes_t avail_min;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800346 snd_pcm_uframes_t xfer_align;
Tao Baod7db5942015-01-28 10:07:51 -0800347 snd_pcm_uframes_t start_threshold;
348 snd_pcm_uframes_t stop_threshold;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800349 snd_pcm_uframes_t silence_threshold;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800350 snd_pcm_uframes_t silence_size;
Tao Baod7db5942015-01-28 10:07:51 -0800351 snd_pcm_uframes_t boundary;
352 unsigned int proto;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800353 unsigned int tstamp_type;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800354 unsigned char reserved[56];
Ben Cheng655a7c02013-10-16 16:09:24 -0700355};
356struct snd_pcm_channel_info {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800357 unsigned int channel;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800358 __kernel_off_t offset;
Tao Baod7db5942015-01-28 10:07:51 -0800359 unsigned int first;
360 unsigned int step;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800361};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800362enum {
363 SNDRV_PCM_AUDIO_TSTAMP_TYPE_COMPAT = 0,
364 SNDRV_PCM_AUDIO_TSTAMP_TYPE_DEFAULT = 1,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800365 SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK = 2,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800366 SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK_ABSOLUTE = 3,
367 SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK_ESTIMATED = 4,
368 SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK_SYNCHRONIZED = 5,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800369 SNDRV_PCM_AUDIO_TSTAMP_TYPE_LAST = SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK_SYNCHRONIZED
Christopher Ferris05d08e92016-02-04 13:16:38 -0800370};
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700371typedef struct {
372 unsigned char pad[sizeof(time_t) - sizeof(int)];
373} __time_pad;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800374struct snd_pcm_status {
Tao Baod7db5942015-01-28 10:07:51 -0800375 snd_pcm_state_t state;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700376 __time_pad pad1;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800377 struct timespec trigger_tstamp;
Tao Baod7db5942015-01-28 10:07:51 -0800378 struct timespec tstamp;
379 snd_pcm_uframes_t appl_ptr;
Tao Baod7db5942015-01-28 10:07:51 -0800380 snd_pcm_uframes_t hw_ptr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800381 snd_pcm_sframes_t delay;
Tao Baod7db5942015-01-28 10:07:51 -0800382 snd_pcm_uframes_t avail;
383 snd_pcm_uframes_t avail_max;
Tao Baod7db5942015-01-28 10:07:51 -0800384 snd_pcm_uframes_t overrange;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800385 snd_pcm_state_t suspended_state;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800386 __u32 audio_tstamp_data;
387 struct timespec audio_tstamp;
388 struct timespec driver_tstamp;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800389 __u32 audio_tstamp_accuracy;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800390 unsigned char reserved[52 - 2 * sizeof(struct timespec)];
Ben Cheng655a7c02013-10-16 16:09:24 -0700391};
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700392#ifdef __SND_STRUCT_TIME64
393#define __snd_pcm_mmap_status64 snd_pcm_mmap_status
394#define __snd_pcm_mmap_control64 snd_pcm_mmap_control
395#define __snd_pcm_sync_ptr64 snd_pcm_sync_ptr
396#define __snd_timespec64 timespec
397struct __snd_timespec {
398 __s32 tv_sec;
399 __s32 tv_nsec;
400};
401#else
402#define __snd_pcm_mmap_status snd_pcm_mmap_status
403#define __snd_pcm_mmap_control snd_pcm_mmap_control
404#define __snd_pcm_sync_ptr snd_pcm_sync_ptr
405#define __snd_timespec timespec
406struct __snd_timespec64 {
407 __s64 tv_sec;
408 __s64 tv_nsec;
409};
410#endif
411struct __snd_pcm_mmap_status {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800412 snd_pcm_state_t state;
Tao Baod7db5942015-01-28 10:07:51 -0800413 int pad1;
414 snd_pcm_uframes_t hw_ptr;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700415 struct __snd_timespec tstamp;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800416 snd_pcm_state_t suspended_state;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700417 struct __snd_timespec audio_tstamp;
Ben Cheng655a7c02013-10-16 16:09:24 -0700418};
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700419struct __snd_pcm_mmap_control {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800420 snd_pcm_uframes_t appl_ptr;
Tao Baod7db5942015-01-28 10:07:51 -0800421 snd_pcm_uframes_t avail_min;
Ben Cheng655a7c02013-10-16 16:09:24 -0700422};
Tao Baod7db5942015-01-28 10:07:51 -0800423#define SNDRV_PCM_SYNC_PTR_HWSYNC (1 << 0)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800424#define SNDRV_PCM_SYNC_PTR_APPL (1 << 1)
Tao Baod7db5942015-01-28 10:07:51 -0800425#define SNDRV_PCM_SYNC_PTR_AVAIL_MIN (1 << 2)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700426struct __snd_pcm_sync_ptr {
Tao Baod7db5942015-01-28 10:07:51 -0800427 unsigned int flags;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800428 union {
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700429 struct __snd_pcm_mmap_status status;
Tao Baod7db5942015-01-28 10:07:51 -0800430 unsigned char reserved[64];
431 } s;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800432 union {
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700433 struct __snd_pcm_mmap_control control;
434 unsigned char reserved[64];
435 } c;
436};
437#if defined(__BYTE_ORDER) ? __BYTE_ORDER == __BIG_ENDIAN : defined(__BIG_ENDIAN)
438typedef char __pad_before_uframe[sizeof(__u64) - sizeof(snd_pcm_uframes_t)];
439typedef char __pad_after_uframe[0];
440#endif
441#if defined(__BYTE_ORDER) ? __BYTE_ORDER == __LITTLE_ENDIAN : defined(__LITTLE_ENDIAN)
442typedef char __pad_before_uframe[0];
443typedef char __pad_after_uframe[sizeof(__u64) - sizeof(snd_pcm_uframes_t)];
444#endif
445struct __snd_pcm_mmap_status64 {
446 snd_pcm_state_t state;
447 __u32 pad1;
448 __pad_before_uframe __pad1;
449 snd_pcm_uframes_t hw_ptr;
450 __pad_after_uframe __pad2;
451 struct __snd_timespec64 tstamp;
452 snd_pcm_state_t suspended_state;
453 __u32 pad3;
454 struct __snd_timespec64 audio_tstamp;
455};
456struct __snd_pcm_mmap_control64 {
457 __pad_before_uframe __pad1;
458 snd_pcm_uframes_t appl_ptr;
459 __pad_before_uframe __pad2;
460 __pad_before_uframe __pad3;
461 snd_pcm_uframes_t avail_min;
462 __pad_after_uframe __pad4;
463};
464struct __snd_pcm_sync_ptr64 {
465 __u32 flags;
466 __u32 pad1;
467 union {
468 struct __snd_pcm_mmap_status64 status;
469 unsigned char reserved[64];
470 } s;
471 union {
472 struct __snd_pcm_mmap_control64 control;
Tao Baod7db5942015-01-28 10:07:51 -0800473 unsigned char reserved[64];
474 } c;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800475};
Tao Baod7db5942015-01-28 10:07:51 -0800476struct snd_xferi {
477 snd_pcm_sframes_t result;
478 void __user * buf;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800479 snd_pcm_uframes_t frames;
Ben Cheng655a7c02013-10-16 16:09:24 -0700480};
481struct snd_xfern {
Tao Baod7db5942015-01-28 10:07:51 -0800482 snd_pcm_sframes_t result;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800483 void __user * __user * bufs;
Tao Baod7db5942015-01-28 10:07:51 -0800484 snd_pcm_uframes_t frames;
Ben Cheng655a7c02013-10-16 16:09:24 -0700485};
Christopher Ferris38062f92014-07-09 15:33:25 -0700486enum {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800487 SNDRV_PCM_TSTAMP_TYPE_GETTIMEOFDAY = 0,
Tao Baod7db5942015-01-28 10:07:51 -0800488 SNDRV_PCM_TSTAMP_TYPE_MONOTONIC,
489 SNDRV_PCM_TSTAMP_TYPE_MONOTONIC_RAW,
490 SNDRV_PCM_TSTAMP_TYPE_LAST = SNDRV_PCM_TSTAMP_TYPE_MONOTONIC_RAW,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800491};
Ben Cheng655a7c02013-10-16 16:09:24 -0700492enum {
Tao Baod7db5942015-01-28 10:07:51 -0800493 SNDRV_CHMAP_UNKNOWN = 0,
494 SNDRV_CHMAP_NA,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800495 SNDRV_CHMAP_MONO,
Tao Baod7db5942015-01-28 10:07:51 -0800496 SNDRV_CHMAP_FL,
497 SNDRV_CHMAP_FR,
498 SNDRV_CHMAP_RL,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800499 SNDRV_CHMAP_RR,
Tao Baod7db5942015-01-28 10:07:51 -0800500 SNDRV_CHMAP_FC,
501 SNDRV_CHMAP_LFE,
502 SNDRV_CHMAP_SL,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800503 SNDRV_CHMAP_SR,
Tao Baod7db5942015-01-28 10:07:51 -0800504 SNDRV_CHMAP_RC,
505 SNDRV_CHMAP_FLC,
506 SNDRV_CHMAP_FRC,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800507 SNDRV_CHMAP_RLC,
Tao Baod7db5942015-01-28 10:07:51 -0800508 SNDRV_CHMAP_RRC,
509 SNDRV_CHMAP_FLW,
510 SNDRV_CHMAP_FRW,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800511 SNDRV_CHMAP_FLH,
Tao Baod7db5942015-01-28 10:07:51 -0800512 SNDRV_CHMAP_FCH,
513 SNDRV_CHMAP_FRH,
514 SNDRV_CHMAP_TC,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800515 SNDRV_CHMAP_TFL,
Tao Baod7db5942015-01-28 10:07:51 -0800516 SNDRV_CHMAP_TFR,
517 SNDRV_CHMAP_TFC,
518 SNDRV_CHMAP_TRL,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800519 SNDRV_CHMAP_TRR,
Tao Baod7db5942015-01-28 10:07:51 -0800520 SNDRV_CHMAP_TRC,
521 SNDRV_CHMAP_TFLC,
522 SNDRV_CHMAP_TFRC,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800523 SNDRV_CHMAP_TSL,
Tao Baod7db5942015-01-28 10:07:51 -0800524 SNDRV_CHMAP_TSR,
525 SNDRV_CHMAP_LLFE,
526 SNDRV_CHMAP_RLFE,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800527 SNDRV_CHMAP_BC,
Tao Baod7db5942015-01-28 10:07:51 -0800528 SNDRV_CHMAP_BLC,
529 SNDRV_CHMAP_BRC,
530 SNDRV_CHMAP_LAST = SNDRV_CHMAP_BRC,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800531};
Ben Cheng655a7c02013-10-16 16:09:24 -0700532#define SNDRV_CHMAP_POSITION_MASK 0xffff
533#define SNDRV_CHMAP_PHASE_INVERSE (0x01 << 16)
534#define SNDRV_CHMAP_DRIVER_SPEC (0x02 << 16)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800535#define SNDRV_PCM_IOCTL_PVERSION _IOR('A', 0x00, int)
Ben Cheng655a7c02013-10-16 16:09:24 -0700536#define SNDRV_PCM_IOCTL_INFO _IOR('A', 0x01, struct snd_pcm_info)
537#define SNDRV_PCM_IOCTL_TSTAMP _IOW('A', 0x02, int)
538#define SNDRV_PCM_IOCTL_TTSTAMP _IOW('A', 0x03, int)
Christopher Ferris1308ad32017-11-14 17:32:13 -0800539#define SNDRV_PCM_IOCTL_USER_PVERSION _IOW('A', 0x04, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800540#define SNDRV_PCM_IOCTL_HW_REFINE _IOWR('A', 0x10, struct snd_pcm_hw_params)
Ben Cheng655a7c02013-10-16 16:09:24 -0700541#define SNDRV_PCM_IOCTL_HW_PARAMS _IOWR('A', 0x11, struct snd_pcm_hw_params)
542#define SNDRV_PCM_IOCTL_HW_FREE _IO('A', 0x12)
543#define SNDRV_PCM_IOCTL_SW_PARAMS _IOWR('A', 0x13, struct snd_pcm_sw_params)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800544#define SNDRV_PCM_IOCTL_STATUS _IOR('A', 0x20, struct snd_pcm_status)
Ben Cheng655a7c02013-10-16 16:09:24 -0700545#define SNDRV_PCM_IOCTL_DELAY _IOR('A', 0x21, snd_pcm_sframes_t)
546#define SNDRV_PCM_IOCTL_HWSYNC _IO('A', 0x22)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700547#define __SNDRV_PCM_IOCTL_SYNC_PTR _IOWR('A', 0x23, struct __snd_pcm_sync_ptr)
548#define __SNDRV_PCM_IOCTL_SYNC_PTR64 _IOWR('A', 0x23, struct __snd_pcm_sync_ptr64)
Ben Cheng655a7c02013-10-16 16:09:24 -0700549#define SNDRV_PCM_IOCTL_SYNC_PTR _IOWR('A', 0x23, struct snd_pcm_sync_ptr)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800550#define SNDRV_PCM_IOCTL_STATUS_EXT _IOWR('A', 0x24, struct snd_pcm_status)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800551#define SNDRV_PCM_IOCTL_CHANNEL_INFO _IOR('A', 0x32, struct snd_pcm_channel_info)
Ben Cheng655a7c02013-10-16 16:09:24 -0700552#define SNDRV_PCM_IOCTL_PREPARE _IO('A', 0x40)
553#define SNDRV_PCM_IOCTL_RESET _IO('A', 0x41)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800554#define SNDRV_PCM_IOCTL_START _IO('A', 0x42)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800555#define SNDRV_PCM_IOCTL_DROP _IO('A', 0x43)
Ben Cheng655a7c02013-10-16 16:09:24 -0700556#define SNDRV_PCM_IOCTL_DRAIN _IO('A', 0x44)
557#define SNDRV_PCM_IOCTL_PAUSE _IOW('A', 0x45, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800558#define SNDRV_PCM_IOCTL_REWIND _IOW('A', 0x46, snd_pcm_uframes_t)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800559#define SNDRV_PCM_IOCTL_RESUME _IO('A', 0x47)
Ben Cheng655a7c02013-10-16 16:09:24 -0700560#define SNDRV_PCM_IOCTL_XRUN _IO('A', 0x48)
561#define SNDRV_PCM_IOCTL_FORWARD _IOW('A', 0x49, snd_pcm_uframes_t)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800562#define SNDRV_PCM_IOCTL_WRITEI_FRAMES _IOW('A', 0x50, struct snd_xferi)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800563#define SNDRV_PCM_IOCTL_READI_FRAMES _IOR('A', 0x51, struct snd_xferi)
Ben Cheng655a7c02013-10-16 16:09:24 -0700564#define SNDRV_PCM_IOCTL_WRITEN_FRAMES _IOW('A', 0x52, struct snd_xfern)
565#define SNDRV_PCM_IOCTL_READN_FRAMES _IOR('A', 0x53, struct snd_xfern)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800566#define SNDRV_PCM_IOCTL_LINK _IOW('A', 0x60, int)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800567#define SNDRV_PCM_IOCTL_UNLINK _IO('A', 0x61)
Christopher Ferris3a39c0b2021-09-02 00:03:38 +0000568#define SNDRV_RAWMIDI_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 2)
Ben Cheng655a7c02013-10-16 16:09:24 -0700569enum {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800570 SNDRV_RAWMIDI_STREAM_OUTPUT = 0,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800571 SNDRV_RAWMIDI_STREAM_INPUT,
Tao Baod7db5942015-01-28 10:07:51 -0800572 SNDRV_RAWMIDI_STREAM_LAST = SNDRV_RAWMIDI_STREAM_INPUT,
Ben Cheng655a7c02013-10-16 16:09:24 -0700573};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800574#define SNDRV_RAWMIDI_INFO_OUTPUT 0x00000001
Christopher Ferris05d08e92016-02-04 13:16:38 -0800575#define SNDRV_RAWMIDI_INFO_INPUT 0x00000002
Ben Cheng655a7c02013-10-16 16:09:24 -0700576#define SNDRV_RAWMIDI_INFO_DUPLEX 0x00000004
577struct snd_rawmidi_info {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800578 unsigned int device;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800579 unsigned int subdevice;
Tao Baod7db5942015-01-28 10:07:51 -0800580 int stream;
581 int card;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800582 unsigned int flags;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800583 unsigned char id[64];
Tao Baod7db5942015-01-28 10:07:51 -0800584 unsigned char name[80];
585 unsigned char subname[32];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800586 unsigned int subdevices_count;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800587 unsigned int subdevices_avail;
Tao Baod7db5942015-01-28 10:07:51 -0800588 unsigned char reserved[64];
Ben Cheng655a7c02013-10-16 16:09:24 -0700589};
Christopher Ferris3a39c0b2021-09-02 00:03:38 +0000590#define SNDRV_RAWMIDI_MODE_FRAMING_MASK (7 << 0)
591#define SNDRV_RAWMIDI_MODE_FRAMING_SHIFT 0
592#define SNDRV_RAWMIDI_MODE_FRAMING_NONE (0 << 0)
593#define SNDRV_RAWMIDI_MODE_FRAMING_TSTAMP (1 << 0)
594#define SNDRV_RAWMIDI_MODE_CLOCK_MASK (7 << 3)
595#define SNDRV_RAWMIDI_MODE_CLOCK_SHIFT 3
596#define SNDRV_RAWMIDI_MODE_CLOCK_NONE (0 << 3)
597#define SNDRV_RAWMIDI_MODE_CLOCK_REALTIME (1 << 3)
598#define SNDRV_RAWMIDI_MODE_CLOCK_MONOTONIC (2 << 3)
599#define SNDRV_RAWMIDI_MODE_CLOCK_MONOTONIC_RAW (3 << 3)
600#define SNDRV_RAWMIDI_FRAMING_DATA_LENGTH 16
601struct snd_rawmidi_framing_tstamp {
602 __u8 frame_type;
603 __u8 length;
604 __u8 reserved[2];
605 __u32 tv_nsec;
606 __u64 tv_sec;
607 __u8 data[SNDRV_RAWMIDI_FRAMING_DATA_LENGTH];
608} __packed;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800609struct snd_rawmidi_params {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800610 int stream;
Tao Baod7db5942015-01-28 10:07:51 -0800611 size_t buffer_size;
612 size_t avail_min;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800613 unsigned int no_active_sensing : 1;
Christopher Ferris3a39c0b2021-09-02 00:03:38 +0000614 unsigned int mode;
615 unsigned char reserved[12];
Ben Cheng655a7c02013-10-16 16:09:24 -0700616};
617struct snd_rawmidi_status {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800618 int stream;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700619 __time_pad pad1;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800620 struct timespec tstamp;
Tao Baod7db5942015-01-28 10:07:51 -0800621 size_t avail;
622 size_t xruns;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800623 unsigned char reserved[16];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800624};
Ben Cheng655a7c02013-10-16 16:09:24 -0700625#define SNDRV_RAWMIDI_IOCTL_PVERSION _IOR('W', 0x00, int)
626#define SNDRV_RAWMIDI_IOCTL_INFO _IOR('W', 0x01, struct snd_rawmidi_info)
Christopher Ferris2abfa9e2021-11-01 16:26:06 -0700627#define SNDRV_RAWMIDI_IOCTL_USER_PVERSION _IOW('W', 0x02, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800628#define SNDRV_RAWMIDI_IOCTL_PARAMS _IOWR('W', 0x10, struct snd_rawmidi_params)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800629#define SNDRV_RAWMIDI_IOCTL_STATUS _IOWR('W', 0x20, struct snd_rawmidi_status)
Ben Cheng655a7c02013-10-16 16:09:24 -0700630#define SNDRV_RAWMIDI_IOCTL_DROP _IOW('W', 0x30, int)
631#define SNDRV_RAWMIDI_IOCTL_DRAIN _IOW('W', 0x31, int)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700632#define SNDRV_TIMER_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 7)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800633enum {
Tao Baod7db5942015-01-28 10:07:51 -0800634 SNDRV_TIMER_CLASS_NONE = - 1,
635 SNDRV_TIMER_CLASS_SLAVE = 0,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800636 SNDRV_TIMER_CLASS_GLOBAL,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800637 SNDRV_TIMER_CLASS_CARD,
Tao Baod7db5942015-01-28 10:07:51 -0800638 SNDRV_TIMER_CLASS_PCM,
639 SNDRV_TIMER_CLASS_LAST = SNDRV_TIMER_CLASS_PCM,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800640};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800641enum {
Tao Baod7db5942015-01-28 10:07:51 -0800642 SNDRV_TIMER_SCLASS_NONE = 0,
643 SNDRV_TIMER_SCLASS_APPLICATION,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800644 SNDRV_TIMER_SCLASS_SEQUENCER,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800645 SNDRV_TIMER_SCLASS_OSS_SEQUENCER,
Tao Baod7db5942015-01-28 10:07:51 -0800646 SNDRV_TIMER_SCLASS_LAST = SNDRV_TIMER_SCLASS_OSS_SEQUENCER,
Ben Cheng655a7c02013-10-16 16:09:24 -0700647};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800648#define SNDRV_TIMER_GLOBAL_SYSTEM 0
Christopher Ferris05d08e92016-02-04 13:16:38 -0800649#define SNDRV_TIMER_GLOBAL_RTC 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700650#define SNDRV_TIMER_GLOBAL_HPET 2
651#define SNDRV_TIMER_GLOBAL_HRTIMER 3
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800652#define SNDRV_TIMER_FLG_SLAVE (1 << 0)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800653struct snd_timer_id {
Tao Baod7db5942015-01-28 10:07:51 -0800654 int dev_class;
655 int dev_sclass;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800656 int card;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800657 int device;
Tao Baod7db5942015-01-28 10:07:51 -0800658 int subdevice;
Ben Cheng655a7c02013-10-16 16:09:24 -0700659};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800660struct snd_timer_ginfo {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800661 struct snd_timer_id tid;
Tao Baod7db5942015-01-28 10:07:51 -0800662 unsigned int flags;
663 int card;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800664 unsigned char id[64];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800665 unsigned char name[80];
Tao Baod7db5942015-01-28 10:07:51 -0800666 unsigned long reserved0;
667 unsigned long resolution;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800668 unsigned long resolution_min;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800669 unsigned long resolution_max;
Tao Baod7db5942015-01-28 10:07:51 -0800670 unsigned int clients;
671 unsigned char reserved[32];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800672};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800673struct snd_timer_gparams {
Tao Baod7db5942015-01-28 10:07:51 -0800674 struct snd_timer_id tid;
675 unsigned long period_num;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800676 unsigned long period_den;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800677 unsigned char reserved[32];
Ben Cheng655a7c02013-10-16 16:09:24 -0700678};
679struct snd_timer_gstatus {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800680 struct snd_timer_id tid;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800681 unsigned long resolution;
Tao Baod7db5942015-01-28 10:07:51 -0800682 unsigned long resolution_num;
683 unsigned long resolution_den;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800684 unsigned char reserved[32];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800685};
Ben Cheng655a7c02013-10-16 16:09:24 -0700686struct snd_timer_select {
Tao Baod7db5942015-01-28 10:07:51 -0800687 struct snd_timer_id id;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800688 unsigned char reserved[32];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800689};
Ben Cheng655a7c02013-10-16 16:09:24 -0700690struct snd_timer_info {
Tao Baod7db5942015-01-28 10:07:51 -0800691 unsigned int flags;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800692 int card;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800693 unsigned char id[64];
Tao Baod7db5942015-01-28 10:07:51 -0800694 unsigned char name[80];
695 unsigned long reserved0;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800696 unsigned long resolution;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800697 unsigned char reserved[64];
Ben Cheng655a7c02013-10-16 16:09:24 -0700698};
Tao Baod7db5942015-01-28 10:07:51 -0800699#define SNDRV_TIMER_PSFLG_AUTO (1 << 0)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800700#define SNDRV_TIMER_PSFLG_EXCLUSIVE (1 << 1)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800701#define SNDRV_TIMER_PSFLG_EARLY_EVENT (1 << 2)
Ben Cheng655a7c02013-10-16 16:09:24 -0700702struct snd_timer_params {
Tao Baod7db5942015-01-28 10:07:51 -0800703 unsigned int flags;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800704 unsigned int ticks;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800705 unsigned int queue_size;
Tao Baod7db5942015-01-28 10:07:51 -0800706 unsigned int reserved0;
707 unsigned int filter;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800708 unsigned char reserved[60];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800709};
Ben Cheng655a7c02013-10-16 16:09:24 -0700710struct snd_timer_status {
Tao Baod7db5942015-01-28 10:07:51 -0800711 struct timespec tstamp;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800712 unsigned int resolution;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800713 unsigned int lost;
Tao Baod7db5942015-01-28 10:07:51 -0800714 unsigned int overrun;
715 unsigned int queue;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800716 unsigned char reserved[64];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800717};
Ben Cheng655a7c02013-10-16 16:09:24 -0700718#define SNDRV_TIMER_IOCTL_PVERSION _IOR('T', 0x00, int)
719#define SNDRV_TIMER_IOCTL_NEXT_DEVICE _IOWR('T', 0x01, struct snd_timer_id)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700720#define SNDRV_TIMER_IOCTL_TREAD_OLD _IOW('T', 0x02, int)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800721#define SNDRV_TIMER_IOCTL_GINFO _IOWR('T', 0x03, struct snd_timer_ginfo)
Ben Cheng655a7c02013-10-16 16:09:24 -0700722#define SNDRV_TIMER_IOCTL_GPARAMS _IOW('T', 0x04, struct snd_timer_gparams)
723#define SNDRV_TIMER_IOCTL_GSTATUS _IOWR('T', 0x05, struct snd_timer_gstatus)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800724#define SNDRV_TIMER_IOCTL_SELECT _IOW('T', 0x10, struct snd_timer_select)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800725#define SNDRV_TIMER_IOCTL_INFO _IOR('T', 0x11, struct snd_timer_info)
Ben Cheng655a7c02013-10-16 16:09:24 -0700726#define SNDRV_TIMER_IOCTL_PARAMS _IOW('T', 0x12, struct snd_timer_params)
727#define SNDRV_TIMER_IOCTL_STATUS _IOR('T', 0x14, struct snd_timer_status)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800728#define SNDRV_TIMER_IOCTL_START _IO('T', 0xa0)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800729#define SNDRV_TIMER_IOCTL_STOP _IO('T', 0xa1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700730#define SNDRV_TIMER_IOCTL_CONTINUE _IO('T', 0xa2)
731#define SNDRV_TIMER_IOCTL_PAUSE _IO('T', 0xa3)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700732#define SNDRV_TIMER_IOCTL_TREAD64 _IOW('T', 0xa4, int)
733#if __BITS_PER_LONG == 64
734#define SNDRV_TIMER_IOCTL_TREAD SNDRV_TIMER_IOCTL_TREAD_OLD
735#else
736#define SNDRV_TIMER_IOCTL_TREAD ((sizeof(__kernel_long_t) >= sizeof(time_t)) ? SNDRV_TIMER_IOCTL_TREAD_OLD : SNDRV_TIMER_IOCTL_TREAD64)
737#endif
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800738struct snd_timer_read {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800739 unsigned int resolution;
Tao Baod7db5942015-01-28 10:07:51 -0800740 unsigned int ticks;
Ben Cheng655a7c02013-10-16 16:09:24 -0700741};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800742enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800743 SNDRV_TIMER_EVENT_RESOLUTION = 0,
Tao Baod7db5942015-01-28 10:07:51 -0800744 SNDRV_TIMER_EVENT_TICK,
745 SNDRV_TIMER_EVENT_START,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800746 SNDRV_TIMER_EVENT_STOP,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800747 SNDRV_TIMER_EVENT_CONTINUE,
Tao Baod7db5942015-01-28 10:07:51 -0800748 SNDRV_TIMER_EVENT_PAUSE,
749 SNDRV_TIMER_EVENT_EARLY,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800750 SNDRV_TIMER_EVENT_SUSPEND,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800751 SNDRV_TIMER_EVENT_RESUME,
Tao Baod7db5942015-01-28 10:07:51 -0800752 SNDRV_TIMER_EVENT_MSTART = SNDRV_TIMER_EVENT_START + 10,
753 SNDRV_TIMER_EVENT_MSTOP = SNDRV_TIMER_EVENT_STOP + 10,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800754 SNDRV_TIMER_EVENT_MCONTINUE = SNDRV_TIMER_EVENT_CONTINUE + 10,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800755 SNDRV_TIMER_EVENT_MPAUSE = SNDRV_TIMER_EVENT_PAUSE + 10,
Tao Baod7db5942015-01-28 10:07:51 -0800756 SNDRV_TIMER_EVENT_MSUSPEND = SNDRV_TIMER_EVENT_SUSPEND + 10,
757 SNDRV_TIMER_EVENT_MRESUME = SNDRV_TIMER_EVENT_RESUME + 10,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800758};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800759struct snd_timer_tread {
Tao Baod7db5942015-01-28 10:07:51 -0800760 int event;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700761 __time_pad pad1;
Tao Baod7db5942015-01-28 10:07:51 -0800762 struct timespec tstamp;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800763 unsigned int val;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700764 __time_pad pad2;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800765};
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700766#define SNDRV_CTL_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 8)
Ben Cheng655a7c02013-10-16 16:09:24 -0700767struct snd_ctl_card_info {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800768 int card;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800769 int pad;
Tao Baod7db5942015-01-28 10:07:51 -0800770 unsigned char id[16];
771 unsigned char driver[16];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800772 unsigned char name[32];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800773 unsigned char longname[80];
Tao Baod7db5942015-01-28 10:07:51 -0800774 unsigned char reserved_[16];
775 unsigned char mixername[80];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800776 unsigned char components[128];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800777};
Ben Cheng655a7c02013-10-16 16:09:24 -0700778typedef int __bitwise snd_ctl_elem_type_t;
779#define SNDRV_CTL_ELEM_TYPE_NONE ((__force snd_ctl_elem_type_t) 0)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800780#define SNDRV_CTL_ELEM_TYPE_BOOLEAN ((__force snd_ctl_elem_type_t) 1)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800781#define SNDRV_CTL_ELEM_TYPE_INTEGER ((__force snd_ctl_elem_type_t) 2)
Ben Cheng655a7c02013-10-16 16:09:24 -0700782#define SNDRV_CTL_ELEM_TYPE_ENUMERATED ((__force snd_ctl_elem_type_t) 3)
783#define SNDRV_CTL_ELEM_TYPE_BYTES ((__force snd_ctl_elem_type_t) 4)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800784#define SNDRV_CTL_ELEM_TYPE_IEC958 ((__force snd_ctl_elem_type_t) 5)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800785#define SNDRV_CTL_ELEM_TYPE_INTEGER64 ((__force snd_ctl_elem_type_t) 6)
Ben Cheng655a7c02013-10-16 16:09:24 -0700786#define SNDRV_CTL_ELEM_TYPE_LAST SNDRV_CTL_ELEM_TYPE_INTEGER64
787typedef int __bitwise snd_ctl_elem_iface_t;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800788#define SNDRV_CTL_ELEM_IFACE_CARD ((__force snd_ctl_elem_iface_t) 0)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800789#define SNDRV_CTL_ELEM_IFACE_HWDEP ((__force snd_ctl_elem_iface_t) 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700790#define SNDRV_CTL_ELEM_IFACE_MIXER ((__force snd_ctl_elem_iface_t) 2)
791#define SNDRV_CTL_ELEM_IFACE_PCM ((__force snd_ctl_elem_iface_t) 3)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800792#define SNDRV_CTL_ELEM_IFACE_RAWMIDI ((__force snd_ctl_elem_iface_t) 4)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800793#define SNDRV_CTL_ELEM_IFACE_TIMER ((__force snd_ctl_elem_iface_t) 5)
Ben Cheng655a7c02013-10-16 16:09:24 -0700794#define SNDRV_CTL_ELEM_IFACE_SEQUENCER ((__force snd_ctl_elem_iface_t) 6)
795#define SNDRV_CTL_ELEM_IFACE_LAST SNDRV_CTL_ELEM_IFACE_SEQUENCER
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800796#define SNDRV_CTL_ELEM_ACCESS_READ (1 << 0)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800797#define SNDRV_CTL_ELEM_ACCESS_WRITE (1 << 1)
Tao Baod7db5942015-01-28 10:07:51 -0800798#define SNDRV_CTL_ELEM_ACCESS_READWRITE (SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_WRITE)
799#define SNDRV_CTL_ELEM_ACCESS_VOLATILE (1 << 2)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800800#define SNDRV_CTL_ELEM_ACCESS_TLV_READ (1 << 4)
Tao Baod7db5942015-01-28 10:07:51 -0800801#define SNDRV_CTL_ELEM_ACCESS_TLV_WRITE (1 << 5)
802#define SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE (SNDRV_CTL_ELEM_ACCESS_TLV_READ | SNDRV_CTL_ELEM_ACCESS_TLV_WRITE)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800803#define SNDRV_CTL_ELEM_ACCESS_TLV_COMMAND (1 << 6)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800804#define SNDRV_CTL_ELEM_ACCESS_INACTIVE (1 << 8)
Tao Baod7db5942015-01-28 10:07:51 -0800805#define SNDRV_CTL_ELEM_ACCESS_LOCK (1 << 9)
806#define SNDRV_CTL_ELEM_ACCESS_OWNER (1 << 10)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800807#define SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK (1 << 28)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800808#define SNDRV_CTL_ELEM_ACCESS_USER (1 << 29)
Ben Cheng655a7c02013-10-16 16:09:24 -0700809#define SNDRV_CTL_POWER_D0 0x0000
810#define SNDRV_CTL_POWER_D1 0x0100
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800811#define SNDRV_CTL_POWER_D2 0x0200
Christopher Ferris05d08e92016-02-04 13:16:38 -0800812#define SNDRV_CTL_POWER_D3 0x0300
Tao Baod7db5942015-01-28 10:07:51 -0800813#define SNDRV_CTL_POWER_D3hot (SNDRV_CTL_POWER_D3 | 0x0000)
814#define SNDRV_CTL_POWER_D3cold (SNDRV_CTL_POWER_D3 | 0x0001)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800815#define SNDRV_CTL_ELEM_ID_NAME_MAXLEN 44
Christopher Ferris05d08e92016-02-04 13:16:38 -0800816struct snd_ctl_elem_id {
Tao Baod7db5942015-01-28 10:07:51 -0800817 unsigned int numid;
818 snd_ctl_elem_iface_t iface;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800819 unsigned int device;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800820 unsigned int subdevice;
821 unsigned char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Tao Baod7db5942015-01-28 10:07:51 -0800822 unsigned int index;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800823};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800824struct snd_ctl_elem_list {
Tao Baod7db5942015-01-28 10:07:51 -0800825 unsigned int offset;
826 unsigned int space;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800827 unsigned int used;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800828 unsigned int count;
Tao Baod7db5942015-01-28 10:07:51 -0800829 struct snd_ctl_elem_id __user * pids;
830 unsigned char reserved[50];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800831};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800832struct snd_ctl_elem_info {
Tao Baod7db5942015-01-28 10:07:51 -0800833 struct snd_ctl_elem_id id;
834 snd_ctl_elem_type_t type;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800835 unsigned int access;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800836 unsigned int count;
Tao Baod7db5942015-01-28 10:07:51 -0800837 __kernel_pid_t owner;
838 union {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800839 struct {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800840 long min;
Tao Baod7db5942015-01-28 10:07:51 -0800841 long max;
842 long step;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800843 } integer;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800844 struct {
Tao Baod7db5942015-01-28 10:07:51 -0800845 long long min;
846 long long max;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800847 long long step;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800848 } integer64;
Tao Baod7db5942015-01-28 10:07:51 -0800849 struct {
850 unsigned int items;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800851 unsigned int item;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800852 char name[64];
Tao Baod7db5942015-01-28 10:07:51 -0800853 __u64 names_ptr;
854 unsigned int names_length;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800855 } enumerated;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800856 unsigned char reserved[128];
Tao Baod7db5942015-01-28 10:07:51 -0800857 } value;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700858 unsigned char reserved[64];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800859};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800860struct snd_ctl_elem_value {
Tao Baod7db5942015-01-28 10:07:51 -0800861 struct snd_ctl_elem_id id;
862 unsigned int indirect : 1;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800863 union {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800864 union {
Tao Baod7db5942015-01-28 10:07:51 -0800865 long value[128];
866 long * value_ptr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800867 } integer;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800868 union {
Tao Baod7db5942015-01-28 10:07:51 -0800869 long long value[64];
870 long long * value_ptr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800871 } integer64;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800872 union {
Tao Baod7db5942015-01-28 10:07:51 -0800873 unsigned int item[128];
874 unsigned int * item_ptr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800875 } enumerated;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800876 union {
Tao Baod7db5942015-01-28 10:07:51 -0800877 unsigned char data[512];
878 unsigned char * data_ptr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800879 } bytes;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800880 struct snd_aes_iec958 iec958;
Tao Baod7db5942015-01-28 10:07:51 -0800881 } value;
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700882 unsigned char reserved[128];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800883};
Tao Baod7db5942015-01-28 10:07:51 -0800884struct snd_ctl_tlv {
885 unsigned int numid;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800886 unsigned int length;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800887 unsigned int tlv[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700888};
889#define SNDRV_CTL_IOCTL_PVERSION _IOR('U', 0x00, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800890#define SNDRV_CTL_IOCTL_CARD_INFO _IOR('U', 0x01, struct snd_ctl_card_info)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800891#define SNDRV_CTL_IOCTL_ELEM_LIST _IOWR('U', 0x10, struct snd_ctl_elem_list)
Ben Cheng655a7c02013-10-16 16:09:24 -0700892#define SNDRV_CTL_IOCTL_ELEM_INFO _IOWR('U', 0x11, struct snd_ctl_elem_info)
893#define SNDRV_CTL_IOCTL_ELEM_READ _IOWR('U', 0x12, struct snd_ctl_elem_value)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800894#define SNDRV_CTL_IOCTL_ELEM_WRITE _IOWR('U', 0x13, struct snd_ctl_elem_value)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800895#define SNDRV_CTL_IOCTL_ELEM_LOCK _IOW('U', 0x14, struct snd_ctl_elem_id)
Ben Cheng655a7c02013-10-16 16:09:24 -0700896#define SNDRV_CTL_IOCTL_ELEM_UNLOCK _IOW('U', 0x15, struct snd_ctl_elem_id)
897#define SNDRV_CTL_IOCTL_SUBSCRIBE_EVENTS _IOWR('U', 0x16, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800898#define SNDRV_CTL_IOCTL_ELEM_ADD _IOWR('U', 0x17, struct snd_ctl_elem_info)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800899#define SNDRV_CTL_IOCTL_ELEM_REPLACE _IOWR('U', 0x18, struct snd_ctl_elem_info)
Ben Cheng655a7c02013-10-16 16:09:24 -0700900#define SNDRV_CTL_IOCTL_ELEM_REMOVE _IOWR('U', 0x19, struct snd_ctl_elem_id)
901#define SNDRV_CTL_IOCTL_TLV_READ _IOWR('U', 0x1a, struct snd_ctl_tlv)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800902#define SNDRV_CTL_IOCTL_TLV_WRITE _IOWR('U', 0x1b, struct snd_ctl_tlv)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800903#define SNDRV_CTL_IOCTL_TLV_COMMAND _IOWR('U', 0x1c, struct snd_ctl_tlv)
Ben Cheng655a7c02013-10-16 16:09:24 -0700904#define SNDRV_CTL_IOCTL_HWDEP_NEXT_DEVICE _IOWR('U', 0x20, int)
905#define SNDRV_CTL_IOCTL_HWDEP_INFO _IOR('U', 0x21, struct snd_hwdep_info)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800906#define SNDRV_CTL_IOCTL_PCM_NEXT_DEVICE _IOR('U', 0x30, int)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800907#define SNDRV_CTL_IOCTL_PCM_INFO _IOWR('U', 0x31, struct snd_pcm_info)
Ben Cheng655a7c02013-10-16 16:09:24 -0700908#define SNDRV_CTL_IOCTL_PCM_PREFER_SUBDEVICE _IOW('U', 0x32, int)
909#define SNDRV_CTL_IOCTL_RAWMIDI_NEXT_DEVICE _IOWR('U', 0x40, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800910#define SNDRV_CTL_IOCTL_RAWMIDI_INFO _IOWR('U', 0x41, struct snd_rawmidi_info)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800911#define SNDRV_CTL_IOCTL_RAWMIDI_PREFER_SUBDEVICE _IOW('U', 0x42, int)
Ben Cheng655a7c02013-10-16 16:09:24 -0700912#define SNDRV_CTL_IOCTL_POWER _IOWR('U', 0xd0, int)
913#define SNDRV_CTL_IOCTL_POWER_STATE _IOR('U', 0xd1, int)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800914enum sndrv_ctl_event_type {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800915 SNDRV_CTL_EVENT_ELEM = 0,
Tao Baod7db5942015-01-28 10:07:51 -0800916 SNDRV_CTL_EVENT_LAST = SNDRV_CTL_EVENT_ELEM,
Ben Cheng655a7c02013-10-16 16:09:24 -0700917};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800918#define SNDRV_CTL_EVENT_MASK_VALUE (1 << 0)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800919#define SNDRV_CTL_EVENT_MASK_INFO (1 << 1)
Tao Baod7db5942015-01-28 10:07:51 -0800920#define SNDRV_CTL_EVENT_MASK_ADD (1 << 2)
921#define SNDRV_CTL_EVENT_MASK_TLV (1 << 3)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800922#define SNDRV_CTL_EVENT_MASK_REMOVE (~0U)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800923struct snd_ctl_event {
Tao Baod7db5942015-01-28 10:07:51 -0800924 int type;
925 union {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800926 struct {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800927 unsigned int mask;
Tao Baod7db5942015-01-28 10:07:51 -0800928 struct snd_ctl_elem_id id;
929 } elem;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800930 unsigned char data8[60];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800931 } data;
Ben Cheng655a7c02013-10-16 16:09:24 -0700932};
933#define SNDRV_CTL_NAME_NONE ""
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800934#define SNDRV_CTL_NAME_PLAYBACK "Playback "
Christopher Ferris05d08e92016-02-04 13:16:38 -0800935#define SNDRV_CTL_NAME_CAPTURE "Capture "
Ben Cheng655a7c02013-10-16 16:09:24 -0700936#define SNDRV_CTL_NAME_IEC958_NONE ""
937#define SNDRV_CTL_NAME_IEC958_SWITCH "Switch"
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800938#define SNDRV_CTL_NAME_IEC958_VOLUME "Volume"
Christopher Ferris05d08e92016-02-04 13:16:38 -0800939#define SNDRV_CTL_NAME_IEC958_DEFAULT "Default"
Ben Cheng655a7c02013-10-16 16:09:24 -0700940#define SNDRV_CTL_NAME_IEC958_MASK "Mask"
941#define SNDRV_CTL_NAME_IEC958_CON_MASK "Con Mask"
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800942#define SNDRV_CTL_NAME_IEC958_PRO_MASK "Pro Mask"
Christopher Ferris05d08e92016-02-04 13:16:38 -0800943#define SNDRV_CTL_NAME_IEC958_PCM_STREAM "PCM Stream"
Tao Baod7db5942015-01-28 10:07:51 -0800944#define SNDRV_CTL_NAME_IEC958(expl,direction,what) "IEC958 " expl SNDRV_CTL_NAME_ ##direction SNDRV_CTL_NAME_IEC958_ ##what
Ben Cheng655a7c02013-10-16 16:09:24 -0700945#endif