diff options
| author | Jari Vetoniemi <mailroxas@gmail.com> | 2018-10-29 00:50:38 +0200 | 
|---|---|---|
| committer | Jari Vetoniemi <mailroxas@gmail.com> | 2018-10-29 00:50:38 +0200 | 
| commit | c4d89540574dfb6a7418ed8cdd34e3cb2df585e7 (patch) | |
| tree | d4dbb844ddb68e64a7dd8edb91c662c82417b6b8 /include/alsa | |
Initial commit
Diffstat (limited to 'include/alsa')
36 files changed, 10042 insertions, 0 deletions
| diff --git a/include/alsa/asoundef.h b/include/alsa/asoundef.h new file mode 100644 index 0000000..c9124b2 --- /dev/null +++ b/include/alsa/asoundef.h @@ -0,0 +1,310 @@ +/** + * \file include/asoundef.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Definitions of constants for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_ASOUNDEF_H +#define __ALSA_ASOUNDEF_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \defgroup Digital_Audio_Interface Constants for Digital Audio Interfaces + * AES/IEC958 channel status bits. + * \{ + */ + +#define IEC958_AES0_PROFESSIONAL	(1<<0)	/**< 0 = consumer, 1 = professional */ +#define IEC958_AES0_NONAUDIO		(1<<1)	/**< 0 = audio, 1 = non-audio */ +#define IEC958_AES0_PRO_EMPHASIS	(7<<2)	/**< mask - emphasis */ +#define IEC958_AES0_PRO_EMPHASIS_NOTID	(0<<2)	/**< emphasis not indicated */ +#define IEC958_AES0_PRO_EMPHASIS_NONE	(1<<2)	/**< no emphasis */ +#define IEC958_AES0_PRO_EMPHASIS_5015	(3<<2)	/**< 50/15us emphasis */ +#define IEC958_AES0_PRO_EMPHASIS_CCITT	(7<<2)	/**< CCITT J.17 emphasis */ +#define IEC958_AES0_PRO_FREQ_UNLOCKED	(1<<5)	/**< source sample frequency: 0 = locked, 1 = unlocked */ +#define IEC958_AES0_PRO_FS		(3<<6)	/**< mask - sample frequency */ +#define IEC958_AES0_PRO_FS_NOTID	(0<<6)	/**< fs not indicated */ +#define IEC958_AES0_PRO_FS_44100	(1<<6)	/**< 44.1kHz */ +#define IEC958_AES0_PRO_FS_48000	(2<<6)	/**< 48kHz */ +#define IEC958_AES0_PRO_FS_32000	(3<<6)	/**< 32kHz */ +#define IEC958_AES0_CON_NOT_COPYRIGHT	(1<<2)	/**< 0 = copyright, 1 = not copyright */ +#define IEC958_AES0_CON_EMPHASIS	(7<<3)	/**< mask - emphasis */ +#define IEC958_AES0_CON_EMPHASIS_NONE	(0<<3)	/**< no emphasis */ +#define IEC958_AES0_CON_EMPHASIS_5015	(1<<3)	/**< 50/15us emphasis */ +#define IEC958_AES0_CON_MODE		(3<<6)	/**< mask - mode */ +#define IEC958_AES1_PRO_MODE		(15<<0)	/**< mask - channel mode */ +#define IEC958_AES1_PRO_MODE_NOTID	(0<<0)	/**< mode not indicated */ +#define IEC958_AES1_PRO_MODE_STEREOPHONIC (2<<0) /**< stereophonic - ch A is left */ +#define IEC958_AES1_PRO_MODE_SINGLE	(4<<0)	/**< single channel */ +#define IEC958_AES1_PRO_MODE_TWO	(8<<0)	/**< two channels */ +#define IEC958_AES1_PRO_MODE_PRIMARY	(12<<0)	/**< primary/secondary */ +#define IEC958_AES1_PRO_MODE_BYTE3	(15<<0)	/**< vector to byte 3 */ +#define IEC958_AES1_PRO_USERBITS	(15<<4)	/**< mask - user bits */ +#define IEC958_AES1_PRO_USERBITS_NOTID	(0<<4)	/**< user bits not indicated */ +#define IEC958_AES1_PRO_USERBITS_192	(8<<4)	/**< 192-bit structure */ +#define IEC958_AES1_PRO_USERBITS_UDEF	(12<<4)	/**< user defined application */ +#define IEC958_AES1_CON_CATEGORY	0x7f	/**< consumer category */ +#define IEC958_AES1_CON_GENERAL		0x00	/**< general category */ +#define IEC958_AES1_CON_LASEROPT_MASK	0x07	/**< Laser-optical mask */ +#define IEC958_AES1_CON_LASEROPT_ID	0x01	/**< Laser-optical ID */ +#define IEC958_AES1_CON_IEC908_CD	(IEC958_AES1_CON_LASEROPT_ID|0x00)	/**< IEC958 CD compatible device */ +#define IEC958_AES1_CON_NON_IEC908_CD	(IEC958_AES1_CON_LASEROPT_ID|0x08)	/**< non-IEC958 CD compatible device */ +#define IEC958_AES1_CON_MINI_DISC	(IEC958_AES1_CON_LASEROPT_ID|0x48)	/**< Mini-Disc device */ +#define IEC958_AES1_CON_DVD		(IEC958_AES1_CON_LASEROPT_ID|0x18)	/**< DVD device */ +#define IEC958_AES1_CON_LASTEROPT_OTHER	(IEC958_AES1_CON_LASEROPT_ID|0x78)	/**< Other laser-optical product */ +#define IEC958_AES1_CON_DIGDIGCONV_MASK 0x07	/**< digital<->digital converter mask */ +#define IEC958_AES1_CON_DIGDIGCONV_ID	0x02	/**< digital<->digital converter id */ +#define IEC958_AES1_CON_PCM_CODER	(IEC958_AES1_CON_DIGDIGCONV_ID|0x00)	/**< PCM coder */ +#define IEC958_AES1_CON_MIXER		(IEC958_AES1_CON_DIGDIGCONV_ID|0x10)	/**< Digital signal mixer */ +#define IEC958_AES1_CON_RATE_CONVERTER	(IEC958_AES1_CON_DIGDIGCONV_ID|0x18)	/**< Rate converter */ +#define IEC958_AES1_CON_SAMPLER		(IEC958_AES1_CON_DIGDIGCONV_ID|0x20)	/**< PCM sampler */ +#define IEC958_AES1_CON_DSP		(IEC958_AES1_CON_DIGDIGCONV_ID|0x28)	/**< Digital sound processor */ +#define IEC958_AES1_CON_DIGDIGCONV_OTHER (IEC958_AES1_CON_DIGDIGCONV_ID|0x78)	/**< Other digital<->digital product */ +#define IEC958_AES1_CON_MAGNETIC_MASK	0x07	/**< Magnetic device mask */ +#define IEC958_AES1_CON_MAGNETIC_ID	0x03	/**< Magnetic device ID */ +#define IEC958_AES1_CON_DAT		(IEC958_AES1_CON_MAGNETIC_ID|0x00)	/**< Digital Audio Tape */ +#define IEC958_AES1_CON_VCR		(IEC958_AES1_CON_MAGNETIC_ID|0x08)	/**< Video recorder */ +#define IEC958_AES1_CON_DCC		(IEC958_AES1_CON_MAGNETIC_ID|0x40)	/**< Digital compact cassette */ +#define IEC958_AES1_CON_MAGNETIC_DISC	(IEC958_AES1_CON_MAGNETIC_ID|0x18)	/**< Magnetic disc digital audio device */ +#define IEC958_AES1_CON_MAGNETIC_OTHER	(IEC958_AES1_CON_MAGNETIC_ID|0x78)	/**< Other magnetic device */ +#define IEC958_AES1_CON_BROADCAST1_MASK 0x07	/**< Broadcast mask */ +#define IEC958_AES1_CON_BROADCAST1_ID	0x04	/**< Broadcast ID */ +#define IEC958_AES1_CON_DAB_JAPAN	(IEC958_AES1_CON_BROADCAST1_ID|0x00)	/**< Digital audio broadcast (Japan) */ +#define IEC958_AES1_CON_DAB_EUROPE	(IEC958_AES1_CON_BROADCAST1_ID|0x08)	/**< Digital audio broadcast (Europe) */ +#define IEC958_AES1_CON_DAB_USA		(IEC958_AES1_CON_BROADCAST1_ID|0x60)	/**< Digital audio broadcast (USA) */ +#define IEC958_AES1_CON_SOFTWARE	(IEC958_AES1_CON_BROADCAST1_ID|0x40)	/**< Electronic software delivery */ +#define IEC958_AES1_CON_IEC62105	(IEC958_AES1_CON_BROADCAST1_ID|0x20)	/**< Used by another standard (IEC 62105) */ +#define IEC958_AES1_CON_BROADCAST1_OTHER (IEC958_AES1_CON_BROADCAST1_ID|0x78)	/**< Other broadcast product */ +#define IEC958_AES1_CON_BROADCAST2_MASK 0x0f	/**< Broadcast alternative mask */ +#define IEC958_AES1_CON_BROADCAST2_ID	0x0e	/**< Broadcast alternative ID */ +#define IEC958_AES1_CON_MUSICAL_MASK	0x07	/**< Musical device mask */ +#define IEC958_AES1_CON_MUSICAL_ID	0x05	/**< Musical device ID */ +#define IEC958_AES1_CON_SYNTHESIZER	(IEC958_AES1_CON_MUSICAL_ID|0x00)	/**< Synthesizer */ +#define IEC958_AES1_CON_MICROPHONE	(IEC958_AES1_CON_MUSICAL_ID|0x08)	/**< Microphone */ +#define IEC958_AES1_CON_MUSICAL_OTHER	(IEC958_AES1_CON_MUSICAL_ID|0x78)	/**< Other musical device */ +#define IEC958_AES1_CON_ADC_MASK	0x1f	/**< ADC Mask */ +#define IEC958_AES1_CON_ADC_ID		0x06	/**< ADC ID */ +#define IEC958_AES1_CON_ADC		(IEC958_AES1_CON_ADC_ID|0x00)	/**< ADC without copyright information */ +#define IEC958_AES1_CON_ADC_OTHER	(IEC958_AES1_CON_ADC_ID|0x60)	/**< Other ADC product (with no copyright information) */ +#define IEC958_AES1_CON_ADC_COPYRIGHT_MASK 0x1f	/**< ADC Copyright mask */ +#define IEC958_AES1_CON_ADC_COPYRIGHT_ID 0x16	/**< ADC Copyright ID */ +#define IEC958_AES1_CON_ADC_COPYRIGHT	(IEC958_AES1_CON_ADC_COPYRIGHT_ID|0x00)	/**< ADC with copyright information */ +#define IEC958_AES1_CON_ADC_COPYRIGHT_OTHER (IEC958_AES1_CON_ADC_COPYRIGHT_ID|0x60)	/**< Other ADC with copyright information product */ +#define IEC958_AES1_CON_SOLIDMEM_MASK	0x0f	/**< Solid memory based products mask */ +#define IEC958_AES1_CON_SOLIDMEM_ID	0x08	/**< Solid memory based products ID */ +#define IEC958_AES1_CON_SOLIDMEM_DIGITAL_RECORDER_PLAYER (IEC958_AES1_CON_SOLIDMEM_ID|0x00)	/**< Digital audio recorder and player using solid state memory */ +#define IEC958_AES1_CON_SOLIDMEM_OTHER	(IEC958_AES1_CON_SOLIDMEM_ID|0x70)	/**< Other solid state memory based product */ +#define IEC958_AES1_CON_EXPERIMENTAL	0x40	/**< experimental category */ +#define IEC958_AES1_CON_ORIGINAL	(1<<7)	/**< this bits depends on the category code */ +#define IEC958_AES2_PRO_SBITS		(7<<0)	/**< mask - sample bits */ +#define IEC958_AES2_PRO_SBITS_20	(2<<0)	/**< 20-bit - coordination */ +#define IEC958_AES2_PRO_SBITS_24	(4<<0)	/**< 24-bit - main audio */ +#define IEC958_AES2_PRO_SBITS_UDEF	(6<<0)	/**< user defined application */ +#define IEC958_AES2_PRO_WORDLEN		(7<<3)	/**< mask - source word length */ +#define IEC958_AES2_PRO_WORDLEN_NOTID	(0<<3)	/**< source word length not indicated */ +#define IEC958_AES2_PRO_WORDLEN_22_18	(2<<3)	/**< 22-bit or 18-bit */ +#define IEC958_AES2_PRO_WORDLEN_23_19	(4<<3)	/**< 23-bit or 19-bit */ +#define IEC958_AES2_PRO_WORDLEN_24_20	(5<<3)	/**< 24-bit or 20-bit */ +#define IEC958_AES2_PRO_WORDLEN_20_16	(6<<3)	/**< 20-bit or 16-bit */ +#define IEC958_AES2_CON_SOURCE		(15<<0)	/**< mask - source number */ +#define IEC958_AES2_CON_SOURCE_UNSPEC	(0<<0)	/**< source number unspecified */ +#define IEC958_AES2_CON_CHANNEL		(15<<4)	/**< mask - channel number */ +#define IEC958_AES2_CON_CHANNEL_UNSPEC	(0<<4)	/**< channel number unspecified */ +#define IEC958_AES3_CON_FS		(15<<0)	/**< mask - sample frequency */ +#define IEC958_AES3_CON_FS_44100	(0<<0)	/**< 44.1kHz */ +#define IEC958_AES3_CON_FS_NOTID	(1<<0)	/**< sample frequency non indicated */ +#define IEC958_AES3_CON_FS_48000	(2<<0)	/**< 48kHz */ +#define IEC958_AES3_CON_FS_32000	(3<<0)	/**< 32kHz */ +#define IEC958_AES3_CON_FS_22050	(4<<0)	/**< 22.05kHz */ +#define IEC958_AES3_CON_FS_24000	(6<<0)	/**< 24kHz */ +#define IEC958_AES3_CON_FS_88200	(8<<0)	/**< 88.2kHz */ +#define IEC958_AES3_CON_FS_768000	(9<<0)	/**< 768kHz */ +#define IEC958_AES3_CON_FS_96000	(10<<0)	/**< 96kHz */ +#define IEC958_AES3_CON_FS_176400	(12<<0)	/**< 176.4kHz */ +#define IEC958_AES3_CON_FS_192000	(14<<0)	/**< 192kHz */ +#define IEC958_AES3_CON_CLOCK		(3<<4)	/**< mask - clock accuracy */ +#define IEC958_AES3_CON_CLOCK_1000PPM	(0<<4)	/**< 1000 ppm */ +#define IEC958_AES3_CON_CLOCK_50PPM	(1<<4)	/**< 50 ppm */ +#define IEC958_AES3_CON_CLOCK_VARIABLE	(2<<4)	/**< variable pitch */ +#define IEC958_AES4_CON_MAX_WORDLEN_24	(1<<0)	/**< 0 = 20-bit, 1 = 24-bit */ +#define IEC958_AES4_CON_WORDLEN		(7<<1)	/**< mask - sample word length */ +#define IEC958_AES4_CON_WORDLEN_NOTID	(0<<1)	/**< not indicated */ +#define IEC958_AES4_CON_WORDLEN_20_16	(1<<1)	/**< 20-bit or 16-bit */ +#define IEC958_AES4_CON_WORDLEN_22_18	(2<<1)	/**< 22-bit or 18-bit */ +#define IEC958_AES4_CON_WORDLEN_23_19	(4<<1)	/**< 23-bit or 19-bit */ +#define IEC958_AES4_CON_WORDLEN_24_20	(5<<1)	/**< 24-bit or 20-bit */ +#define IEC958_AES4_CON_WORDLEN_21_17	(6<<1)	/**< 21-bit or 17-bit */ +#define IEC958_AES4_CON_ORIGFS		(15<<4)	/**< mask - original sample frequency */ +#define IEC958_AES4_CON_ORIGFS_NOTID	(0<<4)	/**< original sample frequency not indicated */ +#define IEC958_AES4_CON_ORIGFS_192000	(1<<4)	/**< 192kHz */ +#define IEC958_AES4_CON_ORIGFS_12000	(2<<4)	/**< 12kHz */ +#define IEC958_AES4_CON_ORIGFS_176400	(3<<4)	/**< 176.4kHz */ +#define IEC958_AES4_CON_ORIGFS_96000	(5<<4)	/**< 96kHz */ +#define IEC958_AES4_CON_ORIGFS_8000	(6<<4)	/**< 8kHz */ +#define IEC958_AES4_CON_ORIGFS_88200	(7<<4)	/**< 88.2kHz */ +#define IEC958_AES4_CON_ORIGFS_16000	(8<<4)	/**< 16kHz */ +#define IEC958_AES4_CON_ORIGFS_24000	(9<<4)	/**< 24kHz */ +#define IEC958_AES4_CON_ORIGFS_11025	(10<<4)	/**< 11.025kHz */ +#define IEC958_AES4_CON_ORIGFS_22050	(11<<4)	/**< 22.05kHz */ +#define IEC958_AES4_CON_ORIGFS_32000	(12<<4)	/**< 32kHz */ +#define IEC958_AES4_CON_ORIGFS_48000	(13<<4)	/**< 48kHz */ +#define IEC958_AES4_CON_ORIGFS_44100	(15<<4)	/**< 44.1kHz */ +#define IEC958_AES5_CON_CGMSA		(3<<0)	/**< mask - CGMS-A */ +#define IEC958_AES5_CON_CGMSA_COPYFREELY (0<<0)	/**< copying is permitted without restriction */ +#define IEC958_AES5_CON_CGMSA_COPYONCE	(1<<0)	/**< one generation of copies may be made */ +#define IEC958_AES5_CON_CGMSA_COPYNOMORE (2<<0)	/**< condition not be used */ +#define IEC958_AES5_CON_CGMSA_COPYNEVER	(3<<0)	/**< no copying is permitted */ + +/** \} */ + +/** + * \defgroup MIDI_Interface Constants for MIDI v1.0 + * Constants for MIDI v1.0. + * \{ + */ + +#define MIDI_CHANNELS			16	/**< Number of channels per port/cable. */ +#define MIDI_GM_DRUM_CHANNEL		(10-1)	/**< Channel number for GM drums. */ + +/** + * \defgroup MIDI_Commands MIDI Commands + * MIDI command codes. + * \{ + */ + +#define MIDI_CMD_NOTE_OFF		0x80	/**< note off */ +#define MIDI_CMD_NOTE_ON		0x90	/**< note on */ +#define MIDI_CMD_NOTE_PRESSURE		0xa0	/**< key pressure */ +#define MIDI_CMD_CONTROL		0xb0	/**< control change */ +#define MIDI_CMD_PGM_CHANGE		0xc0	/**< program change */ +#define MIDI_CMD_CHANNEL_PRESSURE	0xd0	/**< channel pressure */ +#define MIDI_CMD_BENDER			0xe0	/**< pitch bender */ + +#define MIDI_CMD_COMMON_SYSEX		0xf0	/**< sysex (system exclusive) begin */ +#define MIDI_CMD_COMMON_MTC_QUARTER	0xf1	/**< MTC quarter frame */ +#define MIDI_CMD_COMMON_SONG_POS	0xf2	/**< song position */ +#define MIDI_CMD_COMMON_SONG_SELECT	0xf3	/**< song select */ +#define MIDI_CMD_COMMON_TUNE_REQUEST	0xf6	/**< tune request */ +#define MIDI_CMD_COMMON_SYSEX_END	0xf7	/**< end of sysex */ +#define MIDI_CMD_COMMON_CLOCK		0xf8	/**< clock */ +#define MIDI_CMD_COMMON_START		0xfa	/**< start */ +#define MIDI_CMD_COMMON_CONTINUE	0xfb	/**< continue */ +#define MIDI_CMD_COMMON_STOP		0xfc	/**< stop */ +#define MIDI_CMD_COMMON_SENSING		0xfe	/**< active sensing */ +#define MIDI_CMD_COMMON_RESET		0xff	/**< reset */ + +/** \} */ + +/** + * \defgroup MIDI_Controllers MIDI Controllers + * MIDI controller numbers. + * \{ + */ + +#define MIDI_CTL_MSB_BANK		0x00	/**< Bank selection */ +#define MIDI_CTL_MSB_MODWHEEL         	0x01	/**< Modulation */ +#define MIDI_CTL_MSB_BREATH           	0x02	/**< Breath */ +#define MIDI_CTL_MSB_FOOT             	0x04	/**< Foot */ +#define MIDI_CTL_MSB_PORTAMENTO_TIME 	0x05	/**< Portamento time */ +#define MIDI_CTL_MSB_DATA_ENTRY		0x06	/**< Data entry */ +#define MIDI_CTL_MSB_MAIN_VOLUME      	0x07	/**< Main volume */ +#define MIDI_CTL_MSB_BALANCE          	0x08	/**< Balance */ +#define MIDI_CTL_MSB_PAN              	0x0a	/**< Panpot */ +#define MIDI_CTL_MSB_EXPRESSION       	0x0b	/**< Expression */ +#define MIDI_CTL_MSB_EFFECT1		0x0c	/**< Effect1 */ +#define MIDI_CTL_MSB_EFFECT2		0x0d	/**< Effect2 */ +#define MIDI_CTL_MSB_GENERAL_PURPOSE1 	0x10	/**< General purpose 1 */ +#define MIDI_CTL_MSB_GENERAL_PURPOSE2 	0x11	/**< General purpose 2 */ +#define MIDI_CTL_MSB_GENERAL_PURPOSE3 	0x12	/**< General purpose 3 */ +#define MIDI_CTL_MSB_GENERAL_PURPOSE4 	0x13	/**< General purpose 4 */ +#define MIDI_CTL_LSB_BANK		0x20	/**< Bank selection */ +#define MIDI_CTL_LSB_MODWHEEL        	0x21	/**< Modulation */ +#define MIDI_CTL_LSB_BREATH           	0x22	/**< Breath */ +#define MIDI_CTL_LSB_FOOT             	0x24	/**< Foot */ +#define MIDI_CTL_LSB_PORTAMENTO_TIME 	0x25	/**< Portamento time */ +#define MIDI_CTL_LSB_DATA_ENTRY		0x26	/**< Data entry */ +#define MIDI_CTL_LSB_MAIN_VOLUME      	0x27	/**< Main volume */ +#define MIDI_CTL_LSB_BALANCE          	0x28	/**< Balance */ +#define MIDI_CTL_LSB_PAN              	0x2a	/**< Panpot */ +#define MIDI_CTL_LSB_EXPRESSION       	0x2b	/**< Expression */ +#define MIDI_CTL_LSB_EFFECT1		0x2c	/**< Effect1 */ +#define MIDI_CTL_LSB_EFFECT2		0x2d	/**< Effect2 */ +#define MIDI_CTL_LSB_GENERAL_PURPOSE1 	0x30	/**< General purpose 1 */ +#define MIDI_CTL_LSB_GENERAL_PURPOSE2 	0x31	/**< General purpose 2 */ +#define MIDI_CTL_LSB_GENERAL_PURPOSE3 	0x32	/**< General purpose 3 */ +#define MIDI_CTL_LSB_GENERAL_PURPOSE4 	0x33	/**< General purpose 4 */ +#define MIDI_CTL_SUSTAIN              	0x40	/**< Sustain pedal */ +#define MIDI_CTL_PORTAMENTO           	0x41	/**< Portamento */ +#define MIDI_CTL_SOSTENUTO            	0x42	/**< Sostenuto */ +#define MIDI_CTL_SUSTENUTO            	0x42	/**< Sostenuto (a typo in the older version) */ +#define MIDI_CTL_SOFT_PEDAL           	0x43	/**< Soft pedal */ +#define MIDI_CTL_LEGATO_FOOTSWITCH	0x44	/**< Legato foot switch */ +#define MIDI_CTL_HOLD2                	0x45	/**< Hold2 */ +#define MIDI_CTL_SC1_SOUND_VARIATION	0x46	/**< SC1 Sound Variation */ +#define MIDI_CTL_SC2_TIMBRE		0x47	/**< SC2 Timbre */ +#define MIDI_CTL_SC3_RELEASE_TIME	0x48	/**< SC3 Release Time */ +#define MIDI_CTL_SC4_ATTACK_TIME	0x49	/**< SC4 Attack Time */ +#define MIDI_CTL_SC5_BRIGHTNESS		0x4a	/**< SC5 Brightness */ +#define MIDI_CTL_SC6			0x4b	/**< SC6 */ +#define MIDI_CTL_SC7			0x4c	/**< SC7 */ +#define MIDI_CTL_SC8			0x4d	/**< SC8 */ +#define MIDI_CTL_SC9			0x4e	/**< SC9 */ +#define MIDI_CTL_SC10			0x4f	/**< SC10 */ +#define MIDI_CTL_GENERAL_PURPOSE5     	0x50	/**< General purpose 5 */ +#define MIDI_CTL_GENERAL_PURPOSE6     	0x51	/**< General purpose 6 */ +#define MIDI_CTL_GENERAL_PURPOSE7     	0x52	/**< General purpose 7 */ +#define MIDI_CTL_GENERAL_PURPOSE8     	0x53	/**< General purpose 8 */ +#define MIDI_CTL_PORTAMENTO_CONTROL	0x54	/**< Portamento control */ +#define MIDI_CTL_E1_REVERB_DEPTH	0x5b	/**< E1 Reverb Depth */ +#define MIDI_CTL_E2_TREMOLO_DEPTH	0x5c	/**< E2 Tremolo Depth */ +#define MIDI_CTL_E3_CHORUS_DEPTH	0x5d	/**< E3 Chorus Depth */ +#define MIDI_CTL_E4_DETUNE_DEPTH	0x5e	/**< E4 Detune Depth */ +#define MIDI_CTL_E5_PHASER_DEPTH	0x5f	/**< E5 Phaser Depth */ +#define MIDI_CTL_DATA_INCREMENT       	0x60	/**< Data Increment */ +#define MIDI_CTL_DATA_DECREMENT       	0x61	/**< Data Decrement */ +#define MIDI_CTL_NONREG_PARM_NUM_LSB  	0x62	/**< Non-registered parameter number */ +#define MIDI_CTL_NONREG_PARM_NUM_MSB  	0x63	/**< Non-registered parameter number */ +#define MIDI_CTL_REGIST_PARM_NUM_LSB  	0x64	/**< Registered parameter number */ +#define MIDI_CTL_REGIST_PARM_NUM_MSB	0x65	/**< Registered parameter number */ +#define MIDI_CTL_ALL_SOUNDS_OFF		0x78	/**< All sounds off */ +#define MIDI_CTL_RESET_CONTROLLERS	0x79	/**< Reset Controllers */ +#define MIDI_CTL_LOCAL_CONTROL_SWITCH	0x7a	/**< Local control switch */ +#define MIDI_CTL_ALL_NOTES_OFF		0x7b	/**< All notes off */ +#define MIDI_CTL_OMNI_OFF		0x7c	/**< Omni off */ +#define MIDI_CTL_OMNI_ON		0x7d	/**< Omni on */ +#define MIDI_CTL_MONO1			0x7e	/**< Mono1 */ +#define MIDI_CTL_MONO2			0x7f	/**< Mono2 */ + +/** \} */ + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_ASOUNDEF_H */ diff --git a/include/alsa/asoundlib.h b/include/alsa/asoundlib.h new file mode 100644 index 0000000..94dfb7b --- /dev/null +++ b/include/alsa/asoundlib.h @@ -0,0 +1,65 @@ +/** + * \file include/asoundlib.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ASOUNDLIB_H +#define __ASOUNDLIB_H + +#include <unistd.h> +#include <stdio.h> +#include <stdlib.h> +#include <sys/types.h> +#include <string.h> +#include <fcntl.h> +#include <assert.h> +#include <poll.h> +#include <errno.h> +#include <stdarg.h> +#include <endian.h> + +#ifndef __GNUC__ +#define __inline__ inline +#endif + +#include <alsa/asoundef.h> +#include <alsa/version.h> +#include <alsa/global.h> +#include <alsa/input.h> +#include <alsa/output.h> +#include <alsa/error.h> +#include <alsa/conf.h> +#include <alsa/pcm.h> +#include <alsa/rawmidi.h> +#include <alsa/timer.h> +#include <alsa/hwdep.h> +#include <alsa/control.h> +#include <alsa/mixer.h> +#include <alsa/seq_event.h> +#include <alsa/seq.h> +#include <alsa/seqmid.h> +#include <alsa/seq_midi_event.h> + +#endif /* __ASOUNDLIB_H */ diff --git a/include/alsa/conf.h b/include/alsa/conf.h new file mode 100644 index 0000000..e4e2d7b --- /dev/null +++ b/include/alsa/conf.h @@ -0,0 +1,214 @@ +/** + * \file include/conf.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_CONF_H +#define __ALSA_CONF_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Config Configuration Interface + *  The configuration functions and types allow you to read, enumerate, + *  modify and write the contents of ALSA configuration files. + *  \{ + */ + +/** \brief \c dlsym version for the config evaluate callback. */ +#define SND_CONFIG_DLSYM_VERSION_EVALUATE	_dlsym_config_evaluate_001 +/** \brief \c dlsym version for the config hook callback. */ +#define SND_CONFIG_DLSYM_VERSION_HOOK		_dlsym_config_hook_001 + +/** \brief Configuration node type. */ +typedef enum _snd_config_type { +	/** Integer number. */ +        SND_CONFIG_TYPE_INTEGER, +	/** 64-bit integer number. */ +        SND_CONFIG_TYPE_INTEGER64, +	/** Real number. */ +        SND_CONFIG_TYPE_REAL, +	/** Character string. */ +        SND_CONFIG_TYPE_STRING, +        /** Pointer (runtime only, cannot be saved). */ +        SND_CONFIG_TYPE_POINTER, +	/** Compound node. */ +	SND_CONFIG_TYPE_COMPOUND = 1024 +} snd_config_type_t; + +/** + * \brief Internal structure for a configuration node object. + * + * The ALSA library uses a pointer to this structure as a handle to a + * configuration node. Applications don't access its contents directly. + */ +typedef struct _snd_config snd_config_t; +/** + * \brief Type for a configuration compound iterator. + * + * The ALSA library uses this pointer type as a handle to a configuration + * compound iterator. Applications don't directly access the contents of + * the structure pointed to by this type. + */ +typedef struct _snd_config_iterator *snd_config_iterator_t; +/** + * \brief Internal structure for a configuration private update object. + * + * The ALSA library uses this structure to save private update information. + */ +typedef struct _snd_config_update snd_config_update_t; + +extern snd_config_t *snd_config; + +const char *snd_config_topdir(void); + +int snd_config_top(snd_config_t **config); + +int snd_config_load(snd_config_t *config, snd_input_t *in); +int snd_config_load_override(snd_config_t *config, snd_input_t *in); +int snd_config_save(snd_config_t *config, snd_output_t *out); +int snd_config_update(void); +int snd_config_update_r(snd_config_t **top, snd_config_update_t **update, const char *path); +int snd_config_update_free(snd_config_update_t *update); +int snd_config_update_free_global(void); + +int snd_config_update_ref(snd_config_t **top); +void snd_config_ref(snd_config_t *top); +void snd_config_unref(snd_config_t *top); + +int snd_config_search(snd_config_t *config, const char *key, +		      snd_config_t **result); +int snd_config_searchv(snd_config_t *config,  +		       snd_config_t **result, ...); +int snd_config_search_definition(snd_config_t *config, +				 const char *base, const char *key, +				 snd_config_t **result); + +int snd_config_expand(snd_config_t *config, snd_config_t *root, +		      const char *args, snd_config_t *private_data, +		      snd_config_t **result); +int snd_config_evaluate(snd_config_t *config, snd_config_t *root, +			snd_config_t *private_data, snd_config_t **result); + +int snd_config_add(snd_config_t *config, snd_config_t *leaf); +int snd_config_delete(snd_config_t *config); +int snd_config_delete_compound_members(const snd_config_t *config); +int snd_config_copy(snd_config_t **dst, snd_config_t *src); + +int snd_config_make(snd_config_t **config, const char *key, +		    snd_config_type_t type); +int snd_config_make_integer(snd_config_t **config, const char *key); +int snd_config_make_integer64(snd_config_t **config, const char *key); +int snd_config_make_real(snd_config_t **config, const char *key); +int snd_config_make_string(snd_config_t **config, const char *key); +int snd_config_make_pointer(snd_config_t **config, const char *key); +int snd_config_make_compound(snd_config_t **config, const char *key, int join); + +int snd_config_imake_integer(snd_config_t **config, const char *key, const long value); +int snd_config_imake_integer64(snd_config_t **config, const char *key, const long long value); +int snd_config_imake_real(snd_config_t **config, const char *key, const double value); +int snd_config_imake_string(snd_config_t **config, const char *key, const char *ascii); +int snd_config_imake_safe_string(snd_config_t **config, const char *key, const char *ascii); +int snd_config_imake_pointer(snd_config_t **config, const char *key, const void *ptr); + +snd_config_type_t snd_config_get_type(const snd_config_t *config); + +int snd_config_set_id(snd_config_t *config, const char *id); +int snd_config_set_integer(snd_config_t *config, long value); +int snd_config_set_integer64(snd_config_t *config, long long value); +int snd_config_set_real(snd_config_t *config, double value); +int snd_config_set_string(snd_config_t *config, const char *value); +int snd_config_set_ascii(snd_config_t *config, const char *ascii); +int snd_config_set_pointer(snd_config_t *config, const void *ptr); +int snd_config_get_id(const snd_config_t *config, const char **value); +int snd_config_get_integer(const snd_config_t *config, long *value); +int snd_config_get_integer64(const snd_config_t *config, long long *value); +int snd_config_get_real(const snd_config_t *config, double *value); +int snd_config_get_ireal(const snd_config_t *config, double *value); +int snd_config_get_string(const snd_config_t *config, const char **value); +int snd_config_get_ascii(const snd_config_t *config, char **value); +int snd_config_get_pointer(const snd_config_t *config, const void **value); +int snd_config_test_id(const snd_config_t *config, const char *id); + +snd_config_iterator_t snd_config_iterator_first(const snd_config_t *node); +snd_config_iterator_t snd_config_iterator_next(const snd_config_iterator_t iterator); +snd_config_iterator_t snd_config_iterator_end(const snd_config_t *node); +snd_config_t *snd_config_iterator_entry(const snd_config_iterator_t iterator); + +/** + * \brief Helper macro to iterate over the children of a compound node. + * \param[in,out] pos Iterator variable for the current node. + * \param[in,out] next Temporary iterator variable for the next node. + * \param[in] node Handle to the compound configuration node to iterate over. + * + * Use this macro like a \c for statement, e.g.: + * \code + * snd_config_iterator_t pos, next; + * snd_config_for_each(pos, next, node) { + *     snd_config_t *entry = snd_config_iterator_entry(pos); + *     ... + * } + * \endcode + * + * This macro allows deleting or removing the current node. + */ +#define snd_config_for_each(pos, next, node) \ +	for (pos = snd_config_iterator_first(node), next = snd_config_iterator_next(pos); pos != snd_config_iterator_end(node); pos = next, next = snd_config_iterator_next(pos)) + +/* Misc functions */ + +int snd_config_get_bool_ascii(const char *ascii); +int snd_config_get_bool(const snd_config_t *conf); +int snd_config_get_ctl_iface_ascii(const char *ascii); +int snd_config_get_ctl_iface(const snd_config_t *conf); + +/* Names functions */ + +/** + * Device-name list element + */ +typedef struct snd_devname snd_devname_t; + +/** + * Device-name list element (definition) + */ +struct snd_devname { +	char *name;	/**< Device name string */ +	char *comment;	/**< Comments */ +	snd_devname_t *next;	/**< Next pointer */ +}; + +int snd_names_list(const char *iface, snd_devname_t **list); +void snd_names_list_free(snd_devname_t *list); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_CONF_H */ diff --git a/include/alsa/control.h b/include/alsa/control.h new file mode 100644 index 0000000..02db72d --- /dev/null +++ b/include/alsa/control.h @@ -0,0 +1,622 @@ +/** + * \file include/control.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_CONTROL_H +#define __ALSA_CONTROL_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Control Control Interface + *  The control interface. + *  See \ref control page for more details. + *  \{ + */ + +/** dlsym version for interface entry callback */ +#define SND_CONTROL_DLSYM_VERSION	_dlsym_control_001 + +/** IEC958 structure */ +typedef struct snd_aes_iec958 { +	unsigned char status[24];	/**< AES/IEC958 channel status bits */ +	unsigned char subcode[147];	/**< AES/IEC958 subcode bits */ +	unsigned char pad;		/**< nothing */ +	unsigned char dig_subframe[4];	/**< AES/IEC958 subframe bits */ +} snd_aes_iec958_t; + +/** CTL card info container */ +typedef struct _snd_ctl_card_info snd_ctl_card_info_t; + +/** CTL element identifier container */ +typedef struct _snd_ctl_elem_id snd_ctl_elem_id_t; + +/** CTL element identifier list container */ +typedef struct _snd_ctl_elem_list snd_ctl_elem_list_t; + +/** CTL element info container */ +typedef struct _snd_ctl_elem_info snd_ctl_elem_info_t; + +/** CTL element value container */ +typedef struct _snd_ctl_elem_value snd_ctl_elem_value_t; + +/** CTL event container */ +typedef struct _snd_ctl_event snd_ctl_event_t; + +/** CTL element type */ +typedef enum _snd_ctl_elem_type { +	/** Invalid type */ +	SND_CTL_ELEM_TYPE_NONE = 0, +	/** Boolean contents */ +	SND_CTL_ELEM_TYPE_BOOLEAN, +	/** Integer contents */ +	SND_CTL_ELEM_TYPE_INTEGER, +	/** Enumerated contents */ +	SND_CTL_ELEM_TYPE_ENUMERATED, +	/** Bytes contents */ +	SND_CTL_ELEM_TYPE_BYTES, +	/** IEC958 (S/PDIF) setting content */ +	SND_CTL_ELEM_TYPE_IEC958, +	/** 64-bit integer contents */ +	SND_CTL_ELEM_TYPE_INTEGER64, +	SND_CTL_ELEM_TYPE_LAST = SND_CTL_ELEM_TYPE_INTEGER64 +} snd_ctl_elem_type_t; + +/** CTL related interface */ +typedef enum _snd_ctl_elem_iface { +	/** Card level */ +	SND_CTL_ELEM_IFACE_CARD = 0, +	/** Hardware dependent device */ +	SND_CTL_ELEM_IFACE_HWDEP, +	/** Mixer */ +	SND_CTL_ELEM_IFACE_MIXER, +	/** PCM */ +	SND_CTL_ELEM_IFACE_PCM, +	/** RawMidi */ +	SND_CTL_ELEM_IFACE_RAWMIDI, +	/** Timer */ +	SND_CTL_ELEM_IFACE_TIMER, +	/** Sequencer */ +	SND_CTL_ELEM_IFACE_SEQUENCER, +	SND_CTL_ELEM_IFACE_LAST = SND_CTL_ELEM_IFACE_SEQUENCER +} snd_ctl_elem_iface_t; + +/** Event class */ +typedef enum _snd_ctl_event_type { +	/** Elements related event */ +	SND_CTL_EVENT_ELEM = 0, +	SND_CTL_EVENT_LAST = SND_CTL_EVENT_ELEM +}snd_ctl_event_type_t; + +/** Element has been removed (Warning: test this first and if set don't +  * test the other masks) \hideinitializer */ +#define SND_CTL_EVENT_MASK_REMOVE 	(~0U) +/** Element value has been changed \hideinitializer */ +#define SND_CTL_EVENT_MASK_VALUE	(1<<0) +/** Element info has been changed \hideinitializer */ +#define SND_CTL_EVENT_MASK_INFO		(1<<1) +/** Element has been added \hideinitializer */ +#define SND_CTL_EVENT_MASK_ADD		(1<<2) +/** Element's TLV value has been changed \hideinitializer */ +#define SND_CTL_EVENT_MASK_TLV		(1<<3) + +/** CTL name helper */ +#define SND_CTL_NAME_NONE				"" +/** CTL name helper */ +#define SND_CTL_NAME_PLAYBACK				"Playback " +/** CTL name helper */ +#define SND_CTL_NAME_CAPTURE				"Capture " + +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_NONE			"" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_SWITCH			"Switch" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_VOLUME			"Volume" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_DEFAULT			"Default" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_MASK			"Mask" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_CON_MASK			"Con Mask" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_PRO_MASK			"Pro Mask" +/** CTL name helper */ +#define SND_CTL_NAME_IEC958_PCM_STREAM			"PCM Stream" +/** Element name for IEC958 (S/PDIF) */ +#define SND_CTL_NAME_IEC958(expl,direction,what)	"IEC958 " expl SND_CTL_NAME_##direction SND_CTL_NAME_IEC958_##what + +/** Mask for the major Power State identifier */ +#define SND_CTL_POWER_MASK		0xff00 +/** ACPI/PCI Power State D0 */ +#define SND_CTL_POWER_D0          	0x0000 +/** ACPI/PCI Power State D1 */ +#define SND_CTL_POWER_D1     	     	0x0100 +/** ACPI/PCI Power State D2 */ +#define SND_CTL_POWER_D2 	        0x0200 +/** ACPI/PCI Power State D3 */ +#define SND_CTL_POWER_D3         	0x0300 +/** ACPI/PCI Power State D3hot */ +#define SND_CTL_POWER_D3hot		(SND_CTL_POWER_D3|0x0000) +/** ACPI/PCI Power State D3cold */ +#define SND_CTL_POWER_D3cold	      	(SND_CTL_POWER_D3|0x0001) + +/** TLV type - Container */ +#define SND_CTL_TLVT_CONTAINER		0x0000 +/** TLV type - basic dB scale */ +#define SND_CTL_TLVT_DB_SCALE		0x0001 +/** TLV type - linear volume */ +#define SND_CTL_TLVT_DB_LINEAR		0x0002 +/** TLV type - dB range container */ +#define SND_CTL_TLVT_DB_RANGE		0x0003 +/** TLV type - dB scale specified by min/max values */ +#define SND_CTL_TLVT_DB_MINMAX		0x0004 +/** TLV type - dB scale specified by min/max values (with mute) */ +#define SND_CTL_TLVT_DB_MINMAX_MUTE	0x0005 + +/** Mute state */ +#define SND_CTL_TLV_DB_GAIN_MUTE	-9999999 + +/** TLV type - fixed channel map positions */ +#define SND_CTL_TLVT_CHMAP_FIXED	0x00101 +/** TLV type - freely swappable channel map positions */ +#define SND_CTL_TLVT_CHMAP_VAR		0x00102 +/** TLV type - pair-wise swappable channel map positions */ +#define SND_CTL_TLVT_CHMAP_PAIRED	0x00103 + +/** CTL type */ +typedef enum _snd_ctl_type { +	/** Kernel level CTL */ +	SND_CTL_TYPE_HW, +	/** Shared memory client CTL */ +	SND_CTL_TYPE_SHM, +	/** INET client CTL (not yet implemented) */ +	SND_CTL_TYPE_INET, +	/** External control plugin */ +	SND_CTL_TYPE_EXT +} snd_ctl_type_t; + +/** Non blocking mode (flag for open mode) \hideinitializer */ +#define SND_CTL_NONBLOCK		0x0001 + +/** Async notification (flag for open mode) \hideinitializer */ +#define SND_CTL_ASYNC			0x0002 + +/** Read only (flag for open mode) \hideinitializer */ +#define SND_CTL_READONLY		0x0004 + +/** CTL handle */ +typedef struct _snd_ctl snd_ctl_t; + +/** Don't destroy the ctl handle when close */ +#define SND_SCTL_NOFREE			0x0001 + +/** SCTL type */ +typedef struct _snd_sctl snd_sctl_t; + +int snd_card_load(int card); +int snd_card_next(int *card); +int snd_card_get_index(const char *name); +int snd_card_get_name(int card, char **name); +int snd_card_get_longname(int card, char **name); + +int snd_device_name_hint(int card, const char *iface, void ***hints); +int snd_device_name_free_hint(void **hints); +char *snd_device_name_get_hint(const void *hint, const char *id); + +int snd_ctl_open(snd_ctl_t **ctl, const char *name, int mode); +int snd_ctl_open_lconf(snd_ctl_t **ctl, const char *name, int mode, snd_config_t *lconf); +int snd_ctl_open_fallback(snd_ctl_t **ctl, snd_config_t *root, const char *name, const char *orig_name, int mode); +int snd_ctl_close(snd_ctl_t *ctl); +int snd_ctl_nonblock(snd_ctl_t *ctl, int nonblock); +static __inline__ int snd_ctl_abort(snd_ctl_t *ctl) { return snd_ctl_nonblock(ctl, 2); } +int snd_async_add_ctl_handler(snd_async_handler_t **handler, snd_ctl_t *ctl,  +			      snd_async_callback_t callback, void *private_data); +snd_ctl_t *snd_async_handler_get_ctl(snd_async_handler_t *handler); +int snd_ctl_poll_descriptors_count(snd_ctl_t *ctl); +int snd_ctl_poll_descriptors(snd_ctl_t *ctl, struct pollfd *pfds, unsigned int space); +int snd_ctl_poll_descriptors_revents(snd_ctl_t *ctl, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +int snd_ctl_subscribe_events(snd_ctl_t *ctl, int subscribe); +int snd_ctl_card_info(snd_ctl_t *ctl, snd_ctl_card_info_t *info); +int snd_ctl_elem_list(snd_ctl_t *ctl, snd_ctl_elem_list_t *list); +int snd_ctl_elem_info(snd_ctl_t *ctl, snd_ctl_elem_info_t *info); +int snd_ctl_elem_read(snd_ctl_t *ctl, snd_ctl_elem_value_t *data); +int snd_ctl_elem_write(snd_ctl_t *ctl, snd_ctl_elem_value_t *data); +int snd_ctl_elem_lock(snd_ctl_t *ctl, snd_ctl_elem_id_t *id); +int snd_ctl_elem_unlock(snd_ctl_t *ctl, snd_ctl_elem_id_t *id); +int snd_ctl_elem_tlv_read(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, +			  unsigned int *tlv, unsigned int tlv_size); +int snd_ctl_elem_tlv_write(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, +			   const unsigned int *tlv); +int snd_ctl_elem_tlv_command(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, +			     const unsigned int *tlv); +#ifdef __ALSA_HWDEP_H +int snd_ctl_hwdep_next_device(snd_ctl_t *ctl, int * device); +int snd_ctl_hwdep_info(snd_ctl_t *ctl, snd_hwdep_info_t * info); +#endif +#ifdef __ALSA_PCM_H +int snd_ctl_pcm_next_device(snd_ctl_t *ctl, int *device); +int snd_ctl_pcm_info(snd_ctl_t *ctl, snd_pcm_info_t * info); +int snd_ctl_pcm_prefer_subdevice(snd_ctl_t *ctl, int subdev); +#endif +#ifdef __ALSA_RAWMIDI_H +int snd_ctl_rawmidi_next_device(snd_ctl_t *ctl, int * device); +int snd_ctl_rawmidi_info(snd_ctl_t *ctl, snd_rawmidi_info_t * info); +int snd_ctl_rawmidi_prefer_subdevice(snd_ctl_t *ctl, int subdev); +#endif +int snd_ctl_set_power_state(snd_ctl_t *ctl, unsigned int state); +int snd_ctl_get_power_state(snd_ctl_t *ctl, unsigned int *state); + +int snd_ctl_read(snd_ctl_t *ctl, snd_ctl_event_t *event); +int snd_ctl_wait(snd_ctl_t *ctl, int timeout); +const char *snd_ctl_name(snd_ctl_t *ctl); +snd_ctl_type_t snd_ctl_type(snd_ctl_t *ctl); + +const char *snd_ctl_elem_type_name(snd_ctl_elem_type_t type); +const char *snd_ctl_elem_iface_name(snd_ctl_elem_iface_t iface); +const char *snd_ctl_event_type_name(snd_ctl_event_type_t type); + +unsigned int snd_ctl_event_elem_get_mask(const snd_ctl_event_t *obj); +unsigned int snd_ctl_event_elem_get_numid(const snd_ctl_event_t *obj); +void snd_ctl_event_elem_get_id(const snd_ctl_event_t *obj, snd_ctl_elem_id_t *ptr); +snd_ctl_elem_iface_t snd_ctl_event_elem_get_interface(const snd_ctl_event_t *obj); +unsigned int snd_ctl_event_elem_get_device(const snd_ctl_event_t *obj); +unsigned int snd_ctl_event_elem_get_subdevice(const snd_ctl_event_t *obj); +const char *snd_ctl_event_elem_get_name(const snd_ctl_event_t *obj); +unsigned int snd_ctl_event_elem_get_index(const snd_ctl_event_t *obj); + +int snd_ctl_elem_list_alloc_space(snd_ctl_elem_list_t *obj, unsigned int entries); +void snd_ctl_elem_list_free_space(snd_ctl_elem_list_t *obj); + +char *snd_ctl_ascii_elem_id_get(snd_ctl_elem_id_t *id); +int snd_ctl_ascii_elem_id_parse(snd_ctl_elem_id_t *dst, const char *str); +int snd_ctl_ascii_value_parse(snd_ctl_t *handle, +			      snd_ctl_elem_value_t *dst, +			      snd_ctl_elem_info_t *info, +			      const char *value); + +size_t snd_ctl_elem_id_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_ctl_elem_id_t using standard alloca + * \param ptr returned pointer + */ +#define snd_ctl_elem_id_alloca(ptr) __snd_alloca(ptr, snd_ctl_elem_id) +int snd_ctl_elem_id_malloc(snd_ctl_elem_id_t **ptr); +void snd_ctl_elem_id_free(snd_ctl_elem_id_t *obj); +void snd_ctl_elem_id_clear(snd_ctl_elem_id_t *obj); +void snd_ctl_elem_id_copy(snd_ctl_elem_id_t *dst, const snd_ctl_elem_id_t *src); +unsigned int snd_ctl_elem_id_get_numid(const snd_ctl_elem_id_t *obj); +snd_ctl_elem_iface_t snd_ctl_elem_id_get_interface(const snd_ctl_elem_id_t *obj); +unsigned int snd_ctl_elem_id_get_device(const snd_ctl_elem_id_t *obj); +unsigned int snd_ctl_elem_id_get_subdevice(const snd_ctl_elem_id_t *obj); +const char *snd_ctl_elem_id_get_name(const snd_ctl_elem_id_t *obj); +unsigned int snd_ctl_elem_id_get_index(const snd_ctl_elem_id_t *obj); +void snd_ctl_elem_id_set_numid(snd_ctl_elem_id_t *obj, unsigned int val); +void snd_ctl_elem_id_set_interface(snd_ctl_elem_id_t *obj, snd_ctl_elem_iface_t val); +void snd_ctl_elem_id_set_device(snd_ctl_elem_id_t *obj, unsigned int val); +void snd_ctl_elem_id_set_subdevice(snd_ctl_elem_id_t *obj, unsigned int val); +void snd_ctl_elem_id_set_name(snd_ctl_elem_id_t *obj, const char *val); +void snd_ctl_elem_id_set_index(snd_ctl_elem_id_t *obj, unsigned int val); + +size_t snd_ctl_card_info_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_ctl_card_info_t using standard alloca + * \param ptr returned pointer + */ +#define snd_ctl_card_info_alloca(ptr) __snd_alloca(ptr, snd_ctl_card_info) +int snd_ctl_card_info_malloc(snd_ctl_card_info_t **ptr); +void snd_ctl_card_info_free(snd_ctl_card_info_t *obj); +void snd_ctl_card_info_clear(snd_ctl_card_info_t *obj); +void snd_ctl_card_info_copy(snd_ctl_card_info_t *dst, const snd_ctl_card_info_t *src); +int snd_ctl_card_info_get_card(const snd_ctl_card_info_t *obj); +const char *snd_ctl_card_info_get_id(const snd_ctl_card_info_t *obj); +const char *snd_ctl_card_info_get_driver(const snd_ctl_card_info_t *obj); +const char *snd_ctl_card_info_get_name(const snd_ctl_card_info_t *obj); +const char *snd_ctl_card_info_get_longname(const snd_ctl_card_info_t *obj); +const char *snd_ctl_card_info_get_mixername(const snd_ctl_card_info_t *obj); +const char *snd_ctl_card_info_get_components(const snd_ctl_card_info_t *obj); + +size_t snd_ctl_event_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_ctl_event_t using standard alloca + * \param ptr returned pointer + */ +#define snd_ctl_event_alloca(ptr) __snd_alloca(ptr, snd_ctl_event) +int snd_ctl_event_malloc(snd_ctl_event_t **ptr); +void snd_ctl_event_free(snd_ctl_event_t *obj); +void snd_ctl_event_clear(snd_ctl_event_t *obj); +void snd_ctl_event_copy(snd_ctl_event_t *dst, const snd_ctl_event_t *src); +snd_ctl_event_type_t snd_ctl_event_get_type(const snd_ctl_event_t *obj); + +size_t snd_ctl_elem_list_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_ctl_elem_list_t using standard alloca + * \param ptr returned pointer + */ +#define snd_ctl_elem_list_alloca(ptr) __snd_alloca(ptr, snd_ctl_elem_list) +int snd_ctl_elem_list_malloc(snd_ctl_elem_list_t **ptr); +void snd_ctl_elem_list_free(snd_ctl_elem_list_t *obj); +void snd_ctl_elem_list_clear(snd_ctl_elem_list_t *obj); +void snd_ctl_elem_list_copy(snd_ctl_elem_list_t *dst, const snd_ctl_elem_list_t *src); +void snd_ctl_elem_list_set_offset(snd_ctl_elem_list_t *obj, unsigned int val); +unsigned int snd_ctl_elem_list_get_used(const snd_ctl_elem_list_t *obj); +unsigned int snd_ctl_elem_list_get_count(const snd_ctl_elem_list_t *obj); +void snd_ctl_elem_list_get_id(const snd_ctl_elem_list_t *obj, unsigned int idx, snd_ctl_elem_id_t *ptr); +unsigned int snd_ctl_elem_list_get_numid(const snd_ctl_elem_list_t *obj, unsigned int idx); +snd_ctl_elem_iface_t snd_ctl_elem_list_get_interface(const snd_ctl_elem_list_t *obj, unsigned int idx); +unsigned int snd_ctl_elem_list_get_device(const snd_ctl_elem_list_t *obj, unsigned int idx); +unsigned int snd_ctl_elem_list_get_subdevice(const snd_ctl_elem_list_t *obj, unsigned int idx); +const char *snd_ctl_elem_list_get_name(const snd_ctl_elem_list_t *obj, unsigned int idx); +unsigned int snd_ctl_elem_list_get_index(const snd_ctl_elem_list_t *obj, unsigned int idx); + +size_t snd_ctl_elem_info_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_ctl_elem_info_t using standard alloca + * \param ptr returned pointer + */ +#define snd_ctl_elem_info_alloca(ptr) __snd_alloca(ptr, snd_ctl_elem_info) +int snd_ctl_elem_info_malloc(snd_ctl_elem_info_t **ptr); +void snd_ctl_elem_info_free(snd_ctl_elem_info_t *obj); +void snd_ctl_elem_info_clear(snd_ctl_elem_info_t *obj); +void snd_ctl_elem_info_copy(snd_ctl_elem_info_t *dst, const snd_ctl_elem_info_t *src); +snd_ctl_elem_type_t snd_ctl_elem_info_get_type(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_readable(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_writable(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_volatile(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_inactive(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_locked(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_tlv_readable(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_tlv_writable(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_tlv_commandable(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_owner(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_is_user(const snd_ctl_elem_info_t *obj); +pid_t snd_ctl_elem_info_get_owner(const snd_ctl_elem_info_t *obj); +unsigned int snd_ctl_elem_info_get_count(const snd_ctl_elem_info_t *obj); +long snd_ctl_elem_info_get_min(const snd_ctl_elem_info_t *obj); +long snd_ctl_elem_info_get_max(const snd_ctl_elem_info_t *obj); +long snd_ctl_elem_info_get_step(const snd_ctl_elem_info_t *obj); +long long snd_ctl_elem_info_get_min64(const snd_ctl_elem_info_t *obj); +long long snd_ctl_elem_info_get_max64(const snd_ctl_elem_info_t *obj); +long long snd_ctl_elem_info_get_step64(const snd_ctl_elem_info_t *obj); +unsigned int snd_ctl_elem_info_get_items(const snd_ctl_elem_info_t *obj); +void snd_ctl_elem_info_set_item(snd_ctl_elem_info_t *obj, unsigned int val); +const char *snd_ctl_elem_info_get_item_name(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_get_dimensions(const snd_ctl_elem_info_t *obj); +int snd_ctl_elem_info_get_dimension(const snd_ctl_elem_info_t *obj, unsigned int idx); +int snd_ctl_elem_info_set_dimension(snd_ctl_elem_info_t *info, +				    const int dimension[4]); +void snd_ctl_elem_info_get_id(const snd_ctl_elem_info_t *obj, snd_ctl_elem_id_t *ptr); +unsigned int snd_ctl_elem_info_get_numid(const snd_ctl_elem_info_t *obj); +snd_ctl_elem_iface_t snd_ctl_elem_info_get_interface(const snd_ctl_elem_info_t *obj); +unsigned int snd_ctl_elem_info_get_device(const snd_ctl_elem_info_t *obj); +unsigned int snd_ctl_elem_info_get_subdevice(const snd_ctl_elem_info_t *obj); +const char *snd_ctl_elem_info_get_name(const snd_ctl_elem_info_t *obj); +unsigned int snd_ctl_elem_info_get_index(const snd_ctl_elem_info_t *obj); +void snd_ctl_elem_info_set_id(snd_ctl_elem_info_t *obj, const snd_ctl_elem_id_t *ptr); +void snd_ctl_elem_info_set_numid(snd_ctl_elem_info_t *obj, unsigned int val); +void snd_ctl_elem_info_set_interface(snd_ctl_elem_info_t *obj, snd_ctl_elem_iface_t val); +void snd_ctl_elem_info_set_device(snd_ctl_elem_info_t *obj, unsigned int val); +void snd_ctl_elem_info_set_subdevice(snd_ctl_elem_info_t *obj, unsigned int val); +void snd_ctl_elem_info_set_name(snd_ctl_elem_info_t *obj, const char *val); +void snd_ctl_elem_info_set_index(snd_ctl_elem_info_t *obj, unsigned int val); + +int snd_ctl_add_integer_elem_set(snd_ctl_t *ctl, snd_ctl_elem_info_t *info, +				 unsigned int element_count, +				 unsigned int member_count, +				 long min, long max, long step); +int snd_ctl_add_integer64_elem_set(snd_ctl_t *ctl, snd_ctl_elem_info_t *info, +				   unsigned int element_count, +				   unsigned int member_count, +				   long long min, long long max, +				   long long step); +int snd_ctl_add_boolean_elem_set(snd_ctl_t *ctl, snd_ctl_elem_info_t *info, +				 unsigned int element_count, +				 unsigned int member_count); +int snd_ctl_add_enumerated_elem_set(snd_ctl_t *ctl, snd_ctl_elem_info_t *info, +				    unsigned int element_count, +				    unsigned int member_count, +				    unsigned int items, +				    const char *const labels[]); +int snd_ctl_add_bytes_elem_set(snd_ctl_t *ctl, snd_ctl_elem_info_t *info, +			       unsigned int element_count, +			       unsigned int member_count); + +int snd_ctl_elem_add_integer(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, unsigned int count, long imin, long imax, long istep); +int snd_ctl_elem_add_integer64(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, unsigned int count, long long imin, long long imax, long long istep); +int snd_ctl_elem_add_boolean(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, unsigned int count); +int snd_ctl_elem_add_enumerated(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, unsigned int count, unsigned int items, const char *const names[]); +int snd_ctl_elem_add_iec958(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id); +int snd_ctl_elem_remove(snd_ctl_t *ctl, snd_ctl_elem_id_t *id); + +size_t snd_ctl_elem_value_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_ctl_elem_value_t using standard alloca + * \param ptr returned pointer + */ +#define snd_ctl_elem_value_alloca(ptr) __snd_alloca(ptr, snd_ctl_elem_value) +int snd_ctl_elem_value_malloc(snd_ctl_elem_value_t **ptr); +void snd_ctl_elem_value_free(snd_ctl_elem_value_t *obj); +void snd_ctl_elem_value_clear(snd_ctl_elem_value_t *obj); +void snd_ctl_elem_value_copy(snd_ctl_elem_value_t *dst, const snd_ctl_elem_value_t *src); +int snd_ctl_elem_value_compare(snd_ctl_elem_value_t *left, const snd_ctl_elem_value_t *right); +void snd_ctl_elem_value_get_id(const snd_ctl_elem_value_t *obj, snd_ctl_elem_id_t *ptr); +unsigned int snd_ctl_elem_value_get_numid(const snd_ctl_elem_value_t *obj); +snd_ctl_elem_iface_t snd_ctl_elem_value_get_interface(const snd_ctl_elem_value_t *obj); +unsigned int snd_ctl_elem_value_get_device(const snd_ctl_elem_value_t *obj); +unsigned int snd_ctl_elem_value_get_subdevice(const snd_ctl_elem_value_t *obj); +const char *snd_ctl_elem_value_get_name(const snd_ctl_elem_value_t *obj); +unsigned int snd_ctl_elem_value_get_index(const snd_ctl_elem_value_t *obj); +void snd_ctl_elem_value_set_id(snd_ctl_elem_value_t *obj, const snd_ctl_elem_id_t *ptr); +void snd_ctl_elem_value_set_numid(snd_ctl_elem_value_t *obj, unsigned int val); +void snd_ctl_elem_value_set_interface(snd_ctl_elem_value_t *obj, snd_ctl_elem_iface_t val); +void snd_ctl_elem_value_set_device(snd_ctl_elem_value_t *obj, unsigned int val); +void snd_ctl_elem_value_set_subdevice(snd_ctl_elem_value_t *obj, unsigned int val); +void snd_ctl_elem_value_set_name(snd_ctl_elem_value_t *obj, const char *val); +void snd_ctl_elem_value_set_index(snd_ctl_elem_value_t *obj, unsigned int val); +int snd_ctl_elem_value_get_boolean(const snd_ctl_elem_value_t *obj, unsigned int idx); +long snd_ctl_elem_value_get_integer(const snd_ctl_elem_value_t *obj, unsigned int idx); +long long snd_ctl_elem_value_get_integer64(const snd_ctl_elem_value_t *obj, unsigned int idx); +unsigned int snd_ctl_elem_value_get_enumerated(const snd_ctl_elem_value_t *obj, unsigned int idx); +unsigned char snd_ctl_elem_value_get_byte(const snd_ctl_elem_value_t *obj, unsigned int idx); +void snd_ctl_elem_value_set_boolean(snd_ctl_elem_value_t *obj, unsigned int idx, long val); +void snd_ctl_elem_value_set_integer(snd_ctl_elem_value_t *obj, unsigned int idx, long val); +void snd_ctl_elem_value_set_integer64(snd_ctl_elem_value_t *obj, unsigned int idx, long long val); +void snd_ctl_elem_value_set_enumerated(snd_ctl_elem_value_t *obj, unsigned int idx, unsigned int val); +void snd_ctl_elem_value_set_byte(snd_ctl_elem_value_t *obj, unsigned int idx, unsigned char val); +void snd_ctl_elem_set_bytes(snd_ctl_elem_value_t *obj, void *data, size_t size); +const void * snd_ctl_elem_value_get_bytes(const snd_ctl_elem_value_t *obj); +void snd_ctl_elem_value_get_iec958(const snd_ctl_elem_value_t *obj, snd_aes_iec958_t *ptr); +void snd_ctl_elem_value_set_iec958(snd_ctl_elem_value_t *obj, const snd_aes_iec958_t *ptr); + +int snd_tlv_parse_dB_info(unsigned int *tlv, unsigned int tlv_size, +			  unsigned int **db_tlvp); +int snd_tlv_get_dB_range(unsigned int *tlv, long rangemin, long rangemax, +			 long *min, long *max); +int snd_tlv_convert_to_dB(unsigned int *tlv, long rangemin, long rangemax, +			  long volume, long *db_gain); +int snd_tlv_convert_from_dB(unsigned int *tlv, long rangemin, long rangemax, +			    long db_gain, long *value, int xdir); +int snd_ctl_get_dB_range(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, +			 long *min, long *max); +int snd_ctl_convert_to_dB(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, +			  long volume, long *db_gain); +int snd_ctl_convert_from_dB(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id, +			    long db_gain, long *value, int xdir); + +/** + *  \defgroup HControl High level Control Interface + *  \ingroup Control + *  The high level control interface. + *  See \ref hcontrol page for more details. + *  \{ + */ + +/** HCTL element handle */ +typedef struct _snd_hctl_elem snd_hctl_elem_t; + +/** HCTL handle */ +typedef struct _snd_hctl snd_hctl_t; + +/** + * \brief Compare function for sorting HCTL elements + * \param e1 First element + * \param e2 Second element + * \return -1 if e1 < e2, 0 if e1 == e2, 1 if e1 > e2 + */ +typedef int (*snd_hctl_compare_t)(const snd_hctl_elem_t *e1, +				  const snd_hctl_elem_t *e2); +int snd_hctl_compare_fast(const snd_hctl_elem_t *c1, +			  const snd_hctl_elem_t *c2); +/**  + * \brief HCTL callback function + * \param hctl HCTL handle + * \param mask event mask + * \param elem related HCTL element (if any) + * \return 0 on success otherwise a negative error code + */ +typedef int (*snd_hctl_callback_t)(snd_hctl_t *hctl, +				   unsigned int mask, +				   snd_hctl_elem_t *elem); +/**  + * \brief HCTL element callback function + * \param elem HCTL element + * \param mask event mask + * \return 0 on success otherwise a negative error code + */ +typedef int (*snd_hctl_elem_callback_t)(snd_hctl_elem_t *elem, +					unsigned int mask); + +int snd_hctl_open(snd_hctl_t **hctl, const char *name, int mode); +int snd_hctl_open_ctl(snd_hctl_t **hctlp, snd_ctl_t *ctl); +int snd_hctl_close(snd_hctl_t *hctl); +int snd_hctl_nonblock(snd_hctl_t *hctl, int nonblock); +static __inline__ int snd_hctl_abort(snd_hctl_t *hctl) { return snd_hctl_nonblock(hctl, 2); } +int snd_hctl_poll_descriptors_count(snd_hctl_t *hctl); +int snd_hctl_poll_descriptors(snd_hctl_t *hctl, struct pollfd *pfds, unsigned int space); +int snd_hctl_poll_descriptors_revents(snd_hctl_t *ctl, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +unsigned int snd_hctl_get_count(snd_hctl_t *hctl); +int snd_hctl_set_compare(snd_hctl_t *hctl, snd_hctl_compare_t hsort); +snd_hctl_elem_t *snd_hctl_first_elem(snd_hctl_t *hctl); +snd_hctl_elem_t *snd_hctl_last_elem(snd_hctl_t *hctl); +snd_hctl_elem_t *snd_hctl_find_elem(snd_hctl_t *hctl, const snd_ctl_elem_id_t *id); +void snd_hctl_set_callback(snd_hctl_t *hctl, snd_hctl_callback_t callback); +void snd_hctl_set_callback_private(snd_hctl_t *hctl, void *data); +void *snd_hctl_get_callback_private(snd_hctl_t *hctl); +int snd_hctl_load(snd_hctl_t *hctl); +int snd_hctl_free(snd_hctl_t *hctl); +int snd_hctl_handle_events(snd_hctl_t *hctl); +const char *snd_hctl_name(snd_hctl_t *hctl); +int snd_hctl_wait(snd_hctl_t *hctl, int timeout); +snd_ctl_t *snd_hctl_ctl(snd_hctl_t *hctl); + +snd_hctl_elem_t *snd_hctl_elem_next(snd_hctl_elem_t *elem); +snd_hctl_elem_t *snd_hctl_elem_prev(snd_hctl_elem_t *elem); +int snd_hctl_elem_info(snd_hctl_elem_t *elem, snd_ctl_elem_info_t * info); +int snd_hctl_elem_read(snd_hctl_elem_t *elem, snd_ctl_elem_value_t * value); +int snd_hctl_elem_write(snd_hctl_elem_t *elem, snd_ctl_elem_value_t * value); +int snd_hctl_elem_tlv_read(snd_hctl_elem_t *elem, unsigned int *tlv, unsigned int tlv_size); +int snd_hctl_elem_tlv_write(snd_hctl_elem_t *elem, const unsigned int *tlv); +int snd_hctl_elem_tlv_command(snd_hctl_elem_t *elem, const unsigned int *tlv); + +snd_hctl_t *snd_hctl_elem_get_hctl(snd_hctl_elem_t *elem); + +void snd_hctl_elem_get_id(const snd_hctl_elem_t *obj, snd_ctl_elem_id_t *ptr); +unsigned int snd_hctl_elem_get_numid(const snd_hctl_elem_t *obj); +snd_ctl_elem_iface_t snd_hctl_elem_get_interface(const snd_hctl_elem_t *obj); +unsigned int snd_hctl_elem_get_device(const snd_hctl_elem_t *obj); +unsigned int snd_hctl_elem_get_subdevice(const snd_hctl_elem_t *obj); +const char *snd_hctl_elem_get_name(const snd_hctl_elem_t *obj); +unsigned int snd_hctl_elem_get_index(const snd_hctl_elem_t *obj); +void snd_hctl_elem_set_callback(snd_hctl_elem_t *obj, snd_hctl_elem_callback_t val); +void * snd_hctl_elem_get_callback_private(const snd_hctl_elem_t *obj); +void snd_hctl_elem_set_callback_private(snd_hctl_elem_t *obj, void * val); + +/** \} */ + +/** \} */ + +/** + *  \defgroup SControl Setup Control Interface + *  \ingroup Control + *  The setup control interface - set or modify control elements from a configuration file. + *  \{ + */ + +int snd_sctl_build(snd_sctl_t **ctl, snd_ctl_t *handle, snd_config_t *config, +		   snd_config_t *private_data, int mode); +int snd_sctl_free(snd_sctl_t *handle); +int snd_sctl_install(snd_sctl_t *handle); +int snd_sctl_remove(snd_sctl_t *handle); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_CONTROL_H */ diff --git a/include/alsa/control_external.h b/include/alsa/control_external.h new file mode 100644 index 0000000..488fa6e --- /dev/null +++ b/include/alsa/control_external.h @@ -0,0 +1,286 @@ +/** + * \file include/control_external.h + * \brief External control plugin SDK + * \author Takashi Iwai <tiwai@suse.de> + * \date 2005 + * + * External control plugin SDK. + */ + +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ +#ifndef __ALSA_CONTROL_EXTERNAL_H +#define __ALSA_CONTROL_EXTERNAL_H + +#include "control.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup CtlPlugin_SDK External Control Plugin SDK + *  \{ + */ + +/** + * Define the object entry for external control plugins + */ +#define SND_CTL_PLUGIN_ENTRY(name) _snd_ctl_##name##_open + +/** + * Define the symbols of the given control plugin with versions + */ +#define SND_CTL_PLUGIN_SYMBOL(name) SND_DLSYM_BUILD_VERSION(SND_CTL_PLUGIN_ENTRY(name), SND_CONTROL_DLSYM_VERSION); + +/** + * Define the control plugin + */ +#define SND_CTL_PLUGIN_DEFINE_FUNC(plugin) \ +int SND_CTL_PLUGIN_ENTRY(plugin) (snd_ctl_t **handlep, const char *name,\ +				  snd_config_t *root, snd_config_t *conf, int mode) + +/** External control plugin handle */ +typedef struct snd_ctl_ext snd_ctl_ext_t; +/** Callback table of control ext */ +typedef struct snd_ctl_ext_callback snd_ctl_ext_callback_t; +/** Key to access a control pointer */ +typedef unsigned long snd_ctl_ext_key_t; +#ifdef DOC_HIDDEN +/* redefine typedef's for stupid doxygen */ +typedef snd_ctl_ext snd_ctl_ext_t; +typedef snd_ctl_ext_callback snd_ctl_ext_callback_t; +#endif +/** Callback to handle TLV commands. */ +typedef int (snd_ctl_ext_tlv_rw_t)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, int op_flag, unsigned int numid, +				   unsigned int *tlv, unsigned int tlv_size); + +/* + * Protocol version + */ +#define SND_CTL_EXT_VERSION_MAJOR	1	/**< Protocol major version */ +#define SND_CTL_EXT_VERSION_MINOR	0	/**< Protocol minor version */ +#define SND_CTL_EXT_VERSION_TINY	1	/**< Protocol tiny version */ +/** + * external plugin protocol version + */ +#define SND_CTL_EXT_VERSION		((SND_CTL_EXT_VERSION_MAJOR<<16) |\ +					 (SND_CTL_EXT_VERSION_MINOR<<8) |\ +					 (SND_CTL_EXT_VERSION_TINY)) + +/** Handle of control ext */ +struct snd_ctl_ext { +	/** +	 * protocol version; #SND_CTL_EXT_VERSION must be filled here +	 * before calling #snd_ctl_ext_create() +	 */ +	unsigned int version; +	/** +	 * Index of this card; must be filled before calling #snd_ctl_ext_create() +	 */ +	int card_idx; +	/** +	 * ID string of this card; must be filled before calling #snd_ctl_ext_create() +	 */ +	char id[16]; +	/** +	 * Driver name of this card; must be filled before calling #snd_ctl_ext_create() +	 */ +	char driver[16]; +	/** +	 * short name of this card; must be filled before calling #snd_ctl_ext_create() +	 */ +	char name[32]; +	/** +	 * Long name of this card; must be filled before calling #snd_ctl_ext_create() +	 */ +	char longname[80]; +	/** +	 * Mixer name of this card; must be filled before calling #snd_ctl_ext_create() +	 */ +	char mixername[80]; +	/** +	 * poll descriptor +	 */ +	int poll_fd; + +	/** +	 * callbacks of this plugin; must be filled before calling #snd_pcm_ioplug_create() +	 */ +	const snd_ctl_ext_callback_t *callback; +	/** +	 * private data, which can be used freely in the driver callbacks +	 */ +	void *private_data; +	/** +	 * control handle filled by #snd_ctl_ext_create() +	 */ +	snd_ctl_t *handle; + +	int nonblock;			/**< non-block mode; read-only */ +	int subscribed;			/**< events subscribed; read-only */ + +	/** +	 * optional TLV data for the control (since protocol 1.0.1) +	 */ +	union { +		snd_ctl_ext_tlv_rw_t *c; +		const unsigned int *p; +	} tlv; +}; + +/** Callback table of ext. */ +struct snd_ctl_ext_callback { +	/** +	 * close the control handle; optional +	 */ +	void (*close)(snd_ctl_ext_t *ext); +	/** +	 * return the total number of elements; required +	 */ +	int (*elem_count)(snd_ctl_ext_t *ext); +	/** +	 * return the element id of the given offset (array index); required +	 */ +	int (*elem_list)(snd_ctl_ext_t *ext, unsigned int offset, snd_ctl_elem_id_t *id); +	/** +	 * convert the element id to a search key; required +	 */ +	snd_ctl_ext_key_t (*find_elem)(snd_ctl_ext_t *ext, const snd_ctl_elem_id_t *id); +	/** +	 * the destructor of the key; optional +	 */ +	void (*free_key)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key); +	/** +	 * get the attribute of the element; required +	 */ +	int (*get_attribute)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, +			     int *type, unsigned int *acc, unsigned int *count); +	/** +	 * get the element information of integer type +	 */ +	int (*get_integer_info)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, +				long *imin, long *imax, long *istep); +	/** +	 * get the element information of integer64 type +	 */ +	int (*get_integer64_info)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, +				  int64_t *imin, int64_t *imax, int64_t *istep); +	/** +	 * get the element information of enumerated type +	 */ +	int (*get_enumerated_info)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, unsigned int *items); +	/** +	 * get the name of the enumerated item +	 */ +	int (*get_enumerated_name)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, unsigned int item, +				   char *name, size_t name_max_len); +	/** +	 * read the current values of integer type +	 */ +	int (*read_integer)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, long *value); +	/** +	 * read the current values of integer64 type +	 */ +	int (*read_integer64)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, int64_t *value); +	/** +	 * read the current values of enumerated type +	 */ +	int (*read_enumerated)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, unsigned int *items); +	/** +	 * read the current values of bytes type +	 */ +	int (*read_bytes)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, unsigned char *data, +			  size_t max_bytes); +	/** +	 * read the current values of iec958 type +	 */ +	int (*read_iec958)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, snd_aes_iec958_t *iec958); +	/** +	 * update the current values of integer type with the given values +	 */ +	int (*write_integer)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, long *value); +	/** +	 * update the current values of integer64 type with the given values +	 */ +	int (*write_integer64)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, int64_t *value); +	/** +	 * update the current values of enumerated type with the given values +	 */ +	int (*write_enumerated)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, unsigned int *items); +	/** +	 * update the current values of bytes type with the given values +	 */ +	int (*write_bytes)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, unsigned char *data, +			   size_t max_bytes); +	/** +	 * update the current values of iec958 type with the given values +	 */ +	int (*write_iec958)(snd_ctl_ext_t *ext, snd_ctl_ext_key_t key, snd_aes_iec958_t *iec958); +	/** +	 * subscribe/unsubscribe the event notification; optional +	 */ +	void (*subscribe_events)(snd_ctl_ext_t *ext, int subscribe); +	/** +	 * read a pending notification event; optional +	 */ +	int (*read_event)(snd_ctl_ext_t *ext, snd_ctl_elem_id_t *id, unsigned int *event_mask); +	/** +	 * return the number of poll descriptors; optional +	 */ +	int (*poll_descriptors_count)(snd_ctl_ext_t *ext); +	/** +	 * fill the poll descriptors; optional +	 */ +	int (*poll_descriptors)(snd_ctl_ext_t *ext, struct pollfd *pfds, unsigned int space); +	/** +	 * mangle the revents of poll descriptors +	 */ +	int (*poll_revents)(snd_ctl_ext_t *ext, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +}; + +/** + * The access type bits stored in get_attribute callback + */ +typedef enum snd_ctl_ext_access { +	SND_CTL_EXT_ACCESS_READ = (1<<0), +	SND_CTL_EXT_ACCESS_WRITE = (1<<1), +	SND_CTL_EXT_ACCESS_READWRITE = (3<<0), +	SND_CTL_EXT_ACCESS_VOLATILE = (1<<2), +	SND_CTL_EXT_ACCESS_TLV_READ = (1<<4), +	SND_CTL_EXT_ACCESS_TLV_WRITE = (1<<5), +	SND_CTL_EXT_ACCESS_TLV_READWRITE = (3<<4), +	SND_CTL_EXT_ACCESS_TLV_COMMAND = (1<<6), +	SND_CTL_EXT_ACCESS_INACTIVE = (1<<8), +	SND_CTL_EXT_ACCESS_TLV_CALLBACK = (1<<28), +} snd_ctl_ext_access_t; + +/** + * find_elem callback returns this if no matching control element is found + */ +#define SND_CTL_EXT_KEY_NOT_FOUND	(snd_ctl_ext_key_t)(-1) + +int snd_ctl_ext_create(snd_ctl_ext_t *ext, const char *name, int mode); +int snd_ctl_ext_delete(snd_ctl_ext_t *ext); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_CONTROL_EXTERNAL_H */ diff --git a/include/alsa/error.h b/include/alsa/error.h new file mode 100644 index 0000000..9a996ab --- /dev/null +++ b/include/alsa/error.h @@ -0,0 +1,85 @@ +/** + * \file include/error.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_ERROR_H +#define __ALSA_ERROR_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Error Error handling + *  Error handling macros and functions. + *  \{ + */ + +#define SND_ERROR_BEGIN				500000			/**< Lower boundary of sound error codes. */ +#define SND_ERROR_INCOMPATIBLE_VERSION		(SND_ERROR_BEGIN+0)	/**< Kernel/library protocols are not compatible. */ +#define SND_ERROR_ALISP_NIL			(SND_ERROR_BEGIN+1)	/**< Lisp encountered an error during acall. */ + +const char *snd_strerror(int errnum); + +/** + * \brief Error handler callback. + * \param file Source file name. + * \param line Line number. + * \param function Function name. + * \param err Value of \c errno, or 0 if not relevant. + * \param fmt \c printf(3) format. + * \param ... \c printf(3) arguments. + * + * A function of this type is called by the ALSA library when an error occurs. + * This function usually shows the message on the screen, and/or logs it. + */ +typedef void (*snd_lib_error_handler_t)(const char *file, int line, const char *function, int err, const char *fmt, ...) /* __attribute__ ((format (printf, 5, 6))) */; +extern snd_lib_error_handler_t snd_lib_error; +extern int snd_lib_error_set_handler(snd_lib_error_handler_t handler); + +#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ > 95) +#define SNDERR(...) snd_lib_error(__FILE__, __LINE__, __FUNCTION__, 0, __VA_ARGS__) /**< Shows a sound error message. */ +#define SYSERR(...) snd_lib_error(__FILE__, __LINE__, __FUNCTION__, errno, __VA_ARGS__) /**< Shows a system error message (related to \c errno). */ +#else +#define SNDERR(args...) snd_lib_error(__FILE__, __LINE__, __FUNCTION__, 0, ##args) /**< Shows a sound error message. */ +#define SYSERR(args...) snd_lib_error(__FILE__, __LINE__, __FUNCTION__, errno, ##args) /**< Shows a system error message (related to \c errno). */ +#endif + +/** \} */ + +#ifdef __cplusplus +} +#endif + +/** Local error handler function type */ +typedef void (*snd_local_error_handler_t)(const char *file, int line, +					  const char *func, int err, +					  const char *fmt, va_list arg); + +snd_local_error_handler_t snd_lib_error_set_local(snd_local_error_handler_t func); + +#endif /* __ALSA_ERROR_H */ + diff --git a/include/alsa/global.h b/include/alsa/global.h new file mode 100644 index 0000000..d73d333 --- /dev/null +++ b/include/alsa/global.h @@ -0,0 +1,161 @@ +/** + * \file include/global.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_GLOBAL_H_ +#define __ALSA_GLOBAL_H_ + +/* for timeval and timespec */ +#include <time.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Global Global defines and functions + *  Global defines and functions. + *  \par + *  The ALSA library implementation uses these macros and functions. + *  Most applications probably do not need them. + *  \{ + */ + +const char *snd_asoundlib_version(void); + +#ifndef ATTRIBUTE_UNUSED +/** do not print warning (gcc) when function parameter is not used */ +#define ATTRIBUTE_UNUSED __attribute__ ((__unused__)) +#endif + +#ifdef PIC /* dynamic build */ + +/** \hideinitializer \brief Helper macro for #SND_DLSYM_BUILD_VERSION. */ +#define __SND_DLSYM_VERSION(name, version) _ ## name ## version +/** + * \hideinitializer + * \brief Appends the build version to the name of a versioned dynamic symbol. + */ +#define SND_DLSYM_BUILD_VERSION(name, version) char __SND_DLSYM_VERSION(name, version); + +#else /* static build */ + +struct snd_dlsym_link { +	struct snd_dlsym_link *next; +	const char *dlsym_name; +	const void *dlsym_ptr; +}; + +extern struct snd_dlsym_link *snd_dlsym_start; + +/** \hideinitializer \brief Helper macro for #SND_DLSYM_BUILD_VERSION. */ +#define __SND_DLSYM_VERSION(prefix, name, version) _ ## prefix ## name ## version +/** + * \hideinitializer + * \brief Appends the build version to the name of a versioned dynamic symbol. + */ +#define SND_DLSYM_BUILD_VERSION(name, version) \ +  static struct snd_dlsym_link __SND_DLSYM_VERSION(snd_dlsym_, name, version); \ +  void __SND_DLSYM_VERSION(snd_dlsym_constructor_, name, version) (void) __attribute__ ((constructor)); \ +  void __SND_DLSYM_VERSION(snd_dlsym_constructor_, name, version) (void) { \ +    __SND_DLSYM_VERSION(snd_dlsym_, name, version).next = snd_dlsym_start; \ +    __SND_DLSYM_VERSION(snd_dlsym_, name, version).dlsym_name = # name; \ +    __SND_DLSYM_VERSION(snd_dlsym_, name, version).dlsym_ptr = (void *)&name; \ +    snd_dlsym_start = &__SND_DLSYM_VERSION(snd_dlsym_, name, version); \ +  } + +#endif + +#ifndef __STRING +/** \brief Return 'x' argument as string */ +#define __STRING(x)     #x +#endif + +/** \brief Returns the version of a dynamic symbol as a string. */ +#define SND_DLSYM_VERSION(version) __STRING(version) + +void *snd_dlopen(const char *file, int mode, char *errbuf, size_t errbuflen); +void *snd_dlsym(void *handle, const char *name, const char *version); +int snd_dlclose(void *handle); + + +/** \brief alloca helper macro. */ +#define __snd_alloca(ptr,type) do { *ptr = (type##_t *) alloca(type##_sizeof()); memset(*ptr, 0, type##_sizeof()); } while (0) + +/** + * \brief Internal structure for an async notification client handler. + * + * The ALSA library uses a pointer to this structure as a handle to an async + * notification object. Applications don't access its contents directly. + */ +typedef struct _snd_async_handler snd_async_handler_t; + +/** + * \brief Async notification callback. + * + * See the #snd_async_add_handler function for details. + */ +typedef void (*snd_async_callback_t)(snd_async_handler_t *handler); + +int snd_async_add_handler(snd_async_handler_t **handler, int fd,  +			  snd_async_callback_t callback, void *private_data); +int snd_async_del_handler(snd_async_handler_t *handler); +int snd_async_handler_get_fd(snd_async_handler_t *handler); +int snd_async_handler_get_signo(snd_async_handler_t *handler); +void *snd_async_handler_get_callback_private(snd_async_handler_t *handler); + +struct snd_shm_area *snd_shm_area_create(int shmid, void *ptr); +struct snd_shm_area *snd_shm_area_share(struct snd_shm_area *area); +int snd_shm_area_destroy(struct snd_shm_area *area); + +int snd_user_file(const char *file, char **result); + +#ifdef __GLIBC__ +#if !defined(_POSIX_C_SOURCE) && !defined(_POSIX_SOURCE) +struct timeval { +	time_t		tv_sec;		/* seconds */ +	long		tv_usec;	/* microseconds */ +}; + +struct timespec { +	time_t		tv_sec;		/* seconds */ +	long		tv_nsec;	/* nanoseconds */ +}; +#endif +#endif + +/** Timestamp */ +typedef struct timeval snd_timestamp_t; +/** Hi-res timestamp */ +typedef struct timespec snd_htimestamp_t; + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_GLOBAL_H */ diff --git a/include/alsa/hwdep.h b/include/alsa/hwdep.h new file mode 100644 index 0000000..46ed1f7 --- /dev/null +++ b/include/alsa/hwdep.h @@ -0,0 +1,172 @@ +/** + * \file include/hwdep.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_HWDEP_H +#define __ALSA_HWDEP_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup HwDep Hardware Dependant Interface + *  The Hardware Dependant Interface. + *  \{ + */ + +/** dlsym version for interface entry callback */ +#define SND_HWDEP_DLSYM_VERSION		_dlsym_hwdep_001 + +/** HwDep information container */ +typedef struct _snd_hwdep_info snd_hwdep_info_t; + +/** HwDep DSP status container */ +typedef struct _snd_hwdep_dsp_status snd_hwdep_dsp_status_t; + +/** HwDep DSP image container */ +typedef struct _snd_hwdep_dsp_image snd_hwdep_dsp_image_t; + +/** HwDep interface */ +typedef enum _snd_hwdep_iface { +	SND_HWDEP_IFACE_OPL2 = 0,	/**< OPL2 raw driver */ +	SND_HWDEP_IFACE_OPL3,		/**< OPL3 raw driver */ +	SND_HWDEP_IFACE_OPL4,		/**< OPL4 raw driver */ +	SND_HWDEP_IFACE_SB16CSP,	/**< SB16CSP driver */ +	SND_HWDEP_IFACE_EMU10K1,	/**< EMU10K1 driver */ +	SND_HWDEP_IFACE_YSS225,		/**< YSS225 driver */ +	SND_HWDEP_IFACE_ICS2115,	/**< ICS2115 driver */ +	SND_HWDEP_IFACE_SSCAPE,		/**< Ensoniq SoundScape ISA card (MC68EC000) */ +	SND_HWDEP_IFACE_VX,		/**< Digigram VX cards */ +	SND_HWDEP_IFACE_MIXART,		/**< Digigram miXart cards */ +	SND_HWDEP_IFACE_USX2Y,		/**< Tascam US122, US224 & US428 usb */ +	SND_HWDEP_IFACE_EMUX_WAVETABLE,	/**< EmuX wavetable */ +	SND_HWDEP_IFACE_BLUETOOTH,	/**< Bluetooth audio */ +	SND_HWDEP_IFACE_USX2Y_PCM,	/**< Tascam US122, US224 & US428 raw USB PCM */ +	SND_HWDEP_IFACE_PCXHR,		/**< Digigram PCXHR */ +	SND_HWDEP_IFACE_SB_RC,		/**< SB Extigy/Audigy2NX remote control */ +	SND_HWDEP_IFACE_HDA,		/**< HD-audio */ +	SND_HWDEP_IFACE_USB_STREAM,	/**< direct access to usb stream */ +	SND_HWDEP_IFACE_FW_DICE,	/**< TC DICE FireWire device */ +	SND_HWDEP_IFACE_FW_FIREWORKS,	/**< Echo Audio Fireworks based device */ +	SND_HWDEP_IFACE_FW_BEBOB,	/**< BridgeCo BeBoB based device */ +	SND_HWDEP_IFACE_FW_OXFW,	/**< Oxford OXFW970/971 based device */ +	SND_HWDEP_IFACE_FW_DIGI00X,	/* Digidesign Digi 002/003 family */ +	SND_HWDEP_IFACE_FW_TASCAM,	/* TASCAM FireWire series */ +	SND_HWDEP_IFACE_LINE6,		/* Line6 USB processors */ +	SND_HWDEP_IFACE_FW_MOTU,	/* MOTU FireWire series */ +	SND_HWDEP_IFACE_FW_FIREFACE,	/* RME Fireface series */ + +	SND_HWDEP_IFACE_LAST = SND_HWDEP_IFACE_FW_FIREFACE,	/**< last known hwdep interface */ +} snd_hwdep_iface_t; + +/** open for reading */ +#define SND_HWDEP_OPEN_READ		(O_RDONLY) +/** open for writing */ +#define SND_HWDEP_OPEN_WRITE		(O_WRONLY) +/** open for reading and writing */ +#define SND_HWDEP_OPEN_DUPLEX		(O_RDWR) +/** open mode flag: open in nonblock mode */ +#define SND_HWDEP_OPEN_NONBLOCK		(O_NONBLOCK) + +/** HwDep handle type */ +typedef enum _snd_hwdep_type { +	/** Kernel level HwDep */ +	SND_HWDEP_TYPE_HW, +	/** Shared memory client HwDep (not yet implemented) */ +	SND_HWDEP_TYPE_SHM, +	/** INET client HwDep (not yet implemented) */ +	SND_HWDEP_TYPE_INET +} snd_hwdep_type_t; + +/** HwDep handle */ +typedef struct _snd_hwdep snd_hwdep_t; + +int snd_hwdep_open(snd_hwdep_t **hwdep, const char *name, int mode); +int snd_hwdep_close(snd_hwdep_t *hwdep); +int snd_hwdep_poll_descriptors(snd_hwdep_t *hwdep, struct pollfd *pfds, unsigned int space); +int snd_hwdep_poll_descriptors_count(snd_hwdep_t *hwdep); +int snd_hwdep_poll_descriptors_revents(snd_hwdep_t *hwdep, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +int snd_hwdep_nonblock(snd_hwdep_t *hwdep, int nonblock); +int snd_hwdep_info(snd_hwdep_t *hwdep, snd_hwdep_info_t * info); +int snd_hwdep_dsp_status(snd_hwdep_t *hwdep, snd_hwdep_dsp_status_t *status); +int snd_hwdep_dsp_load(snd_hwdep_t *hwdep, snd_hwdep_dsp_image_t *block); +int snd_hwdep_ioctl(snd_hwdep_t *hwdep, unsigned int request, void * arg); +ssize_t snd_hwdep_write(snd_hwdep_t *hwdep, const void *buffer, size_t size); +ssize_t snd_hwdep_read(snd_hwdep_t *hwdep, void *buffer, size_t size); + +size_t snd_hwdep_info_sizeof(void); +/** allocate #snd_hwdep_info_t container on stack */ +#define snd_hwdep_info_alloca(ptr) __snd_alloca(ptr, snd_hwdep_info) +int snd_hwdep_info_malloc(snd_hwdep_info_t **ptr); +void snd_hwdep_info_free(snd_hwdep_info_t *obj); +void snd_hwdep_info_copy(snd_hwdep_info_t *dst, const snd_hwdep_info_t *src); + +unsigned int snd_hwdep_info_get_device(const snd_hwdep_info_t *obj); +int snd_hwdep_info_get_card(const snd_hwdep_info_t *obj); +const char *snd_hwdep_info_get_id(const snd_hwdep_info_t *obj); +const char *snd_hwdep_info_get_name(const snd_hwdep_info_t *obj); +snd_hwdep_iface_t snd_hwdep_info_get_iface(const snd_hwdep_info_t *obj); +void snd_hwdep_info_set_device(snd_hwdep_info_t *obj, unsigned int val); + +size_t snd_hwdep_dsp_status_sizeof(void); +/** allocate #snd_hwdep_dsp_status_t container on stack */ +#define snd_hwdep_dsp_status_alloca(ptr) __snd_alloca(ptr, snd_hwdep_dsp_status) +int snd_hwdep_dsp_status_malloc(snd_hwdep_dsp_status_t **ptr); +void snd_hwdep_dsp_status_free(snd_hwdep_dsp_status_t *obj); +void snd_hwdep_dsp_status_copy(snd_hwdep_dsp_status_t *dst, const snd_hwdep_dsp_status_t *src); + +unsigned int snd_hwdep_dsp_status_get_version(const snd_hwdep_dsp_status_t *obj); +const char *snd_hwdep_dsp_status_get_id(const snd_hwdep_dsp_status_t *obj); +unsigned int snd_hwdep_dsp_status_get_num_dsps(const snd_hwdep_dsp_status_t *obj); +unsigned int snd_hwdep_dsp_status_get_dsp_loaded(const snd_hwdep_dsp_status_t *obj); +unsigned int snd_hwdep_dsp_status_get_chip_ready(const snd_hwdep_dsp_status_t *obj); + +size_t snd_hwdep_dsp_image_sizeof(void); +/** allocate #snd_hwdep_dsp_image_t container on stack */ +#define snd_hwdep_dsp_image_alloca(ptr) __snd_alloca(ptr, snd_hwdep_dsp_image) +int snd_hwdep_dsp_image_malloc(snd_hwdep_dsp_image_t **ptr); +void snd_hwdep_dsp_image_free(snd_hwdep_dsp_image_t *obj); +void snd_hwdep_dsp_image_copy(snd_hwdep_dsp_image_t *dst, const snd_hwdep_dsp_image_t *src); + +unsigned int snd_hwdep_dsp_image_get_index(const snd_hwdep_dsp_image_t *obj); +const char *snd_hwdep_dsp_image_get_name(const snd_hwdep_dsp_image_t *obj); +const void *snd_hwdep_dsp_image_get_image(const snd_hwdep_dsp_image_t *obj); +size_t snd_hwdep_dsp_image_get_length(const snd_hwdep_dsp_image_t *obj); + +void snd_hwdep_dsp_image_set_index(snd_hwdep_dsp_image_t *obj, unsigned int _index); +void snd_hwdep_dsp_image_set_name(snd_hwdep_dsp_image_t *obj, const char *name); +void snd_hwdep_dsp_image_set_image(snd_hwdep_dsp_image_t *obj, void *buffer); +void snd_hwdep_dsp_image_set_length(snd_hwdep_dsp_image_t *obj, size_t length); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_HWDEP_H */ + diff --git a/include/alsa/input.h b/include/alsa/input.h new file mode 100644 index 0000000..e7ce791 --- /dev/null +++ b/include/alsa/input.h @@ -0,0 +1,83 @@ +/** + * \file include/input.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_INPUT_H +#define __ALSA_INPUT_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Input Input Interface + * + *  The input functions present an interface similar to the stdio functions + *  on top of different underlying input sources. + * + *  The #snd_config_load function uses such an input handle to be able to + *  load configurations not only from standard files but also from other + *  sources, e.g. from memory buffers. + * + *  \{ + */ + +/** + * \brief Internal structure for an input object. + * + * The ALSA library uses a pointer to this structure as a handle to an + * input object. Applications don't access its contents directly. + */ +typedef struct _snd_input snd_input_t; + +/** Input type. */ +typedef enum _snd_input_type { +	/** Input from a stdio stream. */ +	SND_INPUT_STDIO, +	/** Input from a memory buffer. */ +	SND_INPUT_BUFFER +} snd_input_type_t; + +int snd_input_stdio_open(snd_input_t **inputp, const char *file, const char *mode); +int snd_input_stdio_attach(snd_input_t **inputp, FILE *fp, int _close); +int snd_input_buffer_open(snd_input_t **inputp, const char *buffer, ssize_t size); +int snd_input_close(snd_input_t *input); +int snd_input_scanf(snd_input_t *input, const char *format, ...) +#ifndef DOC_HIDDEN +	__attribute__ ((format (scanf, 2, 3))) +#endif +	; +char *snd_input_gets(snd_input_t *input, char *str, size_t size); +int snd_input_getc(snd_input_t *input); +int snd_input_ungetc(snd_input_t *input, int c); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_INPUT_H */ diff --git a/include/alsa/mixer.h b/include/alsa/mixer.h new file mode 100644 index 0000000..9352894 --- /dev/null +++ b/include/alsa/mixer.h @@ -0,0 +1,317 @@ +/** + * \file include/mixer.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_MIXER_H +#define __ALSA_MIXER_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Mixer Mixer Interface + *  The mixer interface. + *  \{ + */ + +/** Mixer handle */ +typedef struct _snd_mixer snd_mixer_t; +/** Mixer elements class handle */ +typedef struct _snd_mixer_class snd_mixer_class_t; +/** Mixer element handle */ +typedef struct _snd_mixer_elem snd_mixer_elem_t; + +/**  + * \brief Mixer callback function + * \param mixer Mixer handle + * \param mask event mask + * \param elem related mixer element (if any) + * \return 0 on success otherwise a negative error code + */ +typedef int (*snd_mixer_callback_t)(snd_mixer_t *ctl, +				    unsigned int mask, +				    snd_mixer_elem_t *elem); + +/**  + * \brief Mixer element callback function + * \param elem Mixer element + * \param mask event mask + * \return 0 on success otherwise a negative error code + */ +typedef int (*snd_mixer_elem_callback_t)(snd_mixer_elem_t *elem, +					 unsigned int mask); + +/** + * \brief Compare function for sorting mixer elements + * \param e1 First element + * \param e2 Second element + * \return -1 if e1 < e2, 0 if e1 == e2, 1 if e1 > e2 + */ +typedef int (*snd_mixer_compare_t)(const snd_mixer_elem_t *e1, +				   const snd_mixer_elem_t *e2); + +/** + * \brief Event callback for the mixer class + * \param class_ Mixer class + * \param mask Event mask (SND_CTL_EVENT_*) + * \param helem HCTL element which invoked the event + * \param melem Mixer element associated to HCTL element + * \return zero if success, otherwise a negative error value + */ +typedef int (*snd_mixer_event_t)(snd_mixer_class_t *class_, unsigned int mask, +				 snd_hctl_elem_t *helem, snd_mixer_elem_t *melem); + + +/** Mixer element type */ +typedef enum _snd_mixer_elem_type { +	/* Simple mixer elements */ +	SND_MIXER_ELEM_SIMPLE, +	SND_MIXER_ELEM_LAST = SND_MIXER_ELEM_SIMPLE +} snd_mixer_elem_type_t; + +int snd_mixer_open(snd_mixer_t **mixer, int mode); +int snd_mixer_close(snd_mixer_t *mixer); +snd_mixer_elem_t *snd_mixer_first_elem(snd_mixer_t *mixer); +snd_mixer_elem_t *snd_mixer_last_elem(snd_mixer_t *mixer); +int snd_mixer_handle_events(snd_mixer_t *mixer); +int snd_mixer_attach(snd_mixer_t *mixer, const char *name); +int snd_mixer_attach_hctl(snd_mixer_t *mixer, snd_hctl_t *hctl); +int snd_mixer_detach(snd_mixer_t *mixer, const char *name); +int snd_mixer_detach_hctl(snd_mixer_t *mixer, snd_hctl_t *hctl); +int snd_mixer_get_hctl(snd_mixer_t *mixer, const char *name, snd_hctl_t **hctl); +int snd_mixer_poll_descriptors_count(snd_mixer_t *mixer); +int snd_mixer_poll_descriptors(snd_mixer_t *mixer, struct pollfd *pfds, unsigned int space); +int snd_mixer_poll_descriptors_revents(snd_mixer_t *mixer, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +int snd_mixer_load(snd_mixer_t *mixer); +void snd_mixer_free(snd_mixer_t *mixer); +int snd_mixer_wait(snd_mixer_t *mixer, int timeout); +int snd_mixer_set_compare(snd_mixer_t *mixer, snd_mixer_compare_t msort); +void snd_mixer_set_callback(snd_mixer_t *obj, snd_mixer_callback_t val); +void * snd_mixer_get_callback_private(const snd_mixer_t *obj); +void snd_mixer_set_callback_private(snd_mixer_t *obj, void * val); +unsigned int snd_mixer_get_count(const snd_mixer_t *obj); +int snd_mixer_class_unregister(snd_mixer_class_t *clss); + +snd_mixer_elem_t *snd_mixer_elem_next(snd_mixer_elem_t *elem); +snd_mixer_elem_t *snd_mixer_elem_prev(snd_mixer_elem_t *elem); +void snd_mixer_elem_set_callback(snd_mixer_elem_t *obj, snd_mixer_elem_callback_t val); +void * snd_mixer_elem_get_callback_private(const snd_mixer_elem_t *obj); +void snd_mixer_elem_set_callback_private(snd_mixer_elem_t *obj, void * val); +snd_mixer_elem_type_t snd_mixer_elem_get_type(const snd_mixer_elem_t *obj); + +int snd_mixer_class_register(snd_mixer_class_t *class_, snd_mixer_t *mixer); +int snd_mixer_elem_new(snd_mixer_elem_t **elem, +		       snd_mixer_elem_type_t type, +		       int compare_weight, +		       void *private_data, +		       void (*private_free)(snd_mixer_elem_t *elem)); +int snd_mixer_elem_add(snd_mixer_elem_t *elem, snd_mixer_class_t *class_); +int snd_mixer_elem_remove(snd_mixer_elem_t *elem); +void snd_mixer_elem_free(snd_mixer_elem_t *elem); +int snd_mixer_elem_info(snd_mixer_elem_t *elem); +int snd_mixer_elem_value(snd_mixer_elem_t *elem); +int snd_mixer_elem_attach(snd_mixer_elem_t *melem, snd_hctl_elem_t *helem); +int snd_mixer_elem_detach(snd_mixer_elem_t *melem, snd_hctl_elem_t *helem); +int snd_mixer_elem_empty(snd_mixer_elem_t *melem); +void *snd_mixer_elem_get_private(const snd_mixer_elem_t *melem); + +size_t snd_mixer_class_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_mixer_class_t using standard alloca + * \param ptr returned pointer + */ +#define snd_mixer_class_alloca(ptr) __snd_alloca(ptr, snd_mixer_class) +int snd_mixer_class_malloc(snd_mixer_class_t **ptr); +void snd_mixer_class_free(snd_mixer_class_t *obj); +void snd_mixer_class_copy(snd_mixer_class_t *dst, const snd_mixer_class_t *src); +snd_mixer_t *snd_mixer_class_get_mixer(const snd_mixer_class_t *class_); +snd_mixer_event_t snd_mixer_class_get_event(const snd_mixer_class_t *class_); +void *snd_mixer_class_get_private(const snd_mixer_class_t *class_); +snd_mixer_compare_t snd_mixer_class_get_compare(const snd_mixer_class_t *class_); +int snd_mixer_class_set_event(snd_mixer_class_t *class_, snd_mixer_event_t event); +int snd_mixer_class_set_private(snd_mixer_class_t *class_, void *private_data); +int snd_mixer_class_set_private_free(snd_mixer_class_t *class_, void (*private_free)(snd_mixer_class_t *)); +int snd_mixer_class_set_compare(snd_mixer_class_t *class_, snd_mixer_compare_t compare); + +/** + *  \defgroup SimpleMixer Simple Mixer Interface + *  \ingroup Mixer + *  The simple mixer interface. + *  \{ + */ + +/* Simple mixer elements API */ + +/** Mixer simple element channel identifier */ +typedef enum _snd_mixer_selem_channel_id { +	/** Unknown */ +	SND_MIXER_SCHN_UNKNOWN = -1, +	/** Front left */ +	SND_MIXER_SCHN_FRONT_LEFT = 0, +	/** Front right */ +	SND_MIXER_SCHN_FRONT_RIGHT, +	/** Rear left */ +	SND_MIXER_SCHN_REAR_LEFT, +	/** Rear right */ +	SND_MIXER_SCHN_REAR_RIGHT, +	/** Front center */ +	SND_MIXER_SCHN_FRONT_CENTER, +	/** Woofer */ +	SND_MIXER_SCHN_WOOFER, +	/** Side Left */ +	SND_MIXER_SCHN_SIDE_LEFT, +	/** Side Right */ +	SND_MIXER_SCHN_SIDE_RIGHT, +	/** Rear Center */ +	SND_MIXER_SCHN_REAR_CENTER, +	SND_MIXER_SCHN_LAST = 31, +	/** Mono (Front left alias) */ +	SND_MIXER_SCHN_MONO = SND_MIXER_SCHN_FRONT_LEFT +} snd_mixer_selem_channel_id_t; + +/** Mixer simple element - register options - abstraction level */ +enum snd_mixer_selem_regopt_abstract { +	/** no abstraction - try use all universal controls from driver */ +	SND_MIXER_SABSTRACT_NONE = 0, +	/** basic abstraction - Master,PCM,CD,Aux,Record-Gain etc. */ +	SND_MIXER_SABSTRACT_BASIC, +}; + +/** Mixer simple element - register options */ +struct snd_mixer_selem_regopt { +	/** structure version */ +	int ver; +	/** v1: abstract layer selection */ +	enum snd_mixer_selem_regopt_abstract abstract; +	/** v1: device name (must be NULL when playback_pcm or capture_pcm != NULL) */ +	const char *device; +	/** v1: playback PCM connected to mixer device (NULL == none) */ +	snd_pcm_t *playback_pcm; +	/** v1: capture PCM connected to mixer device (NULL == none) */ +	snd_pcm_t *capture_pcm; +}; + +/** Mixer simple element identifier */ +typedef struct _snd_mixer_selem_id snd_mixer_selem_id_t; + +const char *snd_mixer_selem_channel_name(snd_mixer_selem_channel_id_t channel); + +int snd_mixer_selem_register(snd_mixer_t *mixer, +			     struct snd_mixer_selem_regopt *options, +			     snd_mixer_class_t **classp); +void snd_mixer_selem_get_id(snd_mixer_elem_t *element, +			    snd_mixer_selem_id_t *id); +const char *snd_mixer_selem_get_name(snd_mixer_elem_t *elem); +unsigned int snd_mixer_selem_get_index(snd_mixer_elem_t *elem); +snd_mixer_elem_t *snd_mixer_find_selem(snd_mixer_t *mixer, +				       const snd_mixer_selem_id_t *id); + +int snd_mixer_selem_is_active(snd_mixer_elem_t *elem); +int snd_mixer_selem_is_playback_mono(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_playback_channel(snd_mixer_elem_t *obj, snd_mixer_selem_channel_id_t channel); +int snd_mixer_selem_is_capture_mono(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_capture_channel(snd_mixer_elem_t *obj, snd_mixer_selem_channel_id_t channel); +int snd_mixer_selem_get_capture_group(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_common_volume(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_playback_volume(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_playback_volume_joined(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_capture_volume(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_capture_volume_joined(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_common_switch(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_playback_switch(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_playback_switch_joined(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_capture_switch(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_capture_switch_joined(snd_mixer_elem_t *elem); +int snd_mixer_selem_has_capture_switch_exclusive(snd_mixer_elem_t *elem); + +int snd_mixer_selem_ask_playback_vol_dB(snd_mixer_elem_t *elem, long value, long *dBvalue); +int snd_mixer_selem_ask_capture_vol_dB(snd_mixer_elem_t *elem, long value, long *dBvalue); +int snd_mixer_selem_ask_playback_dB_vol(snd_mixer_elem_t *elem, long dBvalue, int dir, long *value); +int snd_mixer_selem_ask_capture_dB_vol(snd_mixer_elem_t *elem, long dBvalue, int dir, long *value); +int snd_mixer_selem_get_playback_volume(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long *value); +int snd_mixer_selem_get_capture_volume(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long *value); +int snd_mixer_selem_get_playback_dB(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long *value); +int snd_mixer_selem_get_capture_dB(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long *value); +int snd_mixer_selem_get_playback_switch(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, int *value); +int snd_mixer_selem_get_capture_switch(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, int *value); +int snd_mixer_selem_set_playback_volume(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long value); +int snd_mixer_selem_set_capture_volume(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long value); +int snd_mixer_selem_set_playback_dB(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long value, int dir); +int snd_mixer_selem_set_capture_dB(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, long value, int dir); +int snd_mixer_selem_set_playback_volume_all(snd_mixer_elem_t *elem, long value); +int snd_mixer_selem_set_capture_volume_all(snd_mixer_elem_t *elem, long value); +int snd_mixer_selem_set_playback_dB_all(snd_mixer_elem_t *elem, long value, int dir); +int snd_mixer_selem_set_capture_dB_all(snd_mixer_elem_t *elem, long value, int dir); +int snd_mixer_selem_set_playback_switch(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, int value); +int snd_mixer_selem_set_capture_switch(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, int value); +int snd_mixer_selem_set_playback_switch_all(snd_mixer_elem_t *elem, int value); +int snd_mixer_selem_set_capture_switch_all(snd_mixer_elem_t *elem, int value); +int snd_mixer_selem_get_playback_volume_range(snd_mixer_elem_t *elem,  +					      long *min, long *max); +int snd_mixer_selem_get_playback_dB_range(snd_mixer_elem_t *elem,  +					  long *min, long *max); +int snd_mixer_selem_set_playback_volume_range(snd_mixer_elem_t *elem,  +					      long min, long max); +int snd_mixer_selem_get_capture_volume_range(snd_mixer_elem_t *elem,  +					     long *min, long *max); +int snd_mixer_selem_get_capture_dB_range(snd_mixer_elem_t *elem,  +					 long *min, long *max); +int snd_mixer_selem_set_capture_volume_range(snd_mixer_elem_t *elem,  +					     long min, long max); + +int snd_mixer_selem_is_enumerated(snd_mixer_elem_t *elem); +int snd_mixer_selem_is_enum_playback(snd_mixer_elem_t *elem); +int snd_mixer_selem_is_enum_capture(snd_mixer_elem_t *elem); +int snd_mixer_selem_get_enum_items(snd_mixer_elem_t *elem); +int snd_mixer_selem_get_enum_item_name(snd_mixer_elem_t *elem, unsigned int idx, size_t maxlen, char *str); +int snd_mixer_selem_get_enum_item(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, unsigned int *idxp); +int snd_mixer_selem_set_enum_item(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, unsigned int idx); + +size_t snd_mixer_selem_id_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_mixer_selem_id_t using standard alloca + * \param ptr returned pointer + */ +#define snd_mixer_selem_id_alloca(ptr) __snd_alloca(ptr, snd_mixer_selem_id) +int snd_mixer_selem_id_malloc(snd_mixer_selem_id_t **ptr); +void snd_mixer_selem_id_free(snd_mixer_selem_id_t *obj); +void snd_mixer_selem_id_copy(snd_mixer_selem_id_t *dst, const snd_mixer_selem_id_t *src); +const char *snd_mixer_selem_id_get_name(const snd_mixer_selem_id_t *obj); +unsigned int snd_mixer_selem_id_get_index(const snd_mixer_selem_id_t *obj); +void snd_mixer_selem_id_set_name(snd_mixer_selem_id_t *obj, const char *val); +void snd_mixer_selem_id_set_index(snd_mixer_selem_id_t *obj, unsigned int val); + +/** \} */ + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_MIXER_H */ + diff --git a/include/alsa/mixer_abst.h b/include/alsa/mixer_abst.h new file mode 100644 index 0000000..ea8c096 --- /dev/null +++ b/include/alsa/mixer_abst.h @@ -0,0 +1,112 @@ +/** + * \file include/mixer_abst.h + * \brief Mixer abstract implementation interface library for the ALSA library + * \author Jaroslav Kysela <perex@perex.cz> + * \date 2005 + * + * Mixer abstact implementation interface library for the ALSA library + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_MIXER_ABST_H +#define __ALSA_MIXER_ABST_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Mixer_Abstract Mixer Abstact Module Interface + *  The mixer abstact module interface. + *  \{ + */ + +#define	SM_PLAY			0 +#define SM_CAPT			1 + +#define SM_CAP_GVOLUME		(1<<1) +#define SM_CAP_GSWITCH		(1<<2) +#define SM_CAP_PVOLUME		(1<<3) +#define SM_CAP_PVOLUME_JOIN	(1<<4) +#define SM_CAP_PSWITCH		(1<<5)  +#define SM_CAP_PSWITCH_JOIN	(1<<6)  +#define SM_CAP_CVOLUME		(1<<7)  +#define SM_CAP_CVOLUME_JOIN	(1<<8)  +#define SM_CAP_CSWITCH		(1<<9)  +#define SM_CAP_CSWITCH_JOIN	(1<<10) +#define SM_CAP_CSWITCH_EXCL	(1<<11) +#define SM_CAP_PENUM		(1<<12) +#define SM_CAP_CENUM		(1<<13) +/* SM_CAP_* 24-31 => private for module use */ + +#define SM_OPS_IS_ACTIVE	0 +#define SM_OPS_IS_MONO		1 +#define SM_OPS_IS_CHANNEL	2 +#define SM_OPS_IS_ENUMERATED	3 +#define SM_OPS_IS_ENUMCNT	4 + +#define sm_selem(x)		((sm_selem_t *)((x)->private_data)) +#define sm_selem_ops(x)		((sm_selem_t *)((x)->private_data))->ops + +typedef struct _sm_selem { +	snd_mixer_selem_id_t *id; +	struct sm_elem_ops *ops; +	unsigned int caps; +	unsigned int capture_group; +} sm_selem_t; + +typedef struct _sm_class_basic { +	char *device; +	snd_ctl_t *ctl; +	snd_hctl_t *hctl; +	snd_ctl_card_info_t *info; +} sm_class_basic_t; + +struct sm_elem_ops {	 +	int (*is)(snd_mixer_elem_t *elem, int dir, int cmd, int val); +	int (*get_range)(snd_mixer_elem_t *elem, int dir, long *min, long *max); +	int (*set_range)(snd_mixer_elem_t *elem, int dir, long min, long max); +	int (*get_dB_range)(snd_mixer_elem_t *elem, int dir, long *min, long *max); +	int (*ask_vol_dB)(snd_mixer_elem_t *elem, int dir, long value, long *dbValue); +	int (*ask_dB_vol)(snd_mixer_elem_t *elem, int dir, long dbValue, long *value, int xdir); +	int (*get_volume)(snd_mixer_elem_t *elem, int dir, snd_mixer_selem_channel_id_t channel, long *value); +	int (*get_dB)(snd_mixer_elem_t *elem, int dir, snd_mixer_selem_channel_id_t channel, long *value); +	int (*set_volume)(snd_mixer_elem_t *elem, int dir, snd_mixer_selem_channel_id_t channel, long value); +	int (*set_dB)(snd_mixer_elem_t *elem, int dir, snd_mixer_selem_channel_id_t channel, long value, int xdir); +	int (*get_switch)(snd_mixer_elem_t *elem, int dir, snd_mixer_selem_channel_id_t channel, int *value); +	int (*set_switch)(snd_mixer_elem_t *elem, int dir, snd_mixer_selem_channel_id_t channel, int value); +	int (*enum_item_name)(snd_mixer_elem_t *elem, unsigned int item, size_t maxlen, char *buf); +	int (*get_enum_item)(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, unsigned int *itemp); +	int (*set_enum_item)(snd_mixer_elem_t *elem, snd_mixer_selem_channel_id_t channel, unsigned int item); +}; + +int snd_mixer_selem_compare(const snd_mixer_elem_t *c1, const snd_mixer_elem_t *c2); + +int snd_mixer_sbasic_info(const snd_mixer_class_t *class, sm_class_basic_t *info); +void *snd_mixer_sbasic_get_private(const snd_mixer_class_t *class); +void snd_mixer_sbasic_set_private(const snd_mixer_class_t *class, void *private_data); +void snd_mixer_sbasic_set_private_free(const snd_mixer_class_t *class, void (*private_free)(snd_mixer_class_t *class)); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_MIXER_ABST_H */ + diff --git a/include/alsa/output.h b/include/alsa/output.h new file mode 100644 index 0000000..74ff78a --- /dev/null +++ b/include/alsa/output.h @@ -0,0 +1,86 @@ +/** + * \file include/output.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_OUTPUT_H +#define __ALSA_OUTPUT_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Output Output Interface + * + *  The output functions present an interface similar to the stdio functions + *  on top of different underlying output destinations. + * + *  Many PCM debugging functions (\c snd_pcm_xxx_dump_xxx) use such an output + *  handle to be able to write not only to the screen but also to other + *  destinations, e.g. to files or to memory buffers. + * + *  \{ + */ + +/** + * \brief Internal structure for an output object. + * + * The ALSA library uses a pointer to this structure as a handle to an + * output object. Applications don't access its contents directly. + */ +typedef struct _snd_output snd_output_t; + +/** Output type. */ +typedef enum _snd_output_type { +	/** Output to a stdio stream. */ +	SND_OUTPUT_STDIO, +	/** Output to a memory buffer. */ +	SND_OUTPUT_BUFFER +} snd_output_type_t; + +int snd_output_stdio_open(snd_output_t **outputp, const char *file, const char *mode); +int snd_output_stdio_attach(snd_output_t **outputp, FILE *fp, int _close); +int snd_output_buffer_open(snd_output_t **outputp); +size_t snd_output_buffer_string(snd_output_t *output, char **buf); +int snd_output_close(snd_output_t *output); +int snd_output_printf(snd_output_t *output, const char *format, ...) +#ifndef DOC_HIDDEN +	__attribute__ ((format (printf, 2, 3))) +#endif +	; +int snd_output_vprintf(snd_output_t *output, const char *format, va_list args); +int snd_output_puts(snd_output_t *output, const char *str); +int snd_output_putc(snd_output_t *output, int c); +int snd_output_flush(snd_output_t *output); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_OUTPUT_H */ + diff --git a/include/alsa/pcm.h b/include/alsa/pcm.h new file mode 100644 index 0000000..5b07823 --- /dev/null +++ b/include/alsa/pcm.h @@ -0,0 +1,1356 @@ +/** + * \file include/pcm.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver. + * See the \ref pcm page for more details. + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_PCM_H +#define __ALSA_PCM_H + +#ifdef __cplusplus +extern "C" { +#endif + +#include <stdint.h> + +/** + *  \defgroup PCM PCM Interface + *  See the \ref pcm page for more details. + *  \{ + */ + +/** dlsym version for interface entry callback */ +#define SND_PCM_DLSYM_VERSION		_dlsym_pcm_001 + +/** PCM generic info container */ +typedef struct _snd_pcm_info snd_pcm_info_t; + +/** PCM hardware configuration space container + * + *  snd_pcm_hw_params_t is an opaque structure which contains a set of possible + *  PCM hardware configurations. For example, a given instance might include a + *  range of buffer sizes, a range of period sizes, and a set of several sample + *  formats. Some subset of all possible combinations these sets may be valid, + *  but not necessarily any combination will be valid. + * + *  When a parameter is set or restricted using a snd_pcm_hw_params_set* + *  function, all of the other ranges will be updated to exclude as many + *  impossible configurations as possible. Attempting to set a parameter + *  outside of its acceptable range will result in the function failing + *  and an error code being returned. + */ +typedef struct _snd_pcm_hw_params snd_pcm_hw_params_t; + +/** PCM software configuration container */ +typedef struct _snd_pcm_sw_params snd_pcm_sw_params_t; +/** PCM status container */ + typedef struct _snd_pcm_status snd_pcm_status_t; +/** PCM access types mask */ +typedef struct _snd_pcm_access_mask snd_pcm_access_mask_t; +/** PCM formats mask */ +typedef struct _snd_pcm_format_mask snd_pcm_format_mask_t; +/** PCM subformats mask */ +typedef struct _snd_pcm_subformat_mask snd_pcm_subformat_mask_t; + +/** PCM class */ +typedef enum _snd_pcm_class { +	/** standard device */ + +	SND_PCM_CLASS_GENERIC = 0, +	/** multichannel device */ +	SND_PCM_CLASS_MULTI, +	/** software modem device */ +	SND_PCM_CLASS_MODEM, +	/** digitizer device */ +	SND_PCM_CLASS_DIGITIZER, +	SND_PCM_CLASS_LAST = SND_PCM_CLASS_DIGITIZER +} snd_pcm_class_t; + +/** PCM subclass */ +typedef enum _snd_pcm_subclass { +	/** subdevices are mixed together */ +	SND_PCM_SUBCLASS_GENERIC_MIX = 0, +	/** multichannel subdevices are mixed together */ +	SND_PCM_SUBCLASS_MULTI_MIX, +	SND_PCM_SUBCLASS_LAST = SND_PCM_SUBCLASS_MULTI_MIX +} snd_pcm_subclass_t; + +/** PCM stream (direction) */ +typedef enum _snd_pcm_stream { +	/** Playback stream */ +	SND_PCM_STREAM_PLAYBACK = 0, +	/** Capture stream */ +	SND_PCM_STREAM_CAPTURE, +	SND_PCM_STREAM_LAST = SND_PCM_STREAM_CAPTURE +} snd_pcm_stream_t; + +/** PCM access type */ +typedef enum _snd_pcm_access { +	/** mmap access with simple interleaved channels */ +	SND_PCM_ACCESS_MMAP_INTERLEAVED = 0, +	/** mmap access with simple non interleaved channels */ +	SND_PCM_ACCESS_MMAP_NONINTERLEAVED, +	/** mmap access with complex placement */ +	SND_PCM_ACCESS_MMAP_COMPLEX, +	/** snd_pcm_readi/snd_pcm_writei access */ +	SND_PCM_ACCESS_RW_INTERLEAVED, +	/** snd_pcm_readn/snd_pcm_writen access */ +	SND_PCM_ACCESS_RW_NONINTERLEAVED, +	SND_PCM_ACCESS_LAST = SND_PCM_ACCESS_RW_NONINTERLEAVED +} snd_pcm_access_t; + +/** PCM sample format */ +typedef enum _snd_pcm_format { +	/** Unknown */ +	SND_PCM_FORMAT_UNKNOWN = -1, +	/** Signed 8 bit */ +	SND_PCM_FORMAT_S8 = 0, +	/** Unsigned 8 bit */ +	SND_PCM_FORMAT_U8, +	/** Signed 16 bit Little Endian */ +	SND_PCM_FORMAT_S16_LE, +	/** Signed 16 bit Big Endian */ +	SND_PCM_FORMAT_S16_BE, +	/** Unsigned 16 bit Little Endian */ +	SND_PCM_FORMAT_U16_LE, +	/** Unsigned 16 bit Big Endian */ +	SND_PCM_FORMAT_U16_BE, +	/** Signed 24 bit Little Endian using low three bytes in 32-bit word */ +	SND_PCM_FORMAT_S24_LE, +	/** Signed 24 bit Big Endian using low three bytes in 32-bit word */ +	SND_PCM_FORMAT_S24_BE, +	/** Unsigned 24 bit Little Endian using low three bytes in 32-bit word */ +	SND_PCM_FORMAT_U24_LE, +	/** Unsigned 24 bit Big Endian using low three bytes in 32-bit word */ +	SND_PCM_FORMAT_U24_BE, +	/** Signed 32 bit Little Endian */ +	SND_PCM_FORMAT_S32_LE, +	/** Signed 32 bit Big Endian */ +	SND_PCM_FORMAT_S32_BE, +	/** Unsigned 32 bit Little Endian */ +	SND_PCM_FORMAT_U32_LE, +	/** Unsigned 32 bit Big Endian */ +	SND_PCM_FORMAT_U32_BE, +	/** Float 32 bit Little Endian, Range -1.0 to 1.0 */ +	SND_PCM_FORMAT_FLOAT_LE, +	/** Float 32 bit Big Endian, Range -1.0 to 1.0 */ +	SND_PCM_FORMAT_FLOAT_BE, +	/** Float 64 bit Little Endian, Range -1.0 to 1.0 */ +	SND_PCM_FORMAT_FLOAT64_LE, +	/** Float 64 bit Big Endian, Range -1.0 to 1.0 */ +	SND_PCM_FORMAT_FLOAT64_BE, +	/** IEC-958 Little Endian */ +	SND_PCM_FORMAT_IEC958_SUBFRAME_LE, +	/** IEC-958 Big Endian */ +	SND_PCM_FORMAT_IEC958_SUBFRAME_BE, +	/** Mu-Law */ +	SND_PCM_FORMAT_MU_LAW, +	/** A-Law */ +	SND_PCM_FORMAT_A_LAW, +	/** Ima-ADPCM */ +	SND_PCM_FORMAT_IMA_ADPCM, +	/** MPEG */ +	SND_PCM_FORMAT_MPEG, +	/** GSM */ +	SND_PCM_FORMAT_GSM, +	/** Signed 20bit Little Endian in 4bytes format, LSB justified */ +	SND_PCM_FORMAT_S20_LE, +	/** Signed 20bit Big Endian in 4bytes format, LSB justified */ +	SND_PCM_FORMAT_S20_BE, +	/** Unsigned 20bit Little Endian in 4bytes format, LSB justified */ +	SND_PCM_FORMAT_U20_LE, +	/** Unsigned 20bit Big Endian in 4bytes format, LSB justified */ +	SND_PCM_FORMAT_U20_BE, +	/** Special */ +	SND_PCM_FORMAT_SPECIAL = 31, +	/** Signed 24bit Little Endian in 3bytes format */ +	SND_PCM_FORMAT_S24_3LE = 32, +	/** Signed 24bit Big Endian in 3bytes format */ +	SND_PCM_FORMAT_S24_3BE, +	/** Unsigned 24bit Little Endian in 3bytes format */ +	SND_PCM_FORMAT_U24_3LE, +	/** Unsigned 24bit Big Endian in 3bytes format */ +	SND_PCM_FORMAT_U24_3BE, +	/** Signed 20bit Little Endian in 3bytes format */ +	SND_PCM_FORMAT_S20_3LE, +	/** Signed 20bit Big Endian in 3bytes format */ +	SND_PCM_FORMAT_S20_3BE, +	/** Unsigned 20bit Little Endian in 3bytes format */ +	SND_PCM_FORMAT_U20_3LE, +	/** Unsigned 20bit Big Endian in 3bytes format */ +	SND_PCM_FORMAT_U20_3BE, +	/** Signed 18bit Little Endian in 3bytes format */ +	SND_PCM_FORMAT_S18_3LE, +	/** Signed 18bit Big Endian in 3bytes format */ +	SND_PCM_FORMAT_S18_3BE, +	/** Unsigned 18bit Little Endian in 3bytes format */ +	SND_PCM_FORMAT_U18_3LE, +	/** Unsigned 18bit Big Endian in 3bytes format */ +	SND_PCM_FORMAT_U18_3BE, +	/* G.723 (ADPCM) 24 kbit/s, 8 samples in 3 bytes */ +	SND_PCM_FORMAT_G723_24, +	/* G.723 (ADPCM) 24 kbit/s, 1 sample in 1 byte */ +	SND_PCM_FORMAT_G723_24_1B, +	/* G.723 (ADPCM) 40 kbit/s, 8 samples in 3 bytes */ +	SND_PCM_FORMAT_G723_40, +	/* G.723 (ADPCM) 40 kbit/s, 1 sample in 1 byte */ +	SND_PCM_FORMAT_G723_40_1B, +	/* Direct Stream Digital (DSD) in 1-byte samples (x8) */ +	SND_PCM_FORMAT_DSD_U8, +	/* Direct Stream Digital (DSD) in 2-byte samples (x16) */ +	SND_PCM_FORMAT_DSD_U16_LE, +	/* Direct Stream Digital (DSD) in 4-byte samples (x32) */ +	SND_PCM_FORMAT_DSD_U32_LE, +	/* Direct Stream Digital (DSD) in 2-byte samples (x16) */ +	SND_PCM_FORMAT_DSD_U16_BE, +	/* Direct Stream Digital (DSD) in 4-byte samples (x32) */ +	SND_PCM_FORMAT_DSD_U32_BE, +	SND_PCM_FORMAT_LAST = SND_PCM_FORMAT_DSD_U32_BE, + +#if __BYTE_ORDER == __LITTLE_ENDIAN +	/** Signed 16 bit CPU endian */ +	SND_PCM_FORMAT_S16 = SND_PCM_FORMAT_S16_LE, +	/** Unsigned 16 bit CPU endian */ +	SND_PCM_FORMAT_U16 = SND_PCM_FORMAT_U16_LE, +	/** Signed 24 bit CPU endian */ +	SND_PCM_FORMAT_S24 = SND_PCM_FORMAT_S24_LE, +	/** Unsigned 24 bit CPU endian */ +	SND_PCM_FORMAT_U24 = SND_PCM_FORMAT_U24_LE, +	/** Signed 32 bit CPU endian */ +	SND_PCM_FORMAT_S32 = SND_PCM_FORMAT_S32_LE, +	/** Unsigned 32 bit CPU endian */ +	SND_PCM_FORMAT_U32 = SND_PCM_FORMAT_U32_LE, +	/** Float 32 bit CPU endian */ +	SND_PCM_FORMAT_FLOAT = SND_PCM_FORMAT_FLOAT_LE, +	/** Float 64 bit CPU endian */ +	SND_PCM_FORMAT_FLOAT64 = SND_PCM_FORMAT_FLOAT64_LE, +	/** IEC-958 CPU Endian */ +	SND_PCM_FORMAT_IEC958_SUBFRAME = SND_PCM_FORMAT_IEC958_SUBFRAME_LE, +	/** Signed 20bit in 4bytes format, LSB justified, CPU Endian */ +	SND_PCM_FORMAT_S20 = SND_PCM_FORMAT_S20_LE, +	/** Unsigned 20bit in 4bytes format, LSB justified, CPU Endian */ +	SND_PCM_FORMAT_U20 = SND_PCM_FORMAT_U20_LE, +#elif __BYTE_ORDER == __BIG_ENDIAN +	/** Signed 16 bit CPU endian */ +	SND_PCM_FORMAT_S16 = SND_PCM_FORMAT_S16_BE, +	/** Unsigned 16 bit CPU endian */ +	SND_PCM_FORMAT_U16 = SND_PCM_FORMAT_U16_BE, +	/** Signed 24 bit CPU endian */ +	SND_PCM_FORMAT_S24 = SND_PCM_FORMAT_S24_BE, +	/** Unsigned 24 bit CPU endian */ +	SND_PCM_FORMAT_U24 = SND_PCM_FORMAT_U24_BE, +	/** Signed 32 bit CPU endian */ +	SND_PCM_FORMAT_S32 = SND_PCM_FORMAT_S32_BE, +	/** Unsigned 32 bit CPU endian */ +	SND_PCM_FORMAT_U32 = SND_PCM_FORMAT_U32_BE, +	/** Float 32 bit CPU endian */ +	SND_PCM_FORMAT_FLOAT = SND_PCM_FORMAT_FLOAT_BE, +	/** Float 64 bit CPU endian */ +	SND_PCM_FORMAT_FLOAT64 = SND_PCM_FORMAT_FLOAT64_BE, +	/** IEC-958 CPU Endian */ +	SND_PCM_FORMAT_IEC958_SUBFRAME = SND_PCM_FORMAT_IEC958_SUBFRAME_BE, +	/** Signed 20bit in 4bytes format, LSB justified, CPU Endian */ +	SND_PCM_FORMAT_S20 = SND_PCM_FORMAT_S20_BE, +	/** Unsigned 20bit in 4bytes format, LSB justified, CPU Endian */ +	SND_PCM_FORMAT_U20 = SND_PCM_FORMAT_U20_BE, +#else +#error "Unknown endian" +#endif +} snd_pcm_format_t; + +/** PCM sample subformat */ +typedef enum _snd_pcm_subformat { +	/** Standard */ +	SND_PCM_SUBFORMAT_STD = 0, +	SND_PCM_SUBFORMAT_LAST = SND_PCM_SUBFORMAT_STD +} snd_pcm_subformat_t; + +/** PCM state */ +typedef enum _snd_pcm_state { +	/** Open */ +	SND_PCM_STATE_OPEN = 0, +	/** Setup installed */  +	SND_PCM_STATE_SETUP, +	/** Ready to start */ +	SND_PCM_STATE_PREPARED, +	/** Running */ +	SND_PCM_STATE_RUNNING, +	/** Stopped: underrun (playback) or overrun (capture) detected */ +	SND_PCM_STATE_XRUN, +	/** Draining: running (playback) or stopped (capture) */ +	SND_PCM_STATE_DRAINING, +	/** Paused */ +	SND_PCM_STATE_PAUSED, +	/** Hardware is suspended */ +	SND_PCM_STATE_SUSPENDED, +	/** Hardware is disconnected */ +	SND_PCM_STATE_DISCONNECTED, +	SND_PCM_STATE_LAST = SND_PCM_STATE_DISCONNECTED, +	/** Private - used internally in the library - do not use*/ +	SND_PCM_STATE_PRIVATE1 = 1024 +} snd_pcm_state_t; + +/** PCM start mode */ +typedef enum _snd_pcm_start { +	/** Automatic start on data read/write */ +	SND_PCM_START_DATA = 0, +	/** Explicit start */ +	SND_PCM_START_EXPLICIT, +	SND_PCM_START_LAST = SND_PCM_START_EXPLICIT +} snd_pcm_start_t; + +/** PCM xrun mode */ +typedef enum _snd_pcm_xrun { +	/** Xrun detection disabled */ +	SND_PCM_XRUN_NONE = 0, +	/** Stop on xrun detection */ +	SND_PCM_XRUN_STOP, +	SND_PCM_XRUN_LAST = SND_PCM_XRUN_STOP +} snd_pcm_xrun_t; + +/** PCM timestamp mode */ +typedef enum _snd_pcm_tstamp { +	/** No timestamp */ +	SND_PCM_TSTAMP_NONE = 0, +	/** Update timestamp at every hardware position update */ +	SND_PCM_TSTAMP_ENABLE, +	/** Equivalent with #SND_PCM_TSTAMP_ENABLE, +	 * just for compatibility with older versions +	 */ +	SND_PCM_TSTAMP_MMAP = SND_PCM_TSTAMP_ENABLE, +	SND_PCM_TSTAMP_LAST = SND_PCM_TSTAMP_ENABLE +} snd_pcm_tstamp_t; + +typedef enum _snd_pcm_tstamp_type { +	SND_PCM_TSTAMP_TYPE_GETTIMEOFDAY = 0,	/**< gettimeofday equivalent */ +	SND_PCM_TSTAMP_TYPE_MONOTONIC,	/**< posix_clock_monotonic equivalent */ +	SND_PCM_TSTAMP_TYPE_MONOTONIC_RAW,	/**< monotonic_raw (no NTP) */ +	SND_PCM_TSTAMP_TYPE_LAST = SND_PCM_TSTAMP_TYPE_MONOTONIC_RAW, +} snd_pcm_tstamp_type_t; + +typedef struct _snd_pcm_audio_tstamp_config { +	/* 5 of max 16 bits used */ +	unsigned int type_requested:4; +	unsigned int report_delay:1; /* add total delay to A/D or D/A */ +} snd_pcm_audio_tstamp_config_t; + +typedef struct _snd_pcm_audio_tstamp_report { +	/* 6 of max 16 bits used for bit-fields */ + +	/* for backwards compatibility */ +	unsigned int valid:1; + +	/* actual type if hardware could not support requested timestamp */ +	unsigned int actual_type:4; + +	/* accuracy represented in ns units */ +	unsigned int accuracy_report:1; /* 0 if accuracy unknown, 1 if accuracy field is valid */ +	unsigned int accuracy; /* up to 4.29s, will be packed in separate field  */ +} snd_pcm_audio_tstamp_report_t; + +/** Unsigned frames quantity */ +typedef unsigned long snd_pcm_uframes_t; +/** Signed frames quantity */ +typedef long snd_pcm_sframes_t; + +/** Non blocking mode (flag for open mode) \hideinitializer */ +#define SND_PCM_NONBLOCK		0x00000001 +/** Async notification (flag for open mode) \hideinitializer */ +#define SND_PCM_ASYNC			0x00000002 +/** In an abort state (internal, not allowed for open) */ +#define SND_PCM_ABORT			0x00008000 +/** Disable automatic (but not forced!) rate resamplinig */ +#define SND_PCM_NO_AUTO_RESAMPLE	0x00010000 +/** Disable automatic (but not forced!) channel conversion */ +#define SND_PCM_NO_AUTO_CHANNELS	0x00020000 +/** Disable automatic (but not forced!) format conversion */ +#define SND_PCM_NO_AUTO_FORMAT		0x00040000 +/** Disable soft volume control */ +#define SND_PCM_NO_SOFTVOL		0x00080000 + +/** PCM handle */ +typedef struct _snd_pcm snd_pcm_t; + +/** PCM type */ +enum _snd_pcm_type { +	/** Kernel level PCM */ +	SND_PCM_TYPE_HW = 0, +	/** Hooked PCM */ +	SND_PCM_TYPE_HOOKS, +	/** One or more linked PCM with exclusive access to selected +	    channels */ +	SND_PCM_TYPE_MULTI, +	/** File writing plugin */ +	SND_PCM_TYPE_FILE, +	/** Null endpoint PCM */ +	SND_PCM_TYPE_NULL, +	/** Shared memory client PCM */ +	SND_PCM_TYPE_SHM, +	/** INET client PCM (not yet implemented) */ +	SND_PCM_TYPE_INET, +	/** Copying plugin */ +	SND_PCM_TYPE_COPY, +	/** Linear format conversion PCM */ +	SND_PCM_TYPE_LINEAR, +	/** A-Law format conversion PCM */ +	SND_PCM_TYPE_ALAW, +	/** Mu-Law format conversion PCM */ +	SND_PCM_TYPE_MULAW, +	/** IMA-ADPCM format conversion PCM */ +	SND_PCM_TYPE_ADPCM, +	/** Rate conversion PCM */ +	SND_PCM_TYPE_RATE, +	/** Attenuated static route PCM */ +	SND_PCM_TYPE_ROUTE, +	/** Format adjusted PCM */ +	SND_PCM_TYPE_PLUG, +	/** Sharing PCM */ +	SND_PCM_TYPE_SHARE, +	/** Meter plugin */ +	SND_PCM_TYPE_METER, +	/** Mixing PCM */ +	SND_PCM_TYPE_MIX, +	/** Attenuated dynamic route PCM (not yet implemented) */ +	SND_PCM_TYPE_DROUTE, +	/** Loopback server plugin (not yet implemented) */ +	SND_PCM_TYPE_LBSERVER, +	/** Linear Integer <-> Linear Float format conversion PCM */ +	SND_PCM_TYPE_LINEAR_FLOAT, +	/** LADSPA integration plugin */ +	SND_PCM_TYPE_LADSPA, +	/** Direct Mixing plugin */ +	SND_PCM_TYPE_DMIX, +	/** Jack Audio Connection Kit plugin */ +	SND_PCM_TYPE_JACK, +	/** Direct Snooping plugin */ +	SND_PCM_TYPE_DSNOOP, +	/** Direct Sharing plugin */ +	SND_PCM_TYPE_DSHARE, +	/** IEC958 subframe plugin */ +	SND_PCM_TYPE_IEC958, +	/** Soft volume plugin */ +	SND_PCM_TYPE_SOFTVOL, +	/** External I/O plugin */ +	SND_PCM_TYPE_IOPLUG, +	/** External filter plugin */ +	SND_PCM_TYPE_EXTPLUG, +	/** Mmap-emulation plugin */ +	SND_PCM_TYPE_MMAP_EMUL, +	SND_PCM_TYPE_LAST = SND_PCM_TYPE_MMAP_EMUL +}; + +/** PCM type */ +typedef enum _snd_pcm_type snd_pcm_type_t; + +/** PCM area specification */ +typedef struct _snd_pcm_channel_area { +	/** base address of channel samples */ +	void *addr; +	/** offset to first sample in bits */ +	unsigned int first; +	/** samples distance in bits */ +	unsigned int step; +} snd_pcm_channel_area_t; + +/** PCM synchronization ID */ +typedef union _snd_pcm_sync_id { +	/** 8-bit ID */ +	unsigned char id[16]; +	/** 16-bit ID */ +	unsigned short id16[8]; +	/** 32-bit ID */ +	unsigned int id32[4]; +} snd_pcm_sync_id_t; + +/** #SND_PCM_TYPE_METER scope handle */ +typedef struct _snd_pcm_scope snd_pcm_scope_t; + +int snd_pcm_open(snd_pcm_t **pcm, const char *name,  +		 snd_pcm_stream_t stream, int mode); +int snd_pcm_open_lconf(snd_pcm_t **pcm, const char *name,  +		       snd_pcm_stream_t stream, int mode, +		       snd_config_t *lconf); +int snd_pcm_open_fallback(snd_pcm_t **pcm, snd_config_t *root, +			  const char *name, const char *orig_name, +			  snd_pcm_stream_t stream, int mode); + +int snd_pcm_close(snd_pcm_t *pcm); +const char *snd_pcm_name(snd_pcm_t *pcm); +snd_pcm_type_t snd_pcm_type(snd_pcm_t *pcm); +snd_pcm_stream_t snd_pcm_stream(snd_pcm_t *pcm); +int snd_pcm_poll_descriptors_count(snd_pcm_t *pcm); +int snd_pcm_poll_descriptors(snd_pcm_t *pcm, struct pollfd *pfds, unsigned int space); +int snd_pcm_poll_descriptors_revents(snd_pcm_t *pcm, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +int snd_pcm_nonblock(snd_pcm_t *pcm, int nonblock); +static __inline__ int snd_pcm_abort(snd_pcm_t *pcm) { return snd_pcm_nonblock(pcm, 2); } +int snd_async_add_pcm_handler(snd_async_handler_t **handler, snd_pcm_t *pcm,  +			      snd_async_callback_t callback, void *private_data); +snd_pcm_t *snd_async_handler_get_pcm(snd_async_handler_t *handler); +int snd_pcm_info(snd_pcm_t *pcm, snd_pcm_info_t *info); +int snd_pcm_hw_params_current(snd_pcm_t *pcm, snd_pcm_hw_params_t *params); +int snd_pcm_hw_params(snd_pcm_t *pcm, snd_pcm_hw_params_t *params); +int snd_pcm_hw_free(snd_pcm_t *pcm); +int snd_pcm_sw_params_current(snd_pcm_t *pcm, snd_pcm_sw_params_t *params); +int snd_pcm_sw_params(snd_pcm_t *pcm, snd_pcm_sw_params_t *params); +int snd_pcm_prepare(snd_pcm_t *pcm); +int snd_pcm_reset(snd_pcm_t *pcm); +int snd_pcm_status(snd_pcm_t *pcm, snd_pcm_status_t *status); +int snd_pcm_start(snd_pcm_t *pcm); +int snd_pcm_drop(snd_pcm_t *pcm); +int snd_pcm_drain(snd_pcm_t *pcm); +int snd_pcm_pause(snd_pcm_t *pcm, int enable); +snd_pcm_state_t snd_pcm_state(snd_pcm_t *pcm); +int snd_pcm_hwsync(snd_pcm_t *pcm); +int snd_pcm_delay(snd_pcm_t *pcm, snd_pcm_sframes_t *delayp); +int snd_pcm_resume(snd_pcm_t *pcm); +int snd_pcm_htimestamp(snd_pcm_t *pcm, snd_pcm_uframes_t *avail, snd_htimestamp_t *tstamp); +snd_pcm_sframes_t snd_pcm_avail(snd_pcm_t *pcm); +snd_pcm_sframes_t snd_pcm_avail_update(snd_pcm_t *pcm); +int snd_pcm_avail_delay(snd_pcm_t *pcm, snd_pcm_sframes_t *availp, snd_pcm_sframes_t *delayp); +snd_pcm_sframes_t snd_pcm_rewindable(snd_pcm_t *pcm); +snd_pcm_sframes_t snd_pcm_rewind(snd_pcm_t *pcm, snd_pcm_uframes_t frames); +snd_pcm_sframes_t snd_pcm_forwardable(snd_pcm_t *pcm); +snd_pcm_sframes_t snd_pcm_forward(snd_pcm_t *pcm, snd_pcm_uframes_t frames); +snd_pcm_sframes_t snd_pcm_writei(snd_pcm_t *pcm, const void *buffer, snd_pcm_uframes_t size); +snd_pcm_sframes_t snd_pcm_readi(snd_pcm_t *pcm, void *buffer, snd_pcm_uframes_t size); +snd_pcm_sframes_t snd_pcm_writen(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size); +snd_pcm_sframes_t snd_pcm_readn(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size); +int snd_pcm_wait(snd_pcm_t *pcm, int timeout); + +int snd_pcm_link(snd_pcm_t *pcm1, snd_pcm_t *pcm2); +int snd_pcm_unlink(snd_pcm_t *pcm); + +/** channel mapping API version number */ +#define SND_CHMAP_API_VERSION	((1 << 16) | (0 << 8) | 1) + +/** channel map list type */ +enum snd_pcm_chmap_type { +	SND_CHMAP_TYPE_NONE = 0,/**< unspecified channel position */ +	SND_CHMAP_TYPE_FIXED,	/**< fixed channel position */ +	SND_CHMAP_TYPE_VAR,	/**< freely swappable channel position */ +	SND_CHMAP_TYPE_PAIRED,	/**< pair-wise swappable channel position */ +	SND_CHMAP_TYPE_LAST = SND_CHMAP_TYPE_PAIRED, /**< last entry */ +}; + +/** channel positions */ +enum snd_pcm_chmap_position { +	SND_CHMAP_UNKNOWN = 0,	/**< unspecified */ +	SND_CHMAP_NA,		/**< N/A, silent */ +	SND_CHMAP_MONO,		/**< mono stream */ +	SND_CHMAP_FL,		/**< front left */ +	SND_CHMAP_FR,		/**< front right */ +	SND_CHMAP_RL,		/**< rear left */ +	SND_CHMAP_RR,		/**< rear right */ +	SND_CHMAP_FC,		/**< front center */ +	SND_CHMAP_LFE,		/**< LFE */ +	SND_CHMAP_SL,		/**< side left */ +	SND_CHMAP_SR,		/**< side right */ +	SND_CHMAP_RC,		/**< rear center */ +	SND_CHMAP_FLC,		/**< front left center */ +	SND_CHMAP_FRC,		/**< front right center */ +	SND_CHMAP_RLC,		/**< rear left center */ +	SND_CHMAP_RRC,		/**< rear right center */ +	SND_CHMAP_FLW,		/**< front left wide */ +	SND_CHMAP_FRW,		/**< front right wide */ +	SND_CHMAP_FLH,		/**< front left high */ +	SND_CHMAP_FCH,		/**< front center high */ +	SND_CHMAP_FRH,		/**< front right high */ +	SND_CHMAP_TC,		/**< top center */ +	SND_CHMAP_TFL,		/**< top front left */ +	SND_CHMAP_TFR,		/**< top front right */ +	SND_CHMAP_TFC,		/**< top front center */ +	SND_CHMAP_TRL,		/**< top rear left */ +	SND_CHMAP_TRR,		/**< top rear right */ +	SND_CHMAP_TRC,		/**< top rear center */ +	SND_CHMAP_TFLC,		/**< top front left center */ +	SND_CHMAP_TFRC,		/**< top front right center */ +	SND_CHMAP_TSL,		/**< top side left */ +	SND_CHMAP_TSR,		/**< top side right */ +	SND_CHMAP_LLFE,		/**< left LFE */ +	SND_CHMAP_RLFE,		/**< right LFE */ +	SND_CHMAP_BC,		/**< bottom center */ +	SND_CHMAP_BLC,		/**< bottom left center */ +	SND_CHMAP_BRC,		/**< bottom right center */ +	SND_CHMAP_LAST = SND_CHMAP_BRC, +}; + +/** bitmask for channel position */ +#define SND_CHMAP_POSITION_MASK		0xffff + +/** bit flag indicating the channel is phase inverted */ +#define SND_CHMAP_PHASE_INVERSE		(0x01 << 16) +/** bit flag indicating the non-standard channel value */ +#define SND_CHMAP_DRIVER_SPEC		(0x02 << 16) + +/** the channel map header */ +typedef struct snd_pcm_chmap { +	unsigned int channels;	/**< number of channels */ +	unsigned int pos[0];	/**< channel position array */ +} snd_pcm_chmap_t; + +/** the header of array items returned from snd_pcm_query_chmaps() */ +typedef struct snd_pcm_chmap_query { +	enum snd_pcm_chmap_type type;	/**< channel map type */ +	snd_pcm_chmap_t map;		/**< available channel map */ +} snd_pcm_chmap_query_t; + + +snd_pcm_chmap_query_t **snd_pcm_query_chmaps(snd_pcm_t *pcm); +snd_pcm_chmap_query_t **snd_pcm_query_chmaps_from_hw(int card, int dev, +						     int subdev, +						     snd_pcm_stream_t stream); +void snd_pcm_free_chmaps(snd_pcm_chmap_query_t **maps); +snd_pcm_chmap_t *snd_pcm_get_chmap(snd_pcm_t *pcm); +int snd_pcm_set_chmap(snd_pcm_t *pcm, const snd_pcm_chmap_t *map); + +const char *snd_pcm_chmap_type_name(enum snd_pcm_chmap_type val); +const char *snd_pcm_chmap_name(enum snd_pcm_chmap_position val); +const char *snd_pcm_chmap_long_name(enum snd_pcm_chmap_position val); +int snd_pcm_chmap_print(const snd_pcm_chmap_t *map, size_t maxlen, char *buf); +unsigned int snd_pcm_chmap_from_string(const char *str); +snd_pcm_chmap_t *snd_pcm_chmap_parse_string(const char *str); + +//int snd_pcm_mixer_element(snd_pcm_t *pcm, snd_mixer_t *mixer, snd_mixer_elem_t **elem); + +/* + * application helpers - these functions are implemented on top + * of the basic API + */ + +int snd_pcm_recover(snd_pcm_t *pcm, int err, int silent); +int snd_pcm_set_params(snd_pcm_t *pcm, +                       snd_pcm_format_t format, +                       snd_pcm_access_t access, +                       unsigned int channels, +                       unsigned int rate, +                       int soft_resample, +                       unsigned int latency); +int snd_pcm_get_params(snd_pcm_t *pcm, +                       snd_pcm_uframes_t *buffer_size, +                       snd_pcm_uframes_t *period_size); + +/** \} */ + +/** + * \defgroup PCM_Info Stream Information + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +size_t snd_pcm_info_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_pcm_info_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_info_alloca(ptr) __snd_alloca(ptr, snd_pcm_info) +int snd_pcm_info_malloc(snd_pcm_info_t **ptr); +void snd_pcm_info_free(snd_pcm_info_t *obj); +void snd_pcm_info_copy(snd_pcm_info_t *dst, const snd_pcm_info_t *src); +unsigned int snd_pcm_info_get_device(const snd_pcm_info_t *obj); +unsigned int snd_pcm_info_get_subdevice(const snd_pcm_info_t *obj); +snd_pcm_stream_t snd_pcm_info_get_stream(const snd_pcm_info_t *obj); +int snd_pcm_info_get_card(const snd_pcm_info_t *obj); +const char *snd_pcm_info_get_id(const snd_pcm_info_t *obj); +const char *snd_pcm_info_get_name(const snd_pcm_info_t *obj); +const char *snd_pcm_info_get_subdevice_name(const snd_pcm_info_t *obj); +snd_pcm_class_t snd_pcm_info_get_class(const snd_pcm_info_t *obj); +snd_pcm_subclass_t snd_pcm_info_get_subclass(const snd_pcm_info_t *obj); +unsigned int snd_pcm_info_get_subdevices_count(const snd_pcm_info_t *obj); +unsigned int snd_pcm_info_get_subdevices_avail(const snd_pcm_info_t *obj); +snd_pcm_sync_id_t snd_pcm_info_get_sync(const snd_pcm_info_t *obj); +void snd_pcm_info_set_device(snd_pcm_info_t *obj, unsigned int val); +void snd_pcm_info_set_subdevice(snd_pcm_info_t *obj, unsigned int val); +void snd_pcm_info_set_stream(snd_pcm_info_t *obj, snd_pcm_stream_t val); + +/** \} */ + +/** + * \defgroup PCM_HW_Params Hardware Parameters + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +int snd_pcm_hw_params_any(snd_pcm_t *pcm, snd_pcm_hw_params_t *params); + +int snd_pcm_hw_params_can_mmap_sample_resolution(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_is_double(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_is_batch(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_is_block_transfer(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_is_monotonic(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_can_overrange(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_can_pause(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_can_resume(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_is_half_duplex(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_is_joint_duplex(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_can_sync_start(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_can_disable_period_wakeup(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_supports_audio_wallclock_ts(const snd_pcm_hw_params_t *params); /* deprecated, use audio_ts_type */ +int snd_pcm_hw_params_supports_audio_ts_type(const snd_pcm_hw_params_t *params, int type); +int snd_pcm_hw_params_get_rate_numden(const snd_pcm_hw_params_t *params, +				      unsigned int *rate_num, +				      unsigned int *rate_den); +int snd_pcm_hw_params_get_sbits(const snd_pcm_hw_params_t *params); +int snd_pcm_hw_params_get_fifo_size(const snd_pcm_hw_params_t *params); + +#if 0 +typedef struct _snd_pcm_hw_strategy snd_pcm_hw_strategy_t; + +/* choices need to be sorted on ascending badness */ +typedef struct _snd_pcm_hw_strategy_simple_choices_list { +	unsigned int value; +	unsigned int badness; +} snd_pcm_hw_strategy_simple_choices_list_t; + +int snd_pcm_hw_params_strategy(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, +			       const snd_pcm_hw_strategy_t *strategy, +			       unsigned int badness_min, +			       unsigned int badness_max); + +void snd_pcm_hw_strategy_free(snd_pcm_hw_strategy_t *strategy); +int snd_pcm_hw_strategy_simple(snd_pcm_hw_strategy_t **strategyp, +			       unsigned int badness_min, +			       unsigned int badness_max); +int snd_pcm_hw_params_try_explain_failure(snd_pcm_t *pcm, +					  snd_pcm_hw_params_t *fail, +					  snd_pcm_hw_params_t *success, +					  unsigned int depth, +					  snd_output_t *out); + +#endif + +size_t snd_pcm_hw_params_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_pcm_hw_params_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_hw_params_alloca(ptr) __snd_alloca(ptr, snd_pcm_hw_params) +int snd_pcm_hw_params_malloc(snd_pcm_hw_params_t **ptr); +void snd_pcm_hw_params_free(snd_pcm_hw_params_t *obj); +void snd_pcm_hw_params_copy(snd_pcm_hw_params_t *dst, const snd_pcm_hw_params_t *src); + +#if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_HW_PARAMS_API) + +int snd_pcm_hw_params_get_access(const snd_pcm_hw_params_t *params, snd_pcm_access_t *_access); +int snd_pcm_hw_params_test_access(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t _access); +int snd_pcm_hw_params_set_access(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t _access); +int snd_pcm_hw_params_set_access_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t *_access); +int snd_pcm_hw_params_set_access_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t *_access); +int snd_pcm_hw_params_set_access_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_mask_t *mask); +int snd_pcm_hw_params_get_access_mask(snd_pcm_hw_params_t *params, snd_pcm_access_mask_t *mask); + +int snd_pcm_hw_params_get_format(const snd_pcm_hw_params_t *params, snd_pcm_format_t *val); +int snd_pcm_hw_params_test_format(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t val); +int snd_pcm_hw_params_set_format(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t val); +int snd_pcm_hw_params_set_format_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t *format); +int snd_pcm_hw_params_set_format_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t *format); +int snd_pcm_hw_params_set_format_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_mask_t *mask); +void snd_pcm_hw_params_get_format_mask(snd_pcm_hw_params_t *params, snd_pcm_format_mask_t *mask); + +int snd_pcm_hw_params_get_subformat(const snd_pcm_hw_params_t *params, snd_pcm_subformat_t *subformat); +int snd_pcm_hw_params_test_subformat(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t subformat); +int snd_pcm_hw_params_set_subformat(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t subformat); +int snd_pcm_hw_params_set_subformat_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t *subformat); +int snd_pcm_hw_params_set_subformat_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t *subformat); +int snd_pcm_hw_params_set_subformat_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_mask_t *mask); +void snd_pcm_hw_params_get_subformat_mask(snd_pcm_hw_params_t *params, snd_pcm_subformat_mask_t *mask); + +int snd_pcm_hw_params_get_channels(const snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_get_channels_min(const snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_get_channels_max(const snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_test_channels(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val); +int snd_pcm_hw_params_set_channels(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val); +int snd_pcm_hw_params_set_channels_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_set_channels_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_set_channels_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, unsigned int *max); +int snd_pcm_hw_params_set_channels_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_set_channels_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_set_channels_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); + +int snd_pcm_hw_params_get_rate(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_rate_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_rate_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_test_rate(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_rate(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_rate_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_rate_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_rate_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir); +int snd_pcm_hw_params_set_rate_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_rate_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_rate_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_rate_resample(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val); +int snd_pcm_hw_params_get_rate_resample(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_set_export_buffer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val); +int snd_pcm_hw_params_get_export_buffer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); +int snd_pcm_hw_params_set_period_wakeup(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val); +int snd_pcm_hw_params_get_period_wakeup(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val); + +int snd_pcm_hw_params_get_period_time(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_period_time_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_period_time_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_test_period_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_period_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_period_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_period_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_period_time_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir); +int snd_pcm_hw_params_set_period_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_period_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_period_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); + +int snd_pcm_hw_params_get_period_size(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *frames, int *dir); +int snd_pcm_hw_params_get_period_size_min(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *frames, int *dir); +int snd_pcm_hw_params_get_period_size_max(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *frames, int *dir); +int snd_pcm_hw_params_test_period_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val, int dir); +int snd_pcm_hw_params_set_period_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val, int dir); +int snd_pcm_hw_params_set_period_size_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir); +int snd_pcm_hw_params_set_period_size_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir); +int snd_pcm_hw_params_set_period_size_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *min, int *mindir, snd_pcm_uframes_t *max, int *maxdir); +int snd_pcm_hw_params_set_period_size_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir); +int snd_pcm_hw_params_set_period_size_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir); +int snd_pcm_hw_params_set_period_size_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir); +int snd_pcm_hw_params_set_period_size_integer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params); + +int snd_pcm_hw_params_get_periods(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_periods_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_periods_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_test_periods(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_periods(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_periods_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_periods_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_periods_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir); +int snd_pcm_hw_params_set_periods_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_periods_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_periods_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_periods_integer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params); + +int snd_pcm_hw_params_get_buffer_time(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_buffer_time_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_get_buffer_time_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_test_buffer_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_buffer_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir); +int snd_pcm_hw_params_set_buffer_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_buffer_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_buffer_time_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir); +int snd_pcm_hw_params_set_buffer_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_buffer_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); +int snd_pcm_hw_params_set_buffer_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir); + +int snd_pcm_hw_params_get_buffer_size(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_get_buffer_size_min(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_get_buffer_size_max(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_test_buffer_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_hw_params_set_buffer_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_hw_params_set_buffer_size_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_set_buffer_size_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_set_buffer_size_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *min, snd_pcm_uframes_t *max); +int snd_pcm_hw_params_set_buffer_size_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_set_buffer_size_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_hw_params_set_buffer_size_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); + +#endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_HW_PARAMS_API */ + +int snd_pcm_hw_params_get_min_align(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val); + +/** \} */ + +/** + * \defgroup PCM_SW_Params Software Parameters + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +size_t snd_pcm_sw_params_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_pcm_sw_params_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_sw_params_alloca(ptr) __snd_alloca(ptr, snd_pcm_sw_params) +int snd_pcm_sw_params_malloc(snd_pcm_sw_params_t **ptr); +void snd_pcm_sw_params_free(snd_pcm_sw_params_t *obj); +void snd_pcm_sw_params_copy(snd_pcm_sw_params_t *dst, const snd_pcm_sw_params_t *src); +int snd_pcm_sw_params_get_boundary(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val); + +#if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_SW_PARAMS_API) + +int snd_pcm_sw_params_set_tstamp_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_tstamp_t val); +int snd_pcm_sw_params_get_tstamp_mode(const snd_pcm_sw_params_t *params, snd_pcm_tstamp_t *val); +int snd_pcm_sw_params_set_tstamp_type(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_tstamp_type_t val); +int snd_pcm_sw_params_get_tstamp_type(const snd_pcm_sw_params_t *params, snd_pcm_tstamp_type_t *val); +int snd_pcm_sw_params_set_avail_min(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_sw_params_get_avail_min(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_sw_params_set_period_event(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, int val); +int snd_pcm_sw_params_get_period_event(const snd_pcm_sw_params_t *params, int *val); +int snd_pcm_sw_params_set_start_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_sw_params_get_start_threshold(const snd_pcm_sw_params_t *paramsm, snd_pcm_uframes_t *val); +int snd_pcm_sw_params_set_stop_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_sw_params_get_stop_threshold(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_sw_params_set_silence_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_sw_params_get_silence_threshold(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val); +int snd_pcm_sw_params_set_silence_size(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val); +int snd_pcm_sw_params_get_silence_size(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val); + +#endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_SW_PARAMS_API */ + +/** \} */ + +/* include old API */ +#ifndef ALSA_LIBRARY_BUILD +#if defined(ALSA_PCM_OLD_HW_PARAMS_API) || defined(ALSA_PCM_OLD_SW_PARAMS_API) +#include "pcm_old.h" +#endif +#endif + +/** + * \defgroup PCM_Access Access Mask Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +size_t snd_pcm_access_mask_sizeof(void); +/** \hideinitializer + * \brief allocate an empty #snd_pcm_access_mask_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_access_mask_alloca(ptr) __snd_alloca(ptr, snd_pcm_access_mask) +int snd_pcm_access_mask_malloc(snd_pcm_access_mask_t **ptr); +void snd_pcm_access_mask_free(snd_pcm_access_mask_t *obj); +void snd_pcm_access_mask_copy(snd_pcm_access_mask_t *dst, const snd_pcm_access_mask_t *src); +void snd_pcm_access_mask_none(snd_pcm_access_mask_t *mask); +void snd_pcm_access_mask_any(snd_pcm_access_mask_t *mask); +int snd_pcm_access_mask_test(const snd_pcm_access_mask_t *mask, snd_pcm_access_t val); +int snd_pcm_access_mask_empty(const snd_pcm_access_mask_t *mask); +void snd_pcm_access_mask_set(snd_pcm_access_mask_t *mask, snd_pcm_access_t val); +void snd_pcm_access_mask_reset(snd_pcm_access_mask_t *mask, snd_pcm_access_t val); + +/** \} */ + +/** + * \defgroup PCM_Format Format Mask Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +size_t snd_pcm_format_mask_sizeof(void); +/** \hideinitializer + * \brief allocate an empty #snd_pcm_format_mask_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_format_mask_alloca(ptr) __snd_alloca(ptr, snd_pcm_format_mask) +int snd_pcm_format_mask_malloc(snd_pcm_format_mask_t **ptr); +void snd_pcm_format_mask_free(snd_pcm_format_mask_t *obj); +void snd_pcm_format_mask_copy(snd_pcm_format_mask_t *dst, const snd_pcm_format_mask_t *src); +void snd_pcm_format_mask_none(snd_pcm_format_mask_t *mask); +void snd_pcm_format_mask_any(snd_pcm_format_mask_t *mask); +int snd_pcm_format_mask_test(const snd_pcm_format_mask_t *mask, snd_pcm_format_t val); +int snd_pcm_format_mask_empty(const snd_pcm_format_mask_t *mask); +void snd_pcm_format_mask_set(snd_pcm_format_mask_t *mask, snd_pcm_format_t val); +void snd_pcm_format_mask_reset(snd_pcm_format_mask_t *mask, snd_pcm_format_t val); + +/** \} */ + +/** + * \defgroup PCM_SubFormat Subformat Mask Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +size_t snd_pcm_subformat_mask_sizeof(void); +/** \hideinitializer + * \brief allocate an empty #snd_pcm_subformat_mask_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_subformat_mask_alloca(ptr) __snd_alloca(ptr, snd_pcm_subformat_mask) +int snd_pcm_subformat_mask_malloc(snd_pcm_subformat_mask_t **ptr); +void snd_pcm_subformat_mask_free(snd_pcm_subformat_mask_t *obj); +void snd_pcm_subformat_mask_copy(snd_pcm_subformat_mask_t *dst, const snd_pcm_subformat_mask_t *src); +void snd_pcm_subformat_mask_none(snd_pcm_subformat_mask_t *mask); +void snd_pcm_subformat_mask_any(snd_pcm_subformat_mask_t *mask); +int snd_pcm_subformat_mask_test(const snd_pcm_subformat_mask_t *mask, snd_pcm_subformat_t val); +int snd_pcm_subformat_mask_empty(const snd_pcm_subformat_mask_t *mask); +void snd_pcm_subformat_mask_set(snd_pcm_subformat_mask_t *mask, snd_pcm_subformat_t val); +void snd_pcm_subformat_mask_reset(snd_pcm_subformat_mask_t *mask, snd_pcm_subformat_t val); + +/** \} */ + +/** + * \defgroup PCM_Status Status Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +size_t snd_pcm_status_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_pcm_status_t using standard alloca + * \param ptr returned pointer + */ +#define snd_pcm_status_alloca(ptr) __snd_alloca(ptr, snd_pcm_status) +int snd_pcm_status_malloc(snd_pcm_status_t **ptr); +void snd_pcm_status_free(snd_pcm_status_t *obj); +void snd_pcm_status_copy(snd_pcm_status_t *dst, const snd_pcm_status_t *src); +snd_pcm_state_t snd_pcm_status_get_state(const snd_pcm_status_t *obj); +void snd_pcm_status_get_trigger_tstamp(const snd_pcm_status_t *obj, snd_timestamp_t *ptr); +void snd_pcm_status_get_trigger_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr); +void snd_pcm_status_get_tstamp(const snd_pcm_status_t *obj, snd_timestamp_t *ptr); +void snd_pcm_status_get_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr); +void snd_pcm_status_get_audio_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr); +void snd_pcm_status_get_driver_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr); +void snd_pcm_status_get_audio_htstamp_report(const snd_pcm_status_t *obj, +					     snd_pcm_audio_tstamp_report_t *audio_tstamp_report); +void snd_pcm_status_set_audio_htstamp_config(snd_pcm_status_t *obj, +					     snd_pcm_audio_tstamp_config_t *audio_tstamp_config); + +static inline void snd_pcm_pack_audio_tstamp_config(unsigned int *data, +						snd_pcm_audio_tstamp_config_t *config) +{ +	*data = config->report_delay; +	*data <<= 4; +	*data |= config->type_requested; +} + +static inline void snd_pcm_unpack_audio_tstamp_report(unsigned int data, unsigned int accuracy, +						snd_pcm_audio_tstamp_report_t *report) +{ +	data >>= 16; +	report->valid = data & 1; +	report->actual_type = (data >> 1) & 0xF; +	report->accuracy_report = (data >> 5) & 1; +	report->accuracy = accuracy; +} + +snd_pcm_sframes_t snd_pcm_status_get_delay(const snd_pcm_status_t *obj); +snd_pcm_uframes_t snd_pcm_status_get_avail(const snd_pcm_status_t *obj); +snd_pcm_uframes_t snd_pcm_status_get_avail_max(const snd_pcm_status_t *obj); +snd_pcm_uframes_t snd_pcm_status_get_overrange(const snd_pcm_status_t *obj); + +/** \} */ + +/** + * \defgroup PCM_Description Description Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +const char *snd_pcm_type_name(snd_pcm_type_t type); +const char *snd_pcm_stream_name(const snd_pcm_stream_t stream); +const char *snd_pcm_access_name(const snd_pcm_access_t _access); +const char *snd_pcm_format_name(const snd_pcm_format_t format); +const char *snd_pcm_format_description(const snd_pcm_format_t format); +const char *snd_pcm_subformat_name(const snd_pcm_subformat_t subformat); +const char *snd_pcm_subformat_description(const snd_pcm_subformat_t subformat); +snd_pcm_format_t snd_pcm_format_value(const char* name); +const char *snd_pcm_tstamp_mode_name(const snd_pcm_tstamp_t mode); +const char *snd_pcm_state_name(const snd_pcm_state_t state); + +/** \} */ + +/** + * \defgroup PCM_Dump Debug Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +int snd_pcm_dump(snd_pcm_t *pcm, snd_output_t *out); +int snd_pcm_dump_hw_setup(snd_pcm_t *pcm, snd_output_t *out); +int snd_pcm_dump_sw_setup(snd_pcm_t *pcm, snd_output_t *out); +int snd_pcm_dump_setup(snd_pcm_t *pcm, snd_output_t *out); +int snd_pcm_hw_params_dump(snd_pcm_hw_params_t *params, snd_output_t *out); +int snd_pcm_sw_params_dump(snd_pcm_sw_params_t *params, snd_output_t *out); +int snd_pcm_status_dump(snd_pcm_status_t *status, snd_output_t *out); + +/** \} */ + +/** + * \defgroup PCM_Direct Direct Access (MMAP) Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +int snd_pcm_mmap_begin(snd_pcm_t *pcm, +		       const snd_pcm_channel_area_t **areas, +		       snd_pcm_uframes_t *offset, +		       snd_pcm_uframes_t *frames); +snd_pcm_sframes_t snd_pcm_mmap_commit(snd_pcm_t *pcm, +				      snd_pcm_uframes_t offset, +				      snd_pcm_uframes_t frames); +snd_pcm_sframes_t snd_pcm_mmap_writei(snd_pcm_t *pcm, const void *buffer, snd_pcm_uframes_t size); +snd_pcm_sframes_t snd_pcm_mmap_readi(snd_pcm_t *pcm, void *buffer, snd_pcm_uframes_t size); +snd_pcm_sframes_t snd_pcm_mmap_writen(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size); +snd_pcm_sframes_t snd_pcm_mmap_readn(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size);                                                                 + +/** \} */ + +/** + * \defgroup PCM_Helpers Helper Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +int snd_pcm_format_signed(snd_pcm_format_t format); +int snd_pcm_format_unsigned(snd_pcm_format_t format); +int snd_pcm_format_linear(snd_pcm_format_t format); +int snd_pcm_format_float(snd_pcm_format_t format); +int snd_pcm_format_little_endian(snd_pcm_format_t format); +int snd_pcm_format_big_endian(snd_pcm_format_t format); +int snd_pcm_format_cpu_endian(snd_pcm_format_t format); +int snd_pcm_format_width(snd_pcm_format_t format);			/* in bits */ +int snd_pcm_format_physical_width(snd_pcm_format_t format);		/* in bits */ +snd_pcm_format_t snd_pcm_build_linear_format(int width, int pwidth, int unsignd, int big_endian); +ssize_t snd_pcm_format_size(snd_pcm_format_t format, size_t samples); +uint8_t snd_pcm_format_silence(snd_pcm_format_t format); +uint16_t snd_pcm_format_silence_16(snd_pcm_format_t format); +uint32_t snd_pcm_format_silence_32(snd_pcm_format_t format); +uint64_t snd_pcm_format_silence_64(snd_pcm_format_t format); +int snd_pcm_format_set_silence(snd_pcm_format_t format, void *buf, unsigned int samples); + +snd_pcm_sframes_t snd_pcm_bytes_to_frames(snd_pcm_t *pcm, ssize_t bytes); +ssize_t snd_pcm_frames_to_bytes(snd_pcm_t *pcm, snd_pcm_sframes_t frames); +long snd_pcm_bytes_to_samples(snd_pcm_t *pcm, ssize_t bytes); +ssize_t snd_pcm_samples_to_bytes(snd_pcm_t *pcm, long samples); + +int snd_pcm_area_silence(const snd_pcm_channel_area_t *dst_channel, snd_pcm_uframes_t dst_offset, +			 unsigned int samples, snd_pcm_format_t format); +int snd_pcm_areas_silence(const snd_pcm_channel_area_t *dst_channels, snd_pcm_uframes_t dst_offset, +			  unsigned int channels, snd_pcm_uframes_t frames, snd_pcm_format_t format); +int snd_pcm_area_copy(const snd_pcm_channel_area_t *dst_channel, snd_pcm_uframes_t dst_offset, +		      const snd_pcm_channel_area_t *src_channel, snd_pcm_uframes_t src_offset, +		      unsigned int samples, snd_pcm_format_t format); +int snd_pcm_areas_copy(const snd_pcm_channel_area_t *dst_channels, snd_pcm_uframes_t dst_offset, +		       const snd_pcm_channel_area_t *src_channels, snd_pcm_uframes_t src_offset, +		       unsigned int channels, snd_pcm_uframes_t frames, snd_pcm_format_t format); +int snd_pcm_areas_copy_wrap(const snd_pcm_channel_area_t *dst_channels, +			    snd_pcm_uframes_t dst_offset, +			    const snd_pcm_uframes_t dst_size, +			    const snd_pcm_channel_area_t *src_channels, +			    snd_pcm_uframes_t src_offset, +			    const snd_pcm_uframes_t src_size, +			    const unsigned int channels, +			    snd_pcm_uframes_t frames, +			    const snd_pcm_format_t format); + +/** \} */ + +/** + * \defgroup PCM_Hook Hook Extension + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +/** type of pcm hook */ +typedef enum _snd_pcm_hook_type { +	SND_PCM_HOOK_TYPE_HW_PARAMS = 0, +	SND_PCM_HOOK_TYPE_HW_FREE, +	SND_PCM_HOOK_TYPE_CLOSE, +	SND_PCM_HOOK_TYPE_LAST = SND_PCM_HOOK_TYPE_CLOSE +} snd_pcm_hook_type_t; + +/** PCM hook container */ +typedef struct _snd_pcm_hook snd_pcm_hook_t; +/** PCM hook callback function */ +typedef int (*snd_pcm_hook_func_t)(snd_pcm_hook_t *hook); +snd_pcm_t *snd_pcm_hook_get_pcm(snd_pcm_hook_t *hook); +void *snd_pcm_hook_get_private(snd_pcm_hook_t *hook); +void snd_pcm_hook_set_private(snd_pcm_hook_t *hook, void *private_data); +int snd_pcm_hook_add(snd_pcm_hook_t **hookp, snd_pcm_t *pcm, +		     snd_pcm_hook_type_t type, +		     snd_pcm_hook_func_t func, void *private_data); +int snd_pcm_hook_remove(snd_pcm_hook_t *hook); + +/** \} */ + +/** + * \defgroup PCM_Scope Scope Plugin Extension + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +/** #SND_PCM_TYPE_METER scope functions */ +typedef struct _snd_pcm_scope_ops { +	/** \brief Enable and prepare it using current params +	 * \param scope scope handle +	 */ +	int (*enable)(snd_pcm_scope_t *scope); +	/** \brief Disable +	 * \param scope scope handle +	 */ +	void (*disable)(snd_pcm_scope_t *scope); +	/** \brief PCM has been started +	 * \param scope scope handle +	 */ +	void (*start)(snd_pcm_scope_t *scope); +	/** \brief PCM has been stopped +	 * \param scope scope handle +	 */ +	void (*stop)(snd_pcm_scope_t *scope); +	/** \brief New frames are present +	 * \param scope scope handle +	 */ +	void (*update)(snd_pcm_scope_t *scope); +	/** \brief Reset status +	 * \param scope scope handle +	 */ +	void (*reset)(snd_pcm_scope_t *scope); +	/** \brief PCM is closing +	 * \param scope scope handle +	 */ +	void (*close)(snd_pcm_scope_t *scope); +} snd_pcm_scope_ops_t; + +snd_pcm_uframes_t snd_pcm_meter_get_bufsize(snd_pcm_t *pcm); +unsigned int snd_pcm_meter_get_channels(snd_pcm_t *pcm); +unsigned int snd_pcm_meter_get_rate(snd_pcm_t *pcm); +snd_pcm_uframes_t snd_pcm_meter_get_now(snd_pcm_t *pcm); +snd_pcm_uframes_t snd_pcm_meter_get_boundary(snd_pcm_t *pcm); +int snd_pcm_meter_add_scope(snd_pcm_t *pcm, snd_pcm_scope_t *scope); +snd_pcm_scope_t *snd_pcm_meter_search_scope(snd_pcm_t *pcm, const char *name); +int snd_pcm_scope_malloc(snd_pcm_scope_t **ptr); +void snd_pcm_scope_set_ops(snd_pcm_scope_t *scope, +			   const snd_pcm_scope_ops_t *val); +void snd_pcm_scope_set_name(snd_pcm_scope_t *scope, const char *val); +const char *snd_pcm_scope_get_name(snd_pcm_scope_t *scope); +void *snd_pcm_scope_get_callback_private(snd_pcm_scope_t *scope); +void snd_pcm_scope_set_callback_private(snd_pcm_scope_t *scope, void *val); +int snd_pcm_scope_s16_open(snd_pcm_t *pcm, const char *name, +			   snd_pcm_scope_t **scopep); +int16_t *snd_pcm_scope_s16_get_channel_buffer(snd_pcm_scope_t *scope, +					      unsigned int channel); + +/** \} */ + +/** + * \defgroup PCM_Simple Simple setup functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +/** Simple PCM latency type */ +typedef enum _snd_spcm_latency { +	/** standard latency - for standard playback or capture +            (estimated latency in one direction 350ms) */ +	SND_SPCM_LATENCY_STANDARD = 0, +	/** medium latency - software phones etc. +	    (estimated latency in one direction maximally 25ms */ +	SND_SPCM_LATENCY_MEDIUM, +	/** realtime latency - realtime applications (effect processors etc.) +	    (estimated latency in one direction 5ms and better) */ +	SND_SPCM_LATENCY_REALTIME +} snd_spcm_latency_t; + +/** Simple PCM xrun type */ +typedef enum _snd_spcm_xrun_type { +	/** driver / library will ignore all xruns, the stream runs forever */ +	SND_SPCM_XRUN_IGNORE = 0, +	/** driver / library stops the stream when an xrun occurs */ +	SND_SPCM_XRUN_STOP +} snd_spcm_xrun_type_t; + +/** Simple PCM duplex type */ +typedef enum _snd_spcm_duplex_type { +	/** liberal duplex - the buffer and period sizes might not match */ +	SND_SPCM_DUPLEX_LIBERAL = 0, +	/** pedantic duplex - the buffer and period sizes MUST match */ +	SND_SPCM_DUPLEX_PEDANTIC +} snd_spcm_duplex_type_t; + +int snd_spcm_init(snd_pcm_t *pcm, +		  unsigned int rate, +		  unsigned int channels, +		  snd_pcm_format_t format, +		  snd_pcm_subformat_t subformat, +		  snd_spcm_latency_t latency, +		  snd_pcm_access_t _access, +		  snd_spcm_xrun_type_t xrun_type); + +int snd_spcm_init_duplex(snd_pcm_t *playback_pcm, +			 snd_pcm_t *capture_pcm, +			 unsigned int rate, +			 unsigned int channels, +			 snd_pcm_format_t format, +			 snd_pcm_subformat_t subformat, +			 snd_spcm_latency_t latency, +			 snd_pcm_access_t _access, +			 snd_spcm_xrun_type_t xrun_type, +			 snd_spcm_duplex_type_t duplex_type); + +int snd_spcm_init_get_params(snd_pcm_t *pcm, +			     unsigned int *rate, +			     snd_pcm_uframes_t *buffer_size, +			     snd_pcm_uframes_t *period_size); + +/** \} */ + +/** + * \defgroup PCM_Deprecated Deprecated Functions + * \ingroup PCM + * See the \ref pcm page for more details. + * \{ + */ + +/* Deprecated functions, for compatibility */ +const char *snd_pcm_start_mode_name(snd_pcm_start_t mode) __attribute__((deprecated)); +const char *snd_pcm_xrun_mode_name(snd_pcm_xrun_t mode) __attribute__((deprecated)); +int snd_pcm_sw_params_set_start_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_start_t val) __attribute__((deprecated)); +snd_pcm_start_t snd_pcm_sw_params_get_start_mode(const snd_pcm_sw_params_t *params) __attribute__((deprecated)); +int snd_pcm_sw_params_set_xrun_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_xrun_t val) __attribute__((deprecated)); +snd_pcm_xrun_t snd_pcm_sw_params_get_xrun_mode(const snd_pcm_sw_params_t *params) __attribute__((deprecated)); +#if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_SW_PARAMS_API) +int snd_pcm_sw_params_set_xfer_align(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val) __attribute__((deprecated)); +int snd_pcm_sw_params_get_xfer_align(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val) __attribute__((deprecated)); +int snd_pcm_sw_params_set_sleep_min(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, unsigned int val) __attribute__((deprecated)); +int snd_pcm_sw_params_get_sleep_min(const snd_pcm_sw_params_t *params, unsigned int *val) __attribute__((deprecated)); +#endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_SW_PARAMS_API */ +#if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_HW_PARAMS_API) +int snd_pcm_hw_params_get_tick_time(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_get_tick_time_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_get_tick_time_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_test_tick_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +int snd_pcm_hw_params_set_tick_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated)); +#endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_HW_PARAMS_API */ + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_PCM_H */ diff --git a/include/alsa/pcm_external.h b/include/alsa/pcm_external.h new file mode 100644 index 0000000..204a450 --- /dev/null +++ b/include/alsa/pcm_external.h @@ -0,0 +1,70 @@ +/** + * \file include/pcm_external.h + * \brief External PCM plugin SDK + * \author Takashi Iwai <tiwai@suse.de> + * \date 2005 + * + * Extern PCM plugin SDK. + */ + +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ +#ifndef __ALSA_PCM_EXTERNAL_H +#define __ALSA_PCM_EXTERNAL_H + +#include "pcm.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Plugin_SDK External PCM plugin SDK + *  \{ + */ + +/** + * Define the object entry for external PCM plugins + */ +#define SND_PCM_PLUGIN_ENTRY(name) _snd_pcm_##name##_open + +/** + * Define the symbols of the given plugin with versions + */ +#define SND_PCM_PLUGIN_SYMBOL(name) SND_DLSYM_BUILD_VERSION(SND_PCM_PLUGIN_ENTRY(name), SND_PCM_DLSYM_VERSION); + +/** + * Define the plugin + */ +#define SND_PCM_PLUGIN_DEFINE_FUNC(plugin) \ +int SND_PCM_PLUGIN_ENTRY(plugin) (snd_pcm_t **pcmp, const char *name,\ +				  snd_config_t *root, snd_config_t *conf, \ +				  snd_pcm_stream_t stream, int mode) + +#include "pcm_ioplug.h" +#include "pcm_extplug.h" + +int snd_pcm_parse_control_id(snd_config_t *conf, snd_ctl_elem_id_t *ctl_id, int *cardp, +			     int *cchannelsp, int *hwctlp); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_PCM_EXTERNAL_H */ diff --git a/include/alsa/pcm_extplug.h b/include/alsa/pcm_extplug.h new file mode 100644 index 0000000..ced934f --- /dev/null +++ b/include/alsa/pcm_extplug.h @@ -0,0 +1,206 @@ +/** + * \file include/pcm_extplug.h + * \brief External Filter-Plugin SDK + * \author Takashi Iwai <tiwai@suse.de> + * \date 2005 + * + * External Filter-Plugin SDK + */ + +/* + * ALSA external PCM plugin SDK (draft version) + * + * Copyright (c) 2005 Takashi Iwai <tiwai@suse.de> + * + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_PCM_EXTPLUG_H +#define __ALSA_PCM_EXTPLUG_H + +/** + * \defgroup PCM_ExtPlug External Filter plugin SDK + * \ingroup Plugin_SDK + * See the \ref pcm page for more details. + * \{ + */ + +/** hw constraints for extplug */ +enum { +	SND_PCM_EXTPLUG_HW_FORMAT,	/**< format */ +	SND_PCM_EXTPLUG_HW_CHANNELS,	/**< channels */ +	SND_PCM_EXTPLUG_HW_PARAMS	/**< max number of hw constraints */ +}; +	 +/** Handle of external filter plugin */ +typedef struct snd_pcm_extplug snd_pcm_extplug_t; +/** Callback table of extplug */ +typedef struct snd_pcm_extplug_callback snd_pcm_extplug_callback_t; +#ifdef DOC_HIDDEN +/* redefine typedefs for stupid doxygen */ +typedef snd_pcm_extplug snd_pcm_extplug_t; +typedef snd_pcm_extplug_callback snd_pcm_extplug_callback_t; +#endif + +/* + * Protocol version + */ +#define SND_PCM_EXTPLUG_VERSION_MAJOR	1	/**< Protocol major version */ +#define SND_PCM_EXTPLUG_VERSION_MINOR	0	/**< Protocol minor version */ +#define SND_PCM_EXTPLUG_VERSION_TINY	2	/**< Protocol tiny version */ +/** + * Filter-plugin protocol version + */ +#define SND_PCM_EXTPLUG_VERSION		((SND_PCM_EXTPLUG_VERSION_MAJOR<<16) |\ +					 (SND_PCM_EXTPLUG_VERSION_MINOR<<8) |\ +					 (SND_PCM_EXTPLUG_VERSION_TINY)) + +/** Handle of extplug */ +struct snd_pcm_extplug { +	/** +	 * protocol version; #SND_PCM_EXTPLUG_VERSION must be filled here +	 * before calling #snd_pcm_extplug_create() +	 */ +	unsigned int version; +	/** +	 * name of this plugin; must be filled before calling #snd_pcm_extplug_create() +	 */ +	const char *name; +	/** +	 * callbacks of this plugin; must be filled before calling #snd_pcm_extplug_create() +	 */ +	const snd_pcm_extplug_callback_t *callback; +	/** +	 * private data, which can be used freely in the driver callbacks +	 */ +	void *private_data; +	/** +	 * PCM handle filled by #snd_pcm_extplug_create() +	 */ +	snd_pcm_t *pcm; +	/** +	 * stream direction; read-only status +	 */ +	snd_pcm_stream_t stream; +	/** +	 * format hw parameter; filled after hw_params is caled +	 */ +	snd_pcm_format_t format; +	/** +	 * subformat hw parameter; filled after hw_params is caled +	 */ +	snd_pcm_subformat_t subformat; +	/** +	 * channels hw parameter; filled after hw_params is caled +	 */ +	unsigned int channels; +	/** +	 * rate hw parameter; filled after hw_params is caled +	 */ +	unsigned int rate; +	/** +	 * slave_format hw parameter; filled after hw_params is caled +	 */ +	snd_pcm_format_t slave_format; +	/** +	 * slave_subformat hw parameter; filled after hw_params is caled +	 */ +	snd_pcm_subformat_t slave_subformat; +	/** +	 * slave_channels hw parameter; filled after hw_params is caled +	 */ +	unsigned int slave_channels; +}; + +/** Callback table of extplug */ +struct snd_pcm_extplug_callback { +	/** +	 * transfer between source and destination; this is a required callback +	 */ +	snd_pcm_sframes_t (*transfer)(snd_pcm_extplug_t *ext, +				      const snd_pcm_channel_area_t *dst_areas, +				      snd_pcm_uframes_t dst_offset, +				      const snd_pcm_channel_area_t *src_areas, +				      snd_pcm_uframes_t src_offset, +				      snd_pcm_uframes_t size); +	/** +	 * close the PCM; optional +	 */ +	int (*close)(snd_pcm_extplug_t *ext); +	/** +	 * hw_params; optional +	 */ +	int (*hw_params)(snd_pcm_extplug_t *ext, snd_pcm_hw_params_t *params); +	/** +	 * hw_free; optional +	 */ +	int (*hw_free)(snd_pcm_extplug_t *ext); +	/** +	 * dump; optional +	 */ +	void (*dump)(snd_pcm_extplug_t *ext, snd_output_t *out); +	/** +	 * init; optional initialization called at prepare or reset +	 */ +	int (*init)(snd_pcm_extplug_t *ext); +	/** +	 * query the channel maps; optional; since v1.0.2 +	 */ +	snd_pcm_chmap_query_t **(*query_chmaps)(snd_pcm_extplug_t *ext); +	/** +	 * get the channel map; optional; since v1.0.2 +	 */ +	snd_pcm_chmap_t *(*get_chmap)(snd_pcm_extplug_t *ext); +	/** +	 * set the channel map; optional; since v1.0.2 +	 */ +	int (*set_chmap)(snd_pcm_extplug_t *ext, const snd_pcm_chmap_t *map); +}; + + +int snd_pcm_extplug_create(snd_pcm_extplug_t *ext, const char *name, +			   snd_config_t *root, snd_config_t *slave_conf, +			   snd_pcm_stream_t stream, int mode); +int snd_pcm_extplug_delete(snd_pcm_extplug_t *ext); + +/* clear hw_parameter setting */ +void snd_pcm_extplug_params_reset(snd_pcm_extplug_t *ext); + +/* hw_parameter setting */ +int snd_pcm_extplug_set_param_list(snd_pcm_extplug_t *extplug, int type, unsigned int num_list, const unsigned int *list); +int snd_pcm_extplug_set_param_minmax(snd_pcm_extplug_t *extplug, int type, unsigned int min, unsigned int max); +int snd_pcm_extplug_set_slave_param_list(snd_pcm_extplug_t *extplug, int type, unsigned int num_list, const unsigned int *list); +int snd_pcm_extplug_set_slave_param_minmax(snd_pcm_extplug_t *extplug, int type, unsigned int min, unsigned int max); + +/** + * set the parameter constraint with a single value + */ +static __inline__ int snd_pcm_extplug_set_param(snd_pcm_extplug_t *extplug, int type, unsigned int val) +{ +	return snd_pcm_extplug_set_param_list(extplug, type, 1, &val); +} + +/** + * set the parameter constraint for slave PCM with a single value + */ +static __inline__ int snd_pcm_extplug_set_slave_param(snd_pcm_extplug_t *extplug, int type, unsigned int val) +{ +	return snd_pcm_extplug_set_slave_param_list(extplug, type, 1, &val); +} + +/** \} */ + +#endif /* __ALSA_PCM_EXTPLUG_H */ diff --git a/include/alsa/pcm_ioplug.h b/include/alsa/pcm_ioplug.h new file mode 100644 index 0000000..81ac861 --- /dev/null +++ b/include/alsa/pcm_ioplug.h @@ -0,0 +1,247 @@ +/** + * \file include/pcm_ioplug.h + * \brief External I/O-Plugin SDK + * \author Takashi Iwai <tiwai@suse.de> + * \date 2005 + * + * External I/O-Plugin SDK + */ + +/* + * ALSA external PCM plugin SDK + * + * Copyright (c) 2005 Takashi Iwai <tiwai@suse.de> + * + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_PCM_IOPLUG_H +#define __ALSA_PCM_IOPLUG_H + +/** + * \defgroup PCM_IOPlug External I/O plugin SDK + * \ingroup Plugin_SDK + * See the \ref pcm page for more details. + * \{ + */ + +/** hw constraints for ioplug */ +enum { +	SND_PCM_IOPLUG_HW_ACCESS = 0,	/**< access type */ +	SND_PCM_IOPLUG_HW_FORMAT,	/**< format */ +	SND_PCM_IOPLUG_HW_CHANNELS,	/**< channels */ +	SND_PCM_IOPLUG_HW_RATE,		/**< rate */ +	SND_PCM_IOPLUG_HW_PERIOD_BYTES,	/**< period bytes */ +	SND_PCM_IOPLUG_HW_BUFFER_BYTES,	/**< buffer bytes */ +	SND_PCM_IOPLUG_HW_PERIODS,	/**< number of periods */ +	SND_PCM_IOPLUG_HW_PARAMS	/**< max number of hw constraints */ +}; +	 +/** I/O plugin handle */ +typedef struct snd_pcm_ioplug snd_pcm_ioplug_t; +/** Callback table of ioplug */ +typedef struct snd_pcm_ioplug_callback snd_pcm_ioplug_callback_t; +#ifdef DOC_HIDDEN +/* redefine typedefs for stupid doxygen */ +typedef snd_pcm_ioplug snd_pcm_ioplug_t; +typedef snd_pcm_ioplug_callback snd_pcm_ioplug_callback_t; +#endif + +/* + * bit flags for additional conditions + */ +#define SND_PCM_IOPLUG_FLAG_LISTED	(1<<0)		/**< list up this PCM */ +#define SND_PCM_IOPLUG_FLAG_MONOTONIC	(1<<1)		/**< monotonic timestamps */ +/** hw pointer wrap around at boundary instead of buffer_size */ +#define SND_PCM_IOPLUG_FLAG_BOUNDARY_WA	(1<<2) + +/* + * Protocol version + */ +#define SND_PCM_IOPLUG_VERSION_MAJOR	1	/**< Protocol major version */ +#define SND_PCM_IOPLUG_VERSION_MINOR	0	/**< Protocol minor version */ +#define SND_PCM_IOPLUG_VERSION_TINY	2	/**< Protocol tiny version */ +/** + * IO-plugin protocol version + */ +#define SND_PCM_IOPLUG_VERSION		((SND_PCM_IOPLUG_VERSION_MAJOR<<16) |\ +					 (SND_PCM_IOPLUG_VERSION_MINOR<<8) |\ +					 (SND_PCM_IOPLUG_VERSION_TINY)) + +/** Handle of ioplug */ +struct snd_pcm_ioplug { +	/** +	 * protocol version; #SND_PCM_IOPLUG_VERSION must be filled here +	 * before calling #snd_pcm_ioplug_create() +	 */ +	unsigned int version; +	/** +	 * name of this plugin; must be filled before calling #snd_pcm_ioplug_create() +	 */ +	const char *name; +	unsigned int flags;	/**< SND_PCM_IOPLUG_FLAG_XXX */ +	int poll_fd;		/**< poll file descriptor */ +	unsigned int poll_events;	/**< poll events */ +	unsigned int mmap_rw;		/**< pseudo mmap mode */ +	/** +	 * callbacks of this plugin; must be filled before calling #snd_pcm_ioplug_create() +	 */ +	const snd_pcm_ioplug_callback_t *callback; +	/** +	 * private data, which can be used freely in the driver callbacks +	 */ +	void *private_data; +	/** +	 * PCM handle filled by #snd_pcm_ioplug_create() +	 */ +	snd_pcm_t *pcm; + +	snd_pcm_stream_t stream;	/**< stream direcion; read-only */	 +	snd_pcm_state_t state;		/**< current PCM state; read-only */ +	volatile snd_pcm_uframes_t appl_ptr;	/**< application pointer; read-only */ +	volatile snd_pcm_uframes_t hw_ptr;	/**< hw pointer; read-only */ +	int nonblock;			/**< non-block mode; read-only */ + +	snd_pcm_access_t access;	/**< access type; filled after hw_params is called */ +	snd_pcm_format_t format;	/**< PCM format; filled after hw_params is called */ +	unsigned int channels;		/**< number of channels; filled after hw_params is called */ +	unsigned int rate;		/**< rate; filled after hw_params is called */ +	snd_pcm_uframes_t period_size;	/**< period size; filled after hw_params is called */ +	snd_pcm_uframes_t buffer_size;	/**< buffer size; filled after hw_params is called */ +}; + +/** Callback table of ioplug */ +struct snd_pcm_ioplug_callback { +	/** +	 * start the PCM; required, called inside mutex lock +	 */ +	int (*start)(snd_pcm_ioplug_t *io); +	/** +	 * stop the PCM; required, called inside mutex lock +	 */ +	int (*stop)(snd_pcm_ioplug_t *io); +	/** +	 * get the current DMA position; required, called inside mutex lock +	 * \return buffer position up to buffer_size or +	 * when #SND_PCM_IOPLUG_FLAG_BOUNDARY_WA flag is set up to boundary or +	 * a negative error code for Xrun +	 */ +	snd_pcm_sframes_t (*pointer)(snd_pcm_ioplug_t *io); +	/** +	 * transfer the data; optional, called inside mutex lock +	 */ +	snd_pcm_sframes_t (*transfer)(snd_pcm_ioplug_t *io, +				      const snd_pcm_channel_area_t *areas, +				      snd_pcm_uframes_t offset, +				      snd_pcm_uframes_t size); +	/** +	 * close the PCM; optional +	 */ +	int (*close)(snd_pcm_ioplug_t *io); +	/** +	 * hw_params; optional +	 */ +	int (*hw_params)(snd_pcm_ioplug_t *io, snd_pcm_hw_params_t *params); +	/** +	 * hw_free; optional +	 */ +	int (*hw_free)(snd_pcm_ioplug_t *io); +	/** +	 * sw_params; optional +	 */ +	int (*sw_params)(snd_pcm_ioplug_t *io, snd_pcm_sw_params_t *params); +	/** +	 * prepare; optional +	 */ +	int (*prepare)(snd_pcm_ioplug_t *io); +	/** +	 * drain; optional +	 */ +	int (*drain)(snd_pcm_ioplug_t *io); +	/** +	 * toggle pause; optional, called inside mutex lock +	 */ +	int (*pause)(snd_pcm_ioplug_t *io, int enable); +	/** +	 * resume; optional +	 */ +	int (*resume)(snd_pcm_ioplug_t *io); +	/** +	 * poll descriptors count; optional +	 */ +	int (*poll_descriptors_count)(snd_pcm_ioplug_t *io); +	/** +	 * poll descriptors; optional +	 */ +	int (*poll_descriptors)(snd_pcm_ioplug_t *io, struct pollfd *pfd, unsigned int space); +	/** +	 * mangle poll events; optional +	 */ +	int (*poll_revents)(snd_pcm_ioplug_t *io, struct pollfd *pfd, unsigned int nfds, unsigned short *revents); +	/** +	 * dump; optional +	 */ +	void (*dump)(snd_pcm_ioplug_t *io, snd_output_t *out); +	/** +	 * get the delay for the running PCM; optional; since v1.0.1 +	 */ +	int (*delay)(snd_pcm_ioplug_t *io, snd_pcm_sframes_t *delayp); +	/** +	 * query the channel maps; optional; since v1.0.2 +	 */ +	snd_pcm_chmap_query_t **(*query_chmaps)(snd_pcm_ioplug_t *io); +	/** +	 * get the channel map; optional; since v1.0.2 +	 */ +	snd_pcm_chmap_t *(*get_chmap)(snd_pcm_ioplug_t *io); +	/** +	 * set the channel map; optional; since v1.0.2 +	 */ +	int (*set_chmap)(snd_pcm_ioplug_t *io, const snd_pcm_chmap_t *map); +}; + + +int snd_pcm_ioplug_create(snd_pcm_ioplug_t *io, const char *name, +			  snd_pcm_stream_t stream, int mode); +int snd_pcm_ioplug_delete(snd_pcm_ioplug_t *io); + +/* update poll_fd and mmap_rw */ +int snd_pcm_ioplug_reinit_status(snd_pcm_ioplug_t *ioplug); + +/* get a mmap area (for mmap_rw only) */ +const snd_pcm_channel_area_t *snd_pcm_ioplug_mmap_areas(snd_pcm_ioplug_t *ioplug); + +/* clear hw_parameter setting */ +void snd_pcm_ioplug_params_reset(snd_pcm_ioplug_t *io); + +/* hw_parameter setting */ +int snd_pcm_ioplug_set_param_minmax(snd_pcm_ioplug_t *io, int type, unsigned int min, unsigned int max); +int snd_pcm_ioplug_set_param_list(snd_pcm_ioplug_t *io, int type, unsigned int num_list, const unsigned int *list); + +/* change PCM status */ +int snd_pcm_ioplug_set_state(snd_pcm_ioplug_t *ioplug, snd_pcm_state_t state); + +/* calucalte the available frames */ +snd_pcm_uframes_t snd_pcm_ioplug_avail(const snd_pcm_ioplug_t * const ioplug, +				       const snd_pcm_uframes_t hw_ptr, +				       const snd_pcm_uframes_t appl_ptr); +snd_pcm_uframes_t snd_pcm_ioplug_hw_avail(const snd_pcm_ioplug_t * const ioplug, +					  const snd_pcm_uframes_t hw_ptr, +					  const snd_pcm_uframes_t appl_ptr); + +/** \} */ + +#endif /* __ALSA_PCM_IOPLUG_H */ diff --git a/include/alsa/pcm_plugin.h b/include/alsa/pcm_plugin.h new file mode 100644 index 0000000..3061205 --- /dev/null +++ b/include/alsa/pcm_plugin.h @@ -0,0 +1,203 @@ +/** + * \file include/pcm_plugin.h + * \brief Common PCM plugin code + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Jaroslav Kysela <perex@perex.cz> + * \date 2000-2001 + * + * Application interface library for the ALSA driver. + * See the \ref pcm_plugins page for more details. + * + * \warning Using of contents of this header file might be dangerous + *	    in the sense of compatibility reasons. The contents might be + *	    freely changed in future. + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_PCM_PLUGIN_H +#define __ALSA_PCM_PLUGIN_H + +/** + * \defgroup PCM_Plugins PCM Plugins + * \ingroup PCM + * See the \ref pcm_plugins page for more details. + * \{ + */ +   +#define SND_PCM_PLUGIN_RATE_MIN 4000	/**< minimal rate for the rate plugin */ +#define SND_PCM_PLUGIN_RATE_MAX 192000	/**< maximal rate for the rate plugin */ + +/* ROUTE_FLOAT should be set to 0 for machines without FP unit - like iPAQ */ +#ifdef HAVE_SOFT_FLOAT +#define SND_PCM_PLUGIN_ROUTE_FLOAT 0	   /**< use integers for route plugin */ +#else +#define SND_PCM_PLUGIN_ROUTE_FLOAT 1	   /**< use floats for route plugin */ +#endif + +#define SND_PCM_PLUGIN_ROUTE_RESOLUTION 16 /**< integer resolution for route plugin */ + +#if SND_PCM_PLUGIN_ROUTE_FLOAT +/** route ttable entry type */ +typedef float snd_pcm_route_ttable_entry_t; +#define SND_PCM_PLUGIN_ROUTE_HALF 0.5	/**< half value */ +#define SND_PCM_PLUGIN_ROUTE_FULL 1.0	/**< full value */ +#else +/** route ttable entry type */ +typedef int snd_pcm_route_ttable_entry_t; +#define SND_PCM_PLUGIN_ROUTE_HALF (SND_PCM_PLUGIN_ROUTE_RESOLUTION / 2)	/**< half value */ +#define SND_PCM_PLUGIN_ROUTE_FULL SND_PCM_PLUGIN_ROUTE_RESOLUTION	/**< full value */ +#endif + +/* + *  Hardware plugin + */ +int snd_pcm_hw_open(snd_pcm_t **pcmp, const char *name, +		    int card, int device, int subdevice, +		    snd_pcm_stream_t stream, int mode, +		    int mmap_emulation, int sync_ptr_ioctl); +int _snd_pcm_hw_open(snd_pcm_t **pcmp, const char *name, +		     snd_config_t *root ATTRIBUTE_UNUSED, snd_config_t *conf, +		     snd_pcm_stream_t stream, int mode); + +/* + *  Copy plugin + */ +int snd_pcm_copy_open(snd_pcm_t **pcmp, const char *name, +		      snd_pcm_t *slave, int close_slave); +int _snd_pcm_copy_open(snd_pcm_t **pcmp, const char *name, +		       snd_config_t *root, snd_config_t *conf, +                       snd_pcm_stream_t stream, int mode); +                                               +/* + *  Linear conversion plugin + */ +int snd_pcm_linear_open(snd_pcm_t **pcmp, const char *name, +			snd_pcm_format_t sformat, snd_pcm_t *slave, +			int close_slave); +int _snd_pcm_linear_open(snd_pcm_t **pcmp, const char *name, +			 snd_config_t *root, snd_config_t *conf, +			 snd_pcm_stream_t stream, int mode); + +/* + *  Linear<->Float conversion plugin + */ +int snd_pcm_lfloat_open(snd_pcm_t **pcmp, const char *name, +			snd_pcm_format_t sformat, snd_pcm_t *slave, +			int close_slave); +int _snd_pcm_lfloat_open(snd_pcm_t **pcmp, const char *name, +			 snd_config_t *root, snd_config_t *conf, +			 snd_pcm_stream_t stream, int mode); + +/* + *  Linear<->mu-Law conversion plugin + */ +int snd_pcm_mulaw_open(snd_pcm_t **pcmp, const char *name, +		       snd_pcm_format_t sformat, snd_pcm_t *slave, +		       int close_slave); +int _snd_pcm_mulaw_open(snd_pcm_t **pcmp, const char *name, +			snd_config_t *root, snd_config_t *conf, +                        snd_pcm_stream_t stream, int mode); + +/* + *  Linear<->a-Law conversion plugin + */ +int snd_pcm_alaw_open(snd_pcm_t **pcmp, const char *name, +		      snd_pcm_format_t sformat, snd_pcm_t *slave, +		      int close_slave); +int _snd_pcm_alaw_open(snd_pcm_t **pcmp, const char *name, +		       snd_config_t *root, snd_config_t *conf, +		       snd_pcm_stream_t stream, int mode); + +/* + *  Linear<->Ima-ADPCM conversion plugin + */ +int snd_pcm_adpcm_open(snd_pcm_t **pcmp, const char *name, +		       snd_pcm_format_t sformat, snd_pcm_t *slave, +		       int close_slave); +int _snd_pcm_adpcm_open(snd_pcm_t **pcmp, const char *name, +			snd_config_t *root, snd_config_t *conf, +			snd_pcm_stream_t stream, int mode); + +/* + *  Route plugin for linear formats + */ +int snd_pcm_route_load_ttable(snd_config_t *tt, snd_pcm_route_ttable_entry_t *ttable, +			      unsigned int tt_csize, unsigned int tt_ssize, +			      unsigned int *tt_cused, unsigned int *tt_sused, +			      int schannels); +int snd_pcm_route_determine_ttable(snd_config_t *tt, +				   unsigned int *tt_csize, +				   unsigned int *tt_ssize); +int snd_pcm_route_open(snd_pcm_t **pcmp, const char *name, +		       snd_pcm_format_t sformat, int schannels, +		       snd_pcm_route_ttable_entry_t *ttable, +		       unsigned int tt_ssize, +		       unsigned int tt_cused, unsigned int tt_sused, +		       snd_pcm_t *slave, int close_slave); +int _snd_pcm_route_open(snd_pcm_t **pcmp, const char *name, +			snd_config_t *root, snd_config_t *conf, +			snd_pcm_stream_t stream, int mode); + +/* + *  Rate plugin for linear formats + */ +int snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name, +		      snd_pcm_format_t sformat, unsigned int srate, +		      const snd_config_t *converter, +		      snd_pcm_t *slave, int close_slave); +int _snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name, +		       snd_config_t *root, snd_config_t *conf, +		       snd_pcm_stream_t stream, int mode); + +/* + *  Hooks plugin + */ +int snd_pcm_hooks_open(snd_pcm_t **pcmp, const char *name, +		       snd_pcm_t *slave, int close_slave); +int _snd_pcm_hooks_open(snd_pcm_t **pcmp, const char *name, +			snd_config_t *root, snd_config_t *conf, +			snd_pcm_stream_t stream, int mode); + +/* + *  LADSPA plugin + */ +int snd_pcm_ladspa_open(snd_pcm_t **pcmp, const char *name, +			const char *ladspa_path, +			unsigned int channels, +			snd_config_t *ladspa_pplugins, +			snd_config_t *ladspa_cplugins, +			snd_pcm_t *slave, int close_slave); +int _snd_pcm_ladspa_open(snd_pcm_t **pcmp, const char *name, +			 snd_config_t *root, snd_config_t *conf, +			 snd_pcm_stream_t stream, int mode); + +/* + *  Jack plugin + */ +int snd_pcm_jack_open(snd_pcm_t **pcmp, const char *name, +					snd_config_t *playback_conf, +					snd_config_t *capture_conf, +		      snd_pcm_stream_t stream, int mode); +int _snd_pcm_jack_open(snd_pcm_t **pcmp, const char *name, +                       snd_config_t *root, snd_config_t *conf, +                       snd_pcm_stream_t stream, int mode); + + +/** \} */ + +#endif /* __ALSA_PCM_PLUGIN_H */ diff --git a/include/alsa/pcm_rate.h b/include/alsa/pcm_rate.h new file mode 100644 index 0000000..4171fb9 --- /dev/null +++ b/include/alsa/pcm_rate.h @@ -0,0 +1,156 @@ +/** + * \file include/pcm_rate.h + * \brief External Rate-Converter-Plugin SDK + * \author Takashi Iwai <tiwai@suse.de> + * \date 2006 + * + * External Rate-Converter-Plugin SDK + */ + +/* + * ALSA external PCM rate-converter plugin SDK (draft version) + * + * Copyright (c) 2006 Takashi Iwai <tiwai@suse.de> + * + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_PCM_RATE_H +#define __ALSA_PCM_RATE_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * Protocol version + */ +#define SND_PCM_RATE_PLUGIN_VERSION	0x010002 + +/** hw_params information for a single side */ +typedef struct snd_pcm_rate_side_info { +	snd_pcm_format_t format; +	unsigned int rate; +	snd_pcm_uframes_t buffer_size; +	snd_pcm_uframes_t period_size; +} snd_pcm_rate_side_info_t; + +/** hw_params information */ +typedef struct snd_pcm_rate_info { +	struct snd_pcm_rate_side_info in; +	struct snd_pcm_rate_side_info out; +	unsigned int channels; +} snd_pcm_rate_info_t; + +/** Callback table of rate-converter */ +typedef struct snd_pcm_rate_ops { +	/** +	 * close the converter; optional +	 */ +	void (*close)(void *obj); +	/** +	 * initialize the converter, called at hw_params +	 */ +	int (*init)(void *obj, snd_pcm_rate_info_t *info); +	/** +	 * free the converter; optional +	 */ +	void (*free)(void *obj); +	/** +	 * reset the converter, called at prepare; optional +	 */ +	void (*reset)(void *obj); +	/** +	 * adjust the pitch, called at sw_params; optional +	 */ +	int (*adjust_pitch)(void *obj, snd_pcm_rate_info_t *info); +	/** +	 * convert the data +	 */ +	void (*convert)(void *obj, +			const snd_pcm_channel_area_t *dst_areas, +			snd_pcm_uframes_t dst_offset, unsigned int dst_frames, +			const snd_pcm_channel_area_t *src_areas, +			snd_pcm_uframes_t src_offset, unsigned int src_frames); +	/** +	 * convert an s16 interleaved-data array; exclusive with convert +	 */ +	void (*convert_s16)(void *obj, int16_t *dst, unsigned int dst_frames, +			    const int16_t *src, unsigned int src_frames); +	/** +	 * compute the frame size for input +	 */ +	snd_pcm_uframes_t (*input_frames)(void *obj, snd_pcm_uframes_t frames); +	/** +	 * compute the frame size for output +	 */ +	snd_pcm_uframes_t (*output_frames)(void *obj, snd_pcm_uframes_t frames); +	/** +	 * the protocol version the plugin supports; +	 * new field since version 0x010002 +	 */ +	unsigned int version; +	/** +	 * return the supported min / max sample rates; +	 * new ops since version 0x010002 +	 */ +	int (*get_supported_rates)(void *obj, unsigned int *rate_min, +				   unsigned int *rate_max); +	/** +	 * show some status messages for verbose mode; +	 * new ops since version 0x010002 +	 */ +	void (*dump)(void *obj, snd_output_t *out); +} snd_pcm_rate_ops_t; + +/** open function type */ +typedef int (*snd_pcm_rate_open_func_t)(unsigned int version, void **objp, +					snd_pcm_rate_ops_t *opsp); + +typedef int (*snd_pcm_rate_open_conf_func_t)(unsigned int version, void **objp, +					snd_pcm_rate_ops_t *opsp, const snd_config_t *conf); + +/** + * Define the object entry for external PCM rate-converter plugins + */ +#define SND_PCM_RATE_PLUGIN_ENTRY(name) _snd_pcm_rate_##name##_open +#define SND_PCM_RATE_PLUGIN_CONF_ENTRY(name) _snd_pcm_rate_##name##_open_conf + +#ifndef DOC_HIDDEN +/* old rate_ops for protocol version 0x010001 */ +typedef struct snd_pcm_rate_old_ops { +	void (*close)(void *obj); +	int (*init)(void *obj, snd_pcm_rate_info_t *info); +	void (*free)(void *obj); +	void (*reset)(void *obj); +	int (*adjust_pitch)(void *obj, snd_pcm_rate_info_t *info); +	void (*convert)(void *obj, +			const snd_pcm_channel_area_t *dst_areas, +			snd_pcm_uframes_t dst_offset, unsigned int dst_frames, +			const snd_pcm_channel_area_t *src_areas, +			snd_pcm_uframes_t src_offset, unsigned int src_frames); +	void (*convert_s16)(void *obj, int16_t *dst, unsigned int dst_frames, +			    const int16_t *src, unsigned int src_frames); +	snd_pcm_uframes_t (*input_frames)(void *obj, snd_pcm_uframes_t frames); +	snd_pcm_uframes_t (*output_frames)(void *obj, snd_pcm_uframes_t frames); +} snd_pcm_rate_old_ops_t; +#endif + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_PCM_RATE_H */ diff --git a/include/alsa/rawmidi.h b/include/alsa/rawmidi.h new file mode 100644 index 0000000..d88c932 --- /dev/null +++ b/include/alsa/rawmidi.h @@ -0,0 +1,159 @@ +/** + * \file include/rawmidi.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_RAWMIDI_H +#define __ALSA_RAWMIDI_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup RawMidi RawMidi Interface + *  The RawMidi Interface. See \ref rawmidi page for more details. + *  \{ + */ + +/** dlsym version for interface entry callback */ +#define SND_RAWMIDI_DLSYM_VERSION	_dlsym_rawmidi_001 + +/** RawMidi information container */ +typedef struct _snd_rawmidi_info snd_rawmidi_info_t; +/** RawMidi settings container */ +typedef struct _snd_rawmidi_params snd_rawmidi_params_t; +/** RawMidi status container */ +typedef struct _snd_rawmidi_status snd_rawmidi_status_t; + +/** RawMidi stream (direction) */ +typedef enum _snd_rawmidi_stream { +	/** Output stream */ +	SND_RAWMIDI_STREAM_OUTPUT = 0, +	/** Input stream */ +	SND_RAWMIDI_STREAM_INPUT, +	SND_RAWMIDI_STREAM_LAST = SND_RAWMIDI_STREAM_INPUT +} snd_rawmidi_stream_t; + +/** Append (flag to open mode) \hideinitializer */ +#define SND_RAWMIDI_APPEND	0x0001 +/** Non blocking mode (flag to open mode) \hideinitializer */ +#define SND_RAWMIDI_NONBLOCK	0x0002 +/** Write sync mode (Flag to open mode) \hideinitializer */ +#define SND_RAWMIDI_SYNC	0x0004 + +/** RawMidi handle */ +typedef struct _snd_rawmidi snd_rawmidi_t; + +/** RawMidi type */ +typedef enum _snd_rawmidi_type { +	/** Kernel level RawMidi */ +	SND_RAWMIDI_TYPE_HW, +	/** Shared memory client RawMidi (not yet implemented) */ +	SND_RAWMIDI_TYPE_SHM, +	/** INET client RawMidi (not yet implemented) */ +	SND_RAWMIDI_TYPE_INET, +	/** Virtual (sequencer) RawMidi */ +	SND_RAWMIDI_TYPE_VIRTUAL +} snd_rawmidi_type_t; + +int snd_rawmidi_open(snd_rawmidi_t **in_rmidi, snd_rawmidi_t **out_rmidi, +		     const char *name, int mode); +int snd_rawmidi_open_lconf(snd_rawmidi_t **in_rmidi, snd_rawmidi_t **out_rmidi, +			   const char *name, int mode, snd_config_t *lconf); +int snd_rawmidi_close(snd_rawmidi_t *rmidi); +int snd_rawmidi_poll_descriptors_count(snd_rawmidi_t *rmidi); +int snd_rawmidi_poll_descriptors(snd_rawmidi_t *rmidi, struct pollfd *pfds, unsigned int space); +int snd_rawmidi_poll_descriptors_revents(snd_rawmidi_t *rawmidi, struct pollfd *pfds, unsigned int nfds, unsigned short *revent); +int snd_rawmidi_nonblock(snd_rawmidi_t *rmidi, int nonblock); +size_t snd_rawmidi_info_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_rawmidi_info_t using standard alloca + * \param ptr returned pointer + */ +#define snd_rawmidi_info_alloca(ptr) __snd_alloca(ptr, snd_rawmidi_info) +int snd_rawmidi_info_malloc(snd_rawmidi_info_t **ptr); +void snd_rawmidi_info_free(snd_rawmidi_info_t *obj); +void snd_rawmidi_info_copy(snd_rawmidi_info_t *dst, const snd_rawmidi_info_t *src); +unsigned int snd_rawmidi_info_get_device(const snd_rawmidi_info_t *obj); +unsigned int snd_rawmidi_info_get_subdevice(const snd_rawmidi_info_t *obj); +snd_rawmidi_stream_t snd_rawmidi_info_get_stream(const snd_rawmidi_info_t *obj); +int snd_rawmidi_info_get_card(const snd_rawmidi_info_t *obj); +unsigned int snd_rawmidi_info_get_flags(const snd_rawmidi_info_t *obj); +const char *snd_rawmidi_info_get_id(const snd_rawmidi_info_t *obj); +const char *snd_rawmidi_info_get_name(const snd_rawmidi_info_t *obj); +const char *snd_rawmidi_info_get_subdevice_name(const snd_rawmidi_info_t *obj); +unsigned int snd_rawmidi_info_get_subdevices_count(const snd_rawmidi_info_t *obj); +unsigned int snd_rawmidi_info_get_subdevices_avail(const snd_rawmidi_info_t *obj); +void snd_rawmidi_info_set_device(snd_rawmidi_info_t *obj, unsigned int val); +void snd_rawmidi_info_set_subdevice(snd_rawmidi_info_t *obj, unsigned int val); +void snd_rawmidi_info_set_stream(snd_rawmidi_info_t *obj, snd_rawmidi_stream_t val); +int snd_rawmidi_info(snd_rawmidi_t *rmidi, snd_rawmidi_info_t * info); +size_t snd_rawmidi_params_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_rawmidi_params_t using standard alloca + * \param ptr returned pointer + */ +#define snd_rawmidi_params_alloca(ptr) __snd_alloca(ptr, snd_rawmidi_params) +int snd_rawmidi_params_malloc(snd_rawmidi_params_t **ptr); +void snd_rawmidi_params_free(snd_rawmidi_params_t *obj); +void snd_rawmidi_params_copy(snd_rawmidi_params_t *dst, const snd_rawmidi_params_t *src); +int snd_rawmidi_params_set_buffer_size(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params, size_t val); +size_t snd_rawmidi_params_get_buffer_size(const snd_rawmidi_params_t *params); +int snd_rawmidi_params_set_avail_min(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params, size_t val); +size_t snd_rawmidi_params_get_avail_min(const snd_rawmidi_params_t *params); +int snd_rawmidi_params_set_no_active_sensing(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params, int val); +int snd_rawmidi_params_get_no_active_sensing(const snd_rawmidi_params_t *params); +int snd_rawmidi_params(snd_rawmidi_t *rmidi, snd_rawmidi_params_t * params); +int snd_rawmidi_params_current(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params); +size_t snd_rawmidi_status_sizeof(void); +/** \hideinitializer + * \brief allocate an invalid #snd_rawmidi_status_t using standard alloca + * \param ptr returned pointer + */ +#define snd_rawmidi_status_alloca(ptr) __snd_alloca(ptr, snd_rawmidi_status) +int snd_rawmidi_status_malloc(snd_rawmidi_status_t **ptr); +void snd_rawmidi_status_free(snd_rawmidi_status_t *obj); +void snd_rawmidi_status_copy(snd_rawmidi_status_t *dst, const snd_rawmidi_status_t *src); +void snd_rawmidi_status_get_tstamp(const snd_rawmidi_status_t *obj, snd_htimestamp_t *ptr); +size_t snd_rawmidi_status_get_avail(const snd_rawmidi_status_t *obj); +size_t snd_rawmidi_status_get_xruns(const snd_rawmidi_status_t *obj); +int snd_rawmidi_status(snd_rawmidi_t *rmidi, snd_rawmidi_status_t * status); +int snd_rawmidi_drain(snd_rawmidi_t *rmidi); +int snd_rawmidi_drop(snd_rawmidi_t *rmidi); +ssize_t snd_rawmidi_write(snd_rawmidi_t *rmidi, const void *buffer, size_t size); +ssize_t snd_rawmidi_read(snd_rawmidi_t *rmidi, void *buffer, size_t size); +const char *snd_rawmidi_name(snd_rawmidi_t *rmidi); +snd_rawmidi_type_t snd_rawmidi_type(snd_rawmidi_t *rmidi); +snd_rawmidi_stream_t snd_rawmidi_stream(snd_rawmidi_t *rawmidi); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __RAWMIDI_H */ + diff --git a/include/alsa/seq.h b/include/alsa/seq.h new file mode 100644 index 0000000..123a105 --- /dev/null +++ b/include/alsa/seq.h @@ -0,0 +1,739 @@ +/** + * \file include/seq.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + */ +/* + * Application interface library for the ALSA driver + * + * + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_SEQ_H +#define __ALSA_SEQ_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Sequencer MIDI Sequencer + *  MIDI Sequencer Interface. + *  See \ref seq page for more details. + *  \{ + */ + +/** dlsym version for interface entry callback */ +#define SND_SEQ_DLSYM_VERSION		_dlsym_seq_001 + +/** Sequencer handle */ +typedef struct _snd_seq snd_seq_t; + +/** + * sequencer opening stream types + */ +#define SND_SEQ_OPEN_OUTPUT	1	/**< open for output (write) */ +#define SND_SEQ_OPEN_INPUT	2	/**< open for input (read) */ +#define SND_SEQ_OPEN_DUPLEX	(SND_SEQ_OPEN_OUTPUT|SND_SEQ_OPEN_INPUT)	/**< open for both input and output (read/write) */ + +/** + * sequencer opening mode + */ +#define SND_SEQ_NONBLOCK	0x0001	/**< non-blocking mode (flag to open mode) */ + +/** sequencer handle type */ +typedef enum _snd_seq_type { +	SND_SEQ_TYPE_HW,		/**< hardware */ +	SND_SEQ_TYPE_SHM,		/**< shared memory (NYI) */ +	SND_SEQ_TYPE_INET		/**< network (NYI) */ +} snd_seq_type_t; + +/** special client (port) ids */ +#define SND_SEQ_ADDRESS_UNKNOWN		253	/**< unknown source */ +#define SND_SEQ_ADDRESS_SUBSCRIBERS	254	/**< send event to all subscribed ports */ +#define SND_SEQ_ADDRESS_BROADCAST	255	/**< send event to all queues/clients/ports/channels */ + +/** known client numbers */ +#define SND_SEQ_CLIENT_SYSTEM		0	/**< system client */ + +/* + */ +int snd_seq_open(snd_seq_t **handle, const char *name, int streams, int mode); +int snd_seq_open_lconf(snd_seq_t **handle, const char *name, int streams, int mode, snd_config_t *lconf); +const char *snd_seq_name(snd_seq_t *seq); +snd_seq_type_t snd_seq_type(snd_seq_t *seq); +int snd_seq_close(snd_seq_t *handle); +int snd_seq_poll_descriptors_count(snd_seq_t *handle, short events); +int snd_seq_poll_descriptors(snd_seq_t *handle, struct pollfd *pfds, unsigned int space, short events); +int snd_seq_poll_descriptors_revents(snd_seq_t *seq, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +int snd_seq_nonblock(snd_seq_t *handle, int nonblock); +int snd_seq_client_id(snd_seq_t *handle); + +size_t snd_seq_get_output_buffer_size(snd_seq_t *handle); +size_t snd_seq_get_input_buffer_size(snd_seq_t *handle); +int snd_seq_set_output_buffer_size(snd_seq_t *handle, size_t size); +int snd_seq_set_input_buffer_size(snd_seq_t *handle, size_t size); + +/** system information container */ +typedef struct _snd_seq_system_info snd_seq_system_info_t; + +size_t snd_seq_system_info_sizeof(void); +/** allocate a #snd_seq_system_info_t container on stack */ +#define snd_seq_system_info_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_system_info) +int snd_seq_system_info_malloc(snd_seq_system_info_t **ptr); +void snd_seq_system_info_free(snd_seq_system_info_t *ptr); +void snd_seq_system_info_copy(snd_seq_system_info_t *dst, const snd_seq_system_info_t *src); + +int snd_seq_system_info_get_queues(const snd_seq_system_info_t *info); +int snd_seq_system_info_get_clients(const snd_seq_system_info_t *info); +int snd_seq_system_info_get_ports(const snd_seq_system_info_t *info); +int snd_seq_system_info_get_channels(const snd_seq_system_info_t *info); +int snd_seq_system_info_get_cur_clients(const snd_seq_system_info_t *info); +int snd_seq_system_info_get_cur_queues(const snd_seq_system_info_t *info); + +int snd_seq_system_info(snd_seq_t *handle, snd_seq_system_info_t *info); + +/** \} */ + + +/** + *  \defgroup SeqClient Sequencer Client Interface + *  Sequencer Client Interface + *  \ingroup Sequencer + *  \{ + */ + +/** client information container */ +typedef struct _snd_seq_client_info snd_seq_client_info_t; + +/** client types */ +typedef enum snd_seq_client_type { +	SND_SEQ_USER_CLIENT     = 1,	/**< user client */ +	SND_SEQ_KERNEL_CLIENT   = 2	/**< kernel client */ +} snd_seq_client_type_t; +                         +size_t snd_seq_client_info_sizeof(void); +/** allocate a #snd_seq_client_info_t container on stack */ +#define snd_seq_client_info_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_client_info) +int snd_seq_client_info_malloc(snd_seq_client_info_t **ptr); +void snd_seq_client_info_free(snd_seq_client_info_t *ptr); +void snd_seq_client_info_copy(snd_seq_client_info_t *dst, const snd_seq_client_info_t *src); + +int snd_seq_client_info_get_client(const snd_seq_client_info_t *info); +snd_seq_client_type_t snd_seq_client_info_get_type(const snd_seq_client_info_t *info); +const char *snd_seq_client_info_get_name(snd_seq_client_info_t *info); +int snd_seq_client_info_get_broadcast_filter(const snd_seq_client_info_t *info); +int snd_seq_client_info_get_error_bounce(const snd_seq_client_info_t *info); +int snd_seq_client_info_get_card(const snd_seq_client_info_t *info); +int snd_seq_client_info_get_pid(const snd_seq_client_info_t *info); +const unsigned char *snd_seq_client_info_get_event_filter(const snd_seq_client_info_t *info); +int snd_seq_client_info_get_num_ports(const snd_seq_client_info_t *info); +int snd_seq_client_info_get_event_lost(const snd_seq_client_info_t *info); + +void snd_seq_client_info_set_client(snd_seq_client_info_t *info, int client); +void snd_seq_client_info_set_name(snd_seq_client_info_t *info, const char *name); +void snd_seq_client_info_set_broadcast_filter(snd_seq_client_info_t *info, int val); +void snd_seq_client_info_set_error_bounce(snd_seq_client_info_t *info, int val); +void snd_seq_client_info_set_event_filter(snd_seq_client_info_t *info, unsigned char *filter); + +void snd_seq_client_info_event_filter_clear(snd_seq_client_info_t *info); +void snd_seq_client_info_event_filter_add(snd_seq_client_info_t *info, int event_type); +void snd_seq_client_info_event_filter_del(snd_seq_client_info_t *info, int event_type); +int snd_seq_client_info_event_filter_check(snd_seq_client_info_t *info, int event_type); + +int snd_seq_get_client_info(snd_seq_t *handle, snd_seq_client_info_t *info); +int snd_seq_get_any_client_info(snd_seq_t *handle, int client, snd_seq_client_info_t *info); +int snd_seq_set_client_info(snd_seq_t *handle, snd_seq_client_info_t *info); +int snd_seq_query_next_client(snd_seq_t *handle, snd_seq_client_info_t *info); + +/* + */ + +/** client pool information container */ +typedef struct _snd_seq_client_pool snd_seq_client_pool_t; + +size_t snd_seq_client_pool_sizeof(void); +/** allocate a #snd_seq_client_pool_t container on stack */ +#define snd_seq_client_pool_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_client_pool) +int snd_seq_client_pool_malloc(snd_seq_client_pool_t **ptr); +void snd_seq_client_pool_free(snd_seq_client_pool_t *ptr); +void snd_seq_client_pool_copy(snd_seq_client_pool_t *dst, const snd_seq_client_pool_t *src); + +int snd_seq_client_pool_get_client(const snd_seq_client_pool_t *info); +size_t snd_seq_client_pool_get_output_pool(const snd_seq_client_pool_t *info); +size_t snd_seq_client_pool_get_input_pool(const snd_seq_client_pool_t *info); +size_t snd_seq_client_pool_get_output_room(const snd_seq_client_pool_t *info); +size_t snd_seq_client_pool_get_output_free(const snd_seq_client_pool_t *info); +size_t snd_seq_client_pool_get_input_free(const snd_seq_client_pool_t *info); +void snd_seq_client_pool_set_output_pool(snd_seq_client_pool_t *info, size_t size); +void snd_seq_client_pool_set_input_pool(snd_seq_client_pool_t *info, size_t size); +void snd_seq_client_pool_set_output_room(snd_seq_client_pool_t *info, size_t size); + +int snd_seq_get_client_pool(snd_seq_t *handle, snd_seq_client_pool_t *info); +int snd_seq_set_client_pool(snd_seq_t *handle, snd_seq_client_pool_t *info); + + +/** \} */ + + +/** + *  \defgroup SeqPort Sequencer Port Interface + *  Sequencer Port Interface + *  \ingroup Sequencer + *  \{ + */ + +/** port information container */ +typedef struct _snd_seq_port_info snd_seq_port_info_t; + +/** known port numbers */ +#define SND_SEQ_PORT_SYSTEM_TIMER	0	/**< system timer port */ +#define SND_SEQ_PORT_SYSTEM_ANNOUNCE	1	/**< system announce port */ + +/** port capabilities (32 bits) */ +#define SND_SEQ_PORT_CAP_READ		(1<<0)	/**< readable from this port */ +#define SND_SEQ_PORT_CAP_WRITE		(1<<1)	/**< writable to this port */ + +#define SND_SEQ_PORT_CAP_SYNC_READ	(1<<2)	/**< allow read subscriptions */ +#define SND_SEQ_PORT_CAP_SYNC_WRITE	(1<<3)	/**< allow write subscriptions */ + +#define SND_SEQ_PORT_CAP_DUPLEX		(1<<4)	/**< allow read/write duplex */ + +#define SND_SEQ_PORT_CAP_SUBS_READ	(1<<5)	/**< allow read subscription */ +#define SND_SEQ_PORT_CAP_SUBS_WRITE	(1<<6)	/**< allow write subscription */ +#define SND_SEQ_PORT_CAP_NO_EXPORT	(1<<7)	/**< routing not allowed */ + +/* port type */ +/** Messages sent from/to this port have device-specific semantics. */ +#define SND_SEQ_PORT_TYPE_SPECIFIC	(1<<0) +/** This port understands MIDI messages. */ +#define SND_SEQ_PORT_TYPE_MIDI_GENERIC	(1<<1) +/** This port is compatible with the General MIDI specification. */ +#define SND_SEQ_PORT_TYPE_MIDI_GM	(1<<2) +/** This port is compatible with the Roland GS standard. */ +#define SND_SEQ_PORT_TYPE_MIDI_GS	(1<<3) +/** This port is compatible with the Yamaha XG specification. */ +#define SND_SEQ_PORT_TYPE_MIDI_XG	(1<<4) +/** This port is compatible with the Roland MT-32. */ +#define SND_SEQ_PORT_TYPE_MIDI_MT32	(1<<5) +/** This port is compatible with the General MIDI 2 specification. */ +#define SND_SEQ_PORT_TYPE_MIDI_GM2	(1<<6) +/** This port understands SND_SEQ_EVENT_SAMPLE_xxx messages +    (these are not MIDI messages). */ +#define SND_SEQ_PORT_TYPE_SYNTH		(1<<10) +/** Instruments can be downloaded to this port +    (with SND_SEQ_EVENT_INSTR_xxx messages sent directly). */ +#define SND_SEQ_PORT_TYPE_DIRECT_SAMPLE (1<<11) +/** Instruments can be downloaded to this port +    (with SND_SEQ_EVENT_INSTR_xxx messages sent directly or through a queue). */ +#define SND_SEQ_PORT_TYPE_SAMPLE	(1<<12) +/** This port is implemented in hardware. */ +#define SND_SEQ_PORT_TYPE_HARDWARE	(1<<16) +/** This port is implemented in software. */ +#define SND_SEQ_PORT_TYPE_SOFTWARE	(1<<17) +/** Messages sent to this port will generate sounds. */ +#define SND_SEQ_PORT_TYPE_SYNTHESIZER	(1<<18) +/** This port may connect to other devices +    (whose characteristics are not known). */ +#define SND_SEQ_PORT_TYPE_PORT		(1<<19) +/** This port belongs to an application, such as a sequencer or editor. */ +#define SND_SEQ_PORT_TYPE_APPLICATION	(1<<20) + + +size_t snd_seq_port_info_sizeof(void); +/** allocate a #snd_seq_port_info_t container on stack */ +#define snd_seq_port_info_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_port_info) +int snd_seq_port_info_malloc(snd_seq_port_info_t **ptr); +void snd_seq_port_info_free(snd_seq_port_info_t *ptr); +void snd_seq_port_info_copy(snd_seq_port_info_t *dst, const snd_seq_port_info_t *src); + +int snd_seq_port_info_get_client(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_port(const snd_seq_port_info_t *info); +const snd_seq_addr_t *snd_seq_port_info_get_addr(const snd_seq_port_info_t *info); +const char *snd_seq_port_info_get_name(const snd_seq_port_info_t *info); +unsigned int snd_seq_port_info_get_capability(const snd_seq_port_info_t *info); +unsigned int snd_seq_port_info_get_type(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_midi_channels(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_midi_voices(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_synth_voices(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_read_use(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_write_use(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_port_specified(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_timestamping(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_timestamp_real(const snd_seq_port_info_t *info); +int snd_seq_port_info_get_timestamp_queue(const snd_seq_port_info_t *info); + +void snd_seq_port_info_set_client(snd_seq_port_info_t *info, int client); +void snd_seq_port_info_set_port(snd_seq_port_info_t *info, int port); +void snd_seq_port_info_set_addr(snd_seq_port_info_t *info, const snd_seq_addr_t *addr); +void snd_seq_port_info_set_name(snd_seq_port_info_t *info, const char *name); +void snd_seq_port_info_set_capability(snd_seq_port_info_t *info, unsigned int capability); +void snd_seq_port_info_set_type(snd_seq_port_info_t *info, unsigned int type); +void snd_seq_port_info_set_midi_channels(snd_seq_port_info_t *info, int channels); +void snd_seq_port_info_set_midi_voices(snd_seq_port_info_t *info, int voices); +void snd_seq_port_info_set_synth_voices(snd_seq_port_info_t *info, int voices); +void snd_seq_port_info_set_port_specified(snd_seq_port_info_t *info, int val); +void snd_seq_port_info_set_timestamping(snd_seq_port_info_t *info, int enable); +void snd_seq_port_info_set_timestamp_real(snd_seq_port_info_t *info, int realtime); +void snd_seq_port_info_set_timestamp_queue(snd_seq_port_info_t *info, int queue); + +int snd_seq_create_port(snd_seq_t *handle, snd_seq_port_info_t *info); +int snd_seq_delete_port(snd_seq_t *handle, int port); +int snd_seq_get_port_info(snd_seq_t *handle, int port, snd_seq_port_info_t *info); +int snd_seq_get_any_port_info(snd_seq_t *handle, int client, int port, snd_seq_port_info_t *info); +int snd_seq_set_port_info(snd_seq_t *handle, int port, snd_seq_port_info_t *info); +int snd_seq_query_next_port(snd_seq_t *handle, snd_seq_port_info_t *info); + +/** \} */ + + +/** + *  \defgroup SeqSubscribe Sequencer Port Subscription + *  Sequencer Port Subscription + *  \ingroup Sequencer + *  \{ + */ + +/** port subscription container */ +typedef struct _snd_seq_port_subscribe snd_seq_port_subscribe_t; + +size_t snd_seq_port_subscribe_sizeof(void); +/** allocate a #snd_seq_port_subscribe_t container on stack */ +#define snd_seq_port_subscribe_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_port_subscribe) +int snd_seq_port_subscribe_malloc(snd_seq_port_subscribe_t **ptr); +void snd_seq_port_subscribe_free(snd_seq_port_subscribe_t *ptr); +void snd_seq_port_subscribe_copy(snd_seq_port_subscribe_t *dst, const snd_seq_port_subscribe_t *src); + +const snd_seq_addr_t *snd_seq_port_subscribe_get_sender(const snd_seq_port_subscribe_t *info); +const snd_seq_addr_t *snd_seq_port_subscribe_get_dest(const snd_seq_port_subscribe_t *info); +int snd_seq_port_subscribe_get_queue(const snd_seq_port_subscribe_t *info); +int snd_seq_port_subscribe_get_exclusive(const snd_seq_port_subscribe_t *info); +int snd_seq_port_subscribe_get_time_update(const snd_seq_port_subscribe_t *info); +int snd_seq_port_subscribe_get_time_real(const snd_seq_port_subscribe_t *info); + +void snd_seq_port_subscribe_set_sender(snd_seq_port_subscribe_t *info, const snd_seq_addr_t *addr); +void snd_seq_port_subscribe_set_dest(snd_seq_port_subscribe_t *info, const snd_seq_addr_t *addr); +void snd_seq_port_subscribe_set_queue(snd_seq_port_subscribe_t *info, int q); +void snd_seq_port_subscribe_set_exclusive(snd_seq_port_subscribe_t *info, int val); +void snd_seq_port_subscribe_set_time_update(snd_seq_port_subscribe_t *info, int val); +void snd_seq_port_subscribe_set_time_real(snd_seq_port_subscribe_t *info, int val); + +int snd_seq_get_port_subscription(snd_seq_t *handle, snd_seq_port_subscribe_t *sub); +int snd_seq_subscribe_port(snd_seq_t *handle, snd_seq_port_subscribe_t *sub); +int snd_seq_unsubscribe_port(snd_seq_t *handle, snd_seq_port_subscribe_t *sub); + +/* + */ + +/** subscription query container */ +typedef struct _snd_seq_query_subscribe snd_seq_query_subscribe_t; + +/** type of query subscription */ +typedef enum { +	SND_SEQ_QUERY_SUBS_READ,	/**< query read subscriptions */ +	SND_SEQ_QUERY_SUBS_WRITE	/**< query write subscriptions */ +} snd_seq_query_subs_type_t; + +size_t snd_seq_query_subscribe_sizeof(void); +/** allocate a #snd_seq_query_subscribe_t container on stack */ +#define snd_seq_query_subscribe_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_query_subscribe) +int snd_seq_query_subscribe_malloc(snd_seq_query_subscribe_t **ptr); +void snd_seq_query_subscribe_free(snd_seq_query_subscribe_t *ptr); +void snd_seq_query_subscribe_copy(snd_seq_query_subscribe_t *dst, const snd_seq_query_subscribe_t *src); + +int snd_seq_query_subscribe_get_client(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_port(const snd_seq_query_subscribe_t *info); +const snd_seq_addr_t *snd_seq_query_subscribe_get_root(const snd_seq_query_subscribe_t *info); +snd_seq_query_subs_type_t snd_seq_query_subscribe_get_type(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_index(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_num_subs(const snd_seq_query_subscribe_t *info); +const snd_seq_addr_t *snd_seq_query_subscribe_get_addr(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_queue(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_exclusive(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_time_update(const snd_seq_query_subscribe_t *info); +int snd_seq_query_subscribe_get_time_real(const snd_seq_query_subscribe_t *info); + +void snd_seq_query_subscribe_set_client(snd_seq_query_subscribe_t *info, int client); +void snd_seq_query_subscribe_set_port(snd_seq_query_subscribe_t *info, int port); +void snd_seq_query_subscribe_set_root(snd_seq_query_subscribe_t *info, const snd_seq_addr_t *addr); +void snd_seq_query_subscribe_set_type(snd_seq_query_subscribe_t *info, snd_seq_query_subs_type_t type); +void snd_seq_query_subscribe_set_index(snd_seq_query_subscribe_t *info, int _index); + +int snd_seq_query_port_subscribers(snd_seq_t *seq, snd_seq_query_subscribe_t * subs); + +/** \} */ + + +/** + *  \defgroup SeqQueue Sequencer Queue Interface + *  Sequencer Queue Interface + *  \ingroup Sequencer + *  \{ + */ + +/** queue information container */ +typedef struct _snd_seq_queue_info snd_seq_queue_info_t; +/** queue status container */ +typedef struct _snd_seq_queue_status snd_seq_queue_status_t; +/** queue tempo container */ +typedef struct _snd_seq_queue_tempo snd_seq_queue_tempo_t; +/** queue timer information container */ +typedef struct _snd_seq_queue_timer snd_seq_queue_timer_t; + +/** special queue ids */ +#define SND_SEQ_QUEUE_DIRECT		253	/**< direct dispatch */ + +size_t snd_seq_queue_info_sizeof(void); +/** allocate a #snd_seq_queue_info_t container on stack */ +#define snd_seq_queue_info_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_queue_info) +int snd_seq_queue_info_malloc(snd_seq_queue_info_t **ptr); +void snd_seq_queue_info_free(snd_seq_queue_info_t *ptr); +void snd_seq_queue_info_copy(snd_seq_queue_info_t *dst, const snd_seq_queue_info_t *src); + +int snd_seq_queue_info_get_queue(const snd_seq_queue_info_t *info); +const char *snd_seq_queue_info_get_name(const snd_seq_queue_info_t *info); +int snd_seq_queue_info_get_owner(const snd_seq_queue_info_t *info); +int snd_seq_queue_info_get_locked(const snd_seq_queue_info_t *info); +unsigned int snd_seq_queue_info_get_flags(const snd_seq_queue_info_t *info); + +void snd_seq_queue_info_set_name(snd_seq_queue_info_t *info, const char *name); +void snd_seq_queue_info_set_owner(snd_seq_queue_info_t *info, int owner); +void snd_seq_queue_info_set_locked(snd_seq_queue_info_t *info, int locked); +void snd_seq_queue_info_set_flags(snd_seq_queue_info_t *info, unsigned int flags); + +int snd_seq_create_queue(snd_seq_t *seq, snd_seq_queue_info_t *info); +int snd_seq_alloc_named_queue(snd_seq_t *seq, const char *name); +int snd_seq_alloc_queue(snd_seq_t *handle); +int snd_seq_free_queue(snd_seq_t *handle, int q); +int snd_seq_get_queue_info(snd_seq_t *seq, int q, snd_seq_queue_info_t *info); +int snd_seq_set_queue_info(snd_seq_t *seq, int q, snd_seq_queue_info_t *info); +int snd_seq_query_named_queue(snd_seq_t *seq, const char *name); + +int snd_seq_get_queue_usage(snd_seq_t *handle, int q); +int snd_seq_set_queue_usage(snd_seq_t *handle, int q, int used); + +/* + */ +size_t snd_seq_queue_status_sizeof(void); +/** allocate a #snd_seq_queue_status_t container on stack */ +#define snd_seq_queue_status_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_queue_status) +int snd_seq_queue_status_malloc(snd_seq_queue_status_t **ptr); +void snd_seq_queue_status_free(snd_seq_queue_status_t *ptr); +void snd_seq_queue_status_copy(snd_seq_queue_status_t *dst, const snd_seq_queue_status_t *src); + +int snd_seq_queue_status_get_queue(const snd_seq_queue_status_t *info); +int snd_seq_queue_status_get_events(const snd_seq_queue_status_t *info); +snd_seq_tick_time_t snd_seq_queue_status_get_tick_time(const snd_seq_queue_status_t *info); +const snd_seq_real_time_t *snd_seq_queue_status_get_real_time(const snd_seq_queue_status_t *info); +unsigned int snd_seq_queue_status_get_status(const snd_seq_queue_status_t *info); + +int snd_seq_get_queue_status(snd_seq_t *handle, int q, snd_seq_queue_status_t *status); + +/* + */ +size_t snd_seq_queue_tempo_sizeof(void); +/** allocate a #snd_seq_queue_tempo_t container on stack */ +#define snd_seq_queue_tempo_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_queue_tempo) +int snd_seq_queue_tempo_malloc(snd_seq_queue_tempo_t **ptr); +void snd_seq_queue_tempo_free(snd_seq_queue_tempo_t *ptr); +void snd_seq_queue_tempo_copy(snd_seq_queue_tempo_t *dst, const snd_seq_queue_tempo_t *src); + +int snd_seq_queue_tempo_get_queue(const snd_seq_queue_tempo_t *info); +unsigned int snd_seq_queue_tempo_get_tempo(const snd_seq_queue_tempo_t *info); +int snd_seq_queue_tempo_get_ppq(const snd_seq_queue_tempo_t *info); +unsigned int snd_seq_queue_tempo_get_skew(const snd_seq_queue_tempo_t *info); +unsigned int snd_seq_queue_tempo_get_skew_base(const snd_seq_queue_tempo_t *info); +void snd_seq_queue_tempo_set_tempo(snd_seq_queue_tempo_t *info, unsigned int tempo); +void snd_seq_queue_tempo_set_ppq(snd_seq_queue_tempo_t *info, int ppq); +void snd_seq_queue_tempo_set_skew(snd_seq_queue_tempo_t *info, unsigned int skew); +void snd_seq_queue_tempo_set_skew_base(snd_seq_queue_tempo_t *info, unsigned int base); + +int snd_seq_get_queue_tempo(snd_seq_t *handle, int q, snd_seq_queue_tempo_t *tempo); +int snd_seq_set_queue_tempo(snd_seq_t *handle, int q, snd_seq_queue_tempo_t *tempo); + +/* + */ + +/** sequencer timer sources */ +typedef enum { +	SND_SEQ_TIMER_ALSA = 0,		/* ALSA timer */ +	SND_SEQ_TIMER_MIDI_CLOCK = 1,	/* Midi Clock (CLOCK event) */ +	SND_SEQ_TIMER_MIDI_TICK = 2	/* Midi Timer Tick (TICK event */ +} snd_seq_queue_timer_type_t; + +size_t snd_seq_queue_timer_sizeof(void); +/** allocate a #snd_seq_queue_timer_t container on stack */ +#define snd_seq_queue_timer_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_queue_timer) +int snd_seq_queue_timer_malloc(snd_seq_queue_timer_t **ptr); +void snd_seq_queue_timer_free(snd_seq_queue_timer_t *ptr); +void snd_seq_queue_timer_copy(snd_seq_queue_timer_t *dst, const snd_seq_queue_timer_t *src); + +int snd_seq_queue_timer_get_queue(const snd_seq_queue_timer_t *info); +snd_seq_queue_timer_type_t snd_seq_queue_timer_get_type(const snd_seq_queue_timer_t *info); +const snd_timer_id_t *snd_seq_queue_timer_get_id(const snd_seq_queue_timer_t *info); +unsigned int snd_seq_queue_timer_get_resolution(const snd_seq_queue_timer_t *info); + +void snd_seq_queue_timer_set_type(snd_seq_queue_timer_t *info, snd_seq_queue_timer_type_t type); +void snd_seq_queue_timer_set_id(snd_seq_queue_timer_t *info, const snd_timer_id_t *id); +void snd_seq_queue_timer_set_resolution(snd_seq_queue_timer_t *info, unsigned int resolution); + +int snd_seq_get_queue_timer(snd_seq_t *handle, int q, snd_seq_queue_timer_t *timer); +int snd_seq_set_queue_timer(snd_seq_t *handle, int q, snd_seq_queue_timer_t *timer); + +/** \} */ + +/** + *  \defgroup SeqEvent Sequencer Event API + *  Sequencer Event API + *  \ingroup Sequencer + *  \{ + */ + +int snd_seq_free_event(snd_seq_event_t *ev); +ssize_t snd_seq_event_length(snd_seq_event_t *ev); +int snd_seq_event_output(snd_seq_t *handle, snd_seq_event_t *ev); +int snd_seq_event_output_buffer(snd_seq_t *handle, snd_seq_event_t *ev); +int snd_seq_event_output_direct(snd_seq_t *handle, snd_seq_event_t *ev); +int snd_seq_event_input(snd_seq_t *handle, snd_seq_event_t **ev); +int snd_seq_event_input_pending(snd_seq_t *seq, int fetch_sequencer); +int snd_seq_drain_output(snd_seq_t *handle); +int snd_seq_event_output_pending(snd_seq_t *seq); +int snd_seq_extract_output(snd_seq_t *handle, snd_seq_event_t **ev); +int snd_seq_drop_output(snd_seq_t *handle); +int snd_seq_drop_output_buffer(snd_seq_t *handle); +int snd_seq_drop_input(snd_seq_t *handle); +int snd_seq_drop_input_buffer(snd_seq_t *handle); + +/** event removal conditionals */ +typedef struct _snd_seq_remove_events snd_seq_remove_events_t; + +/** Remove conditional flags */ +#define SND_SEQ_REMOVE_INPUT		(1<<0)	/**< Flush input queues */ +#define SND_SEQ_REMOVE_OUTPUT		(1<<1)	/**< Flush output queues */ +#define SND_SEQ_REMOVE_DEST		(1<<2)	/**< Restrict by destination q:client:port */ +#define SND_SEQ_REMOVE_DEST_CHANNEL	(1<<3)	/**< Restrict by channel */ +#define SND_SEQ_REMOVE_TIME_BEFORE	(1<<4)	/**< Restrict to before time */ +#define SND_SEQ_REMOVE_TIME_AFTER	(1<<5)	/**< Restrict to time or after */ +#define SND_SEQ_REMOVE_TIME_TICK	(1<<6)	/**< Time is in ticks */ +#define SND_SEQ_REMOVE_EVENT_TYPE	(1<<7)	/**< Restrict to event type */ +#define SND_SEQ_REMOVE_IGNORE_OFF 	(1<<8)	/**< Do not flush off events */ +#define SND_SEQ_REMOVE_TAG_MATCH 	(1<<9)	/**< Restrict to events with given tag */ + +size_t snd_seq_remove_events_sizeof(void); +/** allocate a #snd_seq_remove_events_t container on stack */ +#define snd_seq_remove_events_alloca(ptr) \ +	__snd_alloca(ptr, snd_seq_remove_events) +int snd_seq_remove_events_malloc(snd_seq_remove_events_t **ptr); +void snd_seq_remove_events_free(snd_seq_remove_events_t *ptr); +void snd_seq_remove_events_copy(snd_seq_remove_events_t *dst, const snd_seq_remove_events_t *src); + +unsigned int snd_seq_remove_events_get_condition(const snd_seq_remove_events_t *info); +int snd_seq_remove_events_get_queue(const snd_seq_remove_events_t *info); +const snd_seq_timestamp_t *snd_seq_remove_events_get_time(const snd_seq_remove_events_t *info); +const snd_seq_addr_t *snd_seq_remove_events_get_dest(const snd_seq_remove_events_t *info); +int snd_seq_remove_events_get_channel(const snd_seq_remove_events_t *info); +int snd_seq_remove_events_get_event_type(const snd_seq_remove_events_t *info); +int snd_seq_remove_events_get_tag(const snd_seq_remove_events_t *info); + +void snd_seq_remove_events_set_condition(snd_seq_remove_events_t *info, unsigned int flags); +void snd_seq_remove_events_set_queue(snd_seq_remove_events_t *info, int queue); +void snd_seq_remove_events_set_time(snd_seq_remove_events_t *info, const snd_seq_timestamp_t *time); +void snd_seq_remove_events_set_dest(snd_seq_remove_events_t *info, const snd_seq_addr_t *addr); +void snd_seq_remove_events_set_channel(snd_seq_remove_events_t *info, int channel); +void snd_seq_remove_events_set_event_type(snd_seq_remove_events_t *info, int type); +void snd_seq_remove_events_set_tag(snd_seq_remove_events_t *info, int tag); + +int snd_seq_remove_events(snd_seq_t *handle, snd_seq_remove_events_t *info); + +/** \} */ + +/** + *  \defgroup SeqMisc Sequencer Miscellaneous + *  Sequencer Miscellaneous + *  \ingroup Sequencer + *  \{ + */ + +void snd_seq_set_bit(int nr, void *array); +void snd_seq_unset_bit(int nr, void *array); +int snd_seq_change_bit(int nr, void *array); +int snd_seq_get_bit(int nr, void *array); + +/** \} */ + + +/** + *  \defgroup SeqEvType Sequencer Event Type Checks + *  Sequencer Event Type Checks + *  \ingroup Sequencer + *  \{ + */ + +/* event type macros */ +enum { +	SND_SEQ_EVFLG_RESULT, +	SND_SEQ_EVFLG_NOTE, +	SND_SEQ_EVFLG_CONTROL, +	SND_SEQ_EVFLG_QUEUE, +	SND_SEQ_EVFLG_SYSTEM, +	SND_SEQ_EVFLG_MESSAGE, +	SND_SEQ_EVFLG_CONNECTION, +	SND_SEQ_EVFLG_SAMPLE, +	SND_SEQ_EVFLG_USERS, +	SND_SEQ_EVFLG_INSTR, +	SND_SEQ_EVFLG_QUOTE, +	SND_SEQ_EVFLG_NONE, +	SND_SEQ_EVFLG_RAW, +	SND_SEQ_EVFLG_FIXED, +	SND_SEQ_EVFLG_VARIABLE, +	SND_SEQ_EVFLG_VARUSR +}; + +enum { +	SND_SEQ_EVFLG_NOTE_ONEARG, +	SND_SEQ_EVFLG_NOTE_TWOARG +}; + +enum { +	SND_SEQ_EVFLG_QUEUE_NOARG, +	SND_SEQ_EVFLG_QUEUE_TICK, +	SND_SEQ_EVFLG_QUEUE_TIME, +	SND_SEQ_EVFLG_QUEUE_VALUE +}; + +/** + * Exported event type table + * + * This table is referred by snd_seq_ev_is_xxx. + */ +extern const unsigned int snd_seq_event_types[]; + +#define _SND_SEQ_TYPE(x)	(1<<(x))	/**< master type - 24bit */ +#define _SND_SEQ_TYPE_OPT(x)	((x)<<24)	/**< optional type - 8bit */ + +/** check the event type */ +#define snd_seq_type_check(ev,x) (snd_seq_event_types[(ev)->type] & _SND_SEQ_TYPE(x)) + +/** event type check: result events */ +#define snd_seq_ev_is_result_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_RESULT) +/** event type check: note events */ +#define snd_seq_ev_is_note_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_NOTE) +/** event type check: control events */ +#define snd_seq_ev_is_control_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_CONTROL) +/** event type check: channel specific events */ +#define snd_seq_ev_is_channel_type(ev) \ +	(snd_seq_event_types[(ev)->type] & (_SND_SEQ_TYPE(SND_SEQ_EVFLG_NOTE) | _SND_SEQ_TYPE(SND_SEQ_EVFLG_CONTROL))) + +/** event type check: queue control events */ +#define snd_seq_ev_is_queue_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_QUEUE) +/** event type check: system status messages */ +#define snd_seq_ev_is_message_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_MESSAGE) +/** event type check: system status messages */ +#define snd_seq_ev_is_subscribe_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_CONNECTION) +/** event type check: sample messages */ +#define snd_seq_ev_is_sample_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_SAMPLE) +/** event type check: user-defined messages */ +#define snd_seq_ev_is_user_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_USERS) +/** event type check: instrument layer events */ +#define snd_seq_ev_is_instr_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_INSTR) +/** event type check: fixed length events */ +#define snd_seq_ev_is_fixed_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_FIXED) +/** event type check: variable length events */ +#define snd_seq_ev_is_variable_type(ev)	\ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_VARIABLE) +/** event type check: user pointer events */ +#define snd_seq_ev_is_varusr_type(ev) \ +	snd_seq_type_check(ev, SND_SEQ_EVFLG_VARUSR) +/** event type check: reserved for kernel */ +#define snd_seq_ev_is_reserved(ev) \ +	(! snd_seq_event_types[(ev)->type]) + +/** + * macros to check event flags + */ +/** prior events */ +#define snd_seq_ev_is_prior(ev)	\ +	(((ev)->flags & SND_SEQ_PRIORITY_MASK) == SND_SEQ_PRIORITY_HIGH) + +/** get the data length type */ +#define snd_seq_ev_length_type(ev) \ +	((ev)->flags & SND_SEQ_EVENT_LENGTH_MASK) +/** fixed length events */ +#define snd_seq_ev_is_fixed(ev)	\ +	(snd_seq_ev_length_type(ev) == SND_SEQ_EVENT_LENGTH_FIXED) +/** variable length events */ +#define snd_seq_ev_is_variable(ev) \ +	(snd_seq_ev_length_type(ev) == SND_SEQ_EVENT_LENGTH_VARIABLE) +/** variable length on user-space */ +#define snd_seq_ev_is_varusr(ev) \ +	(snd_seq_ev_length_type(ev) == SND_SEQ_EVENT_LENGTH_VARUSR) + +/** time-stamp type */ +#define snd_seq_ev_timestamp_type(ev) \ +	((ev)->flags & SND_SEQ_TIME_STAMP_MASK) +/** event is in tick time */ +#define snd_seq_ev_is_tick(ev) \ +	(snd_seq_ev_timestamp_type(ev) == SND_SEQ_TIME_STAMP_TICK) +/** event is in real-time */ +#define snd_seq_ev_is_real(ev) \ +	(snd_seq_ev_timestamp_type(ev) == SND_SEQ_TIME_STAMP_REAL) + +/** time-mode type */ +#define snd_seq_ev_timemode_type(ev) \ +	((ev)->flags & SND_SEQ_TIME_MODE_MASK) +/** scheduled in absolute time */ +#define snd_seq_ev_is_abstime(ev) \ +	(snd_seq_ev_timemode_type(ev) == SND_SEQ_TIME_MODE_ABS) +/** scheduled in relative time */ +#define snd_seq_ev_is_reltime(ev) \ +	(snd_seq_ev_timemode_type(ev) == SND_SEQ_TIME_MODE_REL) + +/** direct dispatched events */ +#define snd_seq_ev_is_direct(ev) \ +	((ev)->queue == SND_SEQ_QUEUE_DIRECT) + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_SEQ_H */ + diff --git a/include/alsa/seq_event.h b/include/alsa/seq_event.h new file mode 100644 index 0000000..60727f5 --- /dev/null +++ b/include/alsa/seq_event.h @@ -0,0 +1,325 @@ +/** + * \file include/seq_event.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_SEQ_EVENT_H +#define __ALSA_SEQ_EVENT_H + +/** + *  \defgroup SeqEvents Sequencer Event Definitions + *  Sequencer Event Definitions + *  \ingroup Sequencer + *  \{ + */ + +/** + * Sequencer event data type + */ +typedef unsigned char snd_seq_event_type_t; + +/** Sequencer event type */ +enum snd_seq_event_type { +	/** system status; event data type = #snd_seq_result_t */ +	SND_SEQ_EVENT_SYSTEM = 0, +	/** returned result status; event data type = #snd_seq_result_t */ +	SND_SEQ_EVENT_RESULT, + +	/** note on and off with duration; event data type = #snd_seq_ev_note_t */ +	SND_SEQ_EVENT_NOTE = 5, +	/** note on; event data type = #snd_seq_ev_note_t */ +	SND_SEQ_EVENT_NOTEON, +	/** note off; event data type = #snd_seq_ev_note_t */ +	SND_SEQ_EVENT_NOTEOFF, +	/** key pressure change (aftertouch); event data type = #snd_seq_ev_note_t */ +	SND_SEQ_EVENT_KEYPRESS, +	 +	/** controller; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_CONTROLLER = 10, +	/** program change; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_PGMCHANGE, +	/** channel pressure; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_CHANPRESS, +	/** pitchwheel; event data type = #snd_seq_ev_ctrl_t; data is from -8192 to 8191) */ +	SND_SEQ_EVENT_PITCHBEND, +	/** 14 bit controller value; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_CONTROL14, +	/** 14 bit NRPN;  event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_NONREGPARAM, +	/** 14 bit RPN; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_REGPARAM, + +	/** SPP with LSB and MSB values; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_SONGPOS = 20, +	/** Song Select with song ID number; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_SONGSEL, +	/** midi time code quarter frame; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_QFRAME, +	/** SMF Time Signature event; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_TIMESIGN, +	/** SMF Key Signature event; event data type = #snd_seq_ev_ctrl_t */ +	SND_SEQ_EVENT_KEYSIGN, +	         +	/** MIDI Real Time Start message; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_START = 30, +	/** MIDI Real Time Continue message; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_CONTINUE, +	/** MIDI Real Time Stop message; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_STOP, +	/** Set tick queue position; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_SETPOS_TICK, +	/** Set real-time queue position; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_SETPOS_TIME, +	/** (SMF) Tempo event; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_TEMPO, +	/** MIDI Real Time Clock message; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_CLOCK, +	/** MIDI Real Time Tick message; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_TICK, +	/** Queue timer skew; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_QUEUE_SKEW, +	/** Sync position changed; event data type = #snd_seq_ev_queue_control_t */ +	SND_SEQ_EVENT_SYNC_POS, + +	/** Tune request; event data type = none */ +	SND_SEQ_EVENT_TUNE_REQUEST = 40, +	/** Reset to power-on state; event data type = none */ +	SND_SEQ_EVENT_RESET, +	/** Active sensing event; event data type = none */ +	SND_SEQ_EVENT_SENSING, + +	/** Echo-back event; event data type = any type */ +	SND_SEQ_EVENT_ECHO = 50, +	/** OSS emulation raw event; event data type = any type */ +	SND_SEQ_EVENT_OSS, + +	/** New client has connected; event data type = #snd_seq_addr_t */ +	SND_SEQ_EVENT_CLIENT_START = 60, +	/** Client has left the system; event data type = #snd_seq_addr_t */ +	SND_SEQ_EVENT_CLIENT_EXIT, +	/** Client status/info has changed; event data type = #snd_seq_addr_t */ +	SND_SEQ_EVENT_CLIENT_CHANGE, +	/** New port was created; event data type = #snd_seq_addr_t */ +	SND_SEQ_EVENT_PORT_START, +	/** Port was deleted from system; event data type = #snd_seq_addr_t */ +	SND_SEQ_EVENT_PORT_EXIT, +	/** Port status/info has changed; event data type = #snd_seq_addr_t */ +	SND_SEQ_EVENT_PORT_CHANGE, + +	/** Ports connected; event data type = #snd_seq_connect_t */ +	SND_SEQ_EVENT_PORT_SUBSCRIBED, +	/** Ports disconnected; event data type = #snd_seq_connect_t */ +	SND_SEQ_EVENT_PORT_UNSUBSCRIBED, + +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR0 = 90, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR1, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR2, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR3, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR4, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR5, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR6, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR7, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR8, +	/** user-defined event; event data type = any (fixed size) */ +	SND_SEQ_EVENT_USR9, + +	/** system exclusive data (variable length);  event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_SYSEX = 130, +	/** error event;  event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_BOUNCE, +	/** reserved for user apps;  event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_USR_VAR0 = 135, +	/** reserved for user apps; event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_USR_VAR1, +	/** reserved for user apps; event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_USR_VAR2, +	/** reserved for user apps; event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_USR_VAR3, +	/** reserved for user apps; event data type = #snd_seq_ev_ext_t */ +	SND_SEQ_EVENT_USR_VAR4, + +	/** NOP; ignored in any case */ +	SND_SEQ_EVENT_NONE = 255 +}; + + +/** Sequencer event address */ +typedef struct snd_seq_addr { +	unsigned char client;	/**< Client id */ +	unsigned char port;	/**< Port id */ +} snd_seq_addr_t; + +/** Connection (subscription) between ports */ +typedef struct snd_seq_connect { +	snd_seq_addr_t sender;	/**< sender address */ +	snd_seq_addr_t dest;	/**< destination address */ +} snd_seq_connect_t; + + +/** Real-time data record */ +typedef struct snd_seq_real_time { +	unsigned int tv_sec;		/**< seconds */ +	unsigned int tv_nsec;		/**< nanoseconds */ +} snd_seq_real_time_t; + +/** (MIDI) Tick-time data record */ +typedef unsigned int snd_seq_tick_time_t; + +/** unioned time stamp */ +typedef union snd_seq_timestamp { +	snd_seq_tick_time_t tick;	/**< tick-time */ +	struct snd_seq_real_time time;	/**< real-time */ +} snd_seq_timestamp_t; + + +/** + * Event mode flags + * + * NOTE: only 8 bits available! + */ +#define SND_SEQ_TIME_STAMP_TICK		(0<<0)	/**< timestamp in clock ticks */ +#define SND_SEQ_TIME_STAMP_REAL		(1<<0)	/**< timestamp in real time */ +#define SND_SEQ_TIME_STAMP_MASK		(1<<0)	/**< mask for timestamp bits */ + +#define SND_SEQ_TIME_MODE_ABS		(0<<1)	/**< absolute timestamp */ +#define SND_SEQ_TIME_MODE_REL		(1<<1)	/**< relative to current time */ +#define SND_SEQ_TIME_MODE_MASK		(1<<1)	/**< mask for time mode bits */ + +#define SND_SEQ_EVENT_LENGTH_FIXED	(0<<2)	/**< fixed event size */ +#define SND_SEQ_EVENT_LENGTH_VARIABLE	(1<<2)	/**< variable event size */ +#define SND_SEQ_EVENT_LENGTH_VARUSR	(2<<2)	/**< variable event size - user memory space */ +#define SND_SEQ_EVENT_LENGTH_MASK	(3<<2)	/**< mask for event length bits */ + +#define SND_SEQ_PRIORITY_NORMAL		(0<<4)	/**< normal priority */ +#define SND_SEQ_PRIORITY_HIGH		(1<<4)	/**< event should be processed before others */ +#define SND_SEQ_PRIORITY_MASK		(1<<4)	/**< mask for priority bits */ + + +/** Note event */ +typedef struct snd_seq_ev_note { +	unsigned char channel;		/**< channel number */ +	unsigned char note;		/**< note */ +	unsigned char velocity;		/**< velocity */ +	unsigned char off_velocity;	/**< note-off velocity; only for #SND_SEQ_EVENT_NOTE */ +	unsigned int duration;		/**< duration until note-off; only for #SND_SEQ_EVENT_NOTE */ +} snd_seq_ev_note_t; + +/** Controller event */ +typedef struct snd_seq_ev_ctrl { +	unsigned char channel;		/**< channel number */ +	unsigned char unused[3];	/**< reserved */ +	unsigned int param;		/**< control parameter */ +	signed int value;		/**< control value */ +} snd_seq_ev_ctrl_t; + +/** generic set of bytes (12x8 bit) */ +typedef struct snd_seq_ev_raw8 { +	unsigned char d[12];		/**< 8 bit value */ +} snd_seq_ev_raw8_t; + +/** generic set of integers (3x32 bit) */ +typedef struct snd_seq_ev_raw32 { +	unsigned int d[3];		/**< 32 bit value */ +} snd_seq_ev_raw32_t; + +/** external stored data */ +struct snd_seq_ev_ext { +	unsigned int len;		/**< length of data */ +	void *ptr;			/**< pointer to data (note: can be 64-bit) */ +} __attribute__((packed)); +/** external stored data */ +typedef struct snd_seq_ev_ext snd_seq_ev_ext_t; +#ifdef DOC_HIDDEN +/* redefine typedef for stupid doxygen */ +typedef snd_seq_ev_ext snd_seq_ev_ext_t; +#endif + +/** Result events */ +typedef struct snd_seq_result { +	int event;		/**< processed event type */ +	int result;		/**< status */ +} snd_seq_result_t; + +/** Queue skew values */ +typedef struct snd_seq_queue_skew { +	unsigned int value;	/**< skew value */ +	unsigned int base;	/**< skew base */ +} snd_seq_queue_skew_t; + +/** queue timer control */ +typedef struct snd_seq_ev_queue_control { +	unsigned char queue;			/**< affected queue */ +	unsigned char unused[3];		/**< reserved */ +	union { +		signed int value;		/**< affected value (e.g. tempo) */ +		snd_seq_timestamp_t time;	/**< time */ +		unsigned int position;		/**< sync position */ +		snd_seq_queue_skew_t skew;	/**< queue skew */ +		unsigned int d32[2];		/**< any data */ +		unsigned char d8[8];		/**< any data */ +	} param;				/**< data value union */ +} snd_seq_ev_queue_control_t; + + +/** Sequencer event */ +typedef struct snd_seq_event { +	snd_seq_event_type_t type;	/**< event type */ +	unsigned char flags;		/**< event flags */ +	unsigned char tag;		/**< tag */ +	 +	unsigned char queue;		/**< schedule queue */ +	snd_seq_timestamp_t time;	/**< schedule time */ + +	snd_seq_addr_t source;		/**< source address */ +	snd_seq_addr_t dest;		/**< destination address */ + +	union { +		snd_seq_ev_note_t note;		/**< note information */ +		snd_seq_ev_ctrl_t control;	/**< MIDI control information */ +		snd_seq_ev_raw8_t raw8;		/**< raw8 data */ +		snd_seq_ev_raw32_t raw32;	/**< raw32 data */ +		snd_seq_ev_ext_t ext;		/**< external data */ +		snd_seq_ev_queue_control_t queue; /**< queue control */ +		snd_seq_timestamp_t time;	/**< timestamp */ +		snd_seq_addr_t addr;		/**< address */ +		snd_seq_connect_t connect;	/**< connect information */ +		snd_seq_result_t result;	/**< operation result code */ +	} data;				/**< event data... */ +} snd_seq_event_t; + + +/** \} */ + +#endif /* __ALSA_SEQ_EVENT_H */ + diff --git a/include/alsa/seq_midi_event.h b/include/alsa/seq_midi_event.h new file mode 100644 index 0000000..4cfb15c --- /dev/null +++ b/include/alsa/seq_midi_event.h @@ -0,0 +1,65 @@ +/** + * \file include/seq_midi_event.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_SEQ_MIDI_EVENT_H +#define __ALSA_SEQ_MIDI_EVENT_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup MIDI_Event Sequencer event <-> MIDI byte stream coder + *  \ingroup Sequencer + *  Sequencer event <-> MIDI byte stream coder + *  \{ + */ + +/** container for sequencer midi event parsers */ +typedef struct snd_midi_event snd_midi_event_t; + +int snd_midi_event_new(size_t bufsize, snd_midi_event_t **rdev); +int snd_midi_event_resize_buffer(snd_midi_event_t *dev, size_t bufsize); +void snd_midi_event_free(snd_midi_event_t *dev); +void snd_midi_event_init(snd_midi_event_t *dev); +void snd_midi_event_reset_encode(snd_midi_event_t *dev); +void snd_midi_event_reset_decode(snd_midi_event_t *dev); +void snd_midi_event_no_status(snd_midi_event_t *dev, int on); +/* encode from byte stream - return number of written bytes if success */ +long snd_midi_event_encode(snd_midi_event_t *dev, const unsigned char *buf, long count, snd_seq_event_t *ev); +int snd_midi_event_encode_byte(snd_midi_event_t *dev, int c, snd_seq_event_t *ev); +/* decode from event to bytes - return number of written bytes if success */ +long snd_midi_event_decode(snd_midi_event_t *dev, unsigned char *buf, long count, const snd_seq_event_t *ev); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_SEQ_MIDI_EVENT_H */ + diff --git a/include/alsa/seqmid.h b/include/alsa/seqmid.h new file mode 100644 index 0000000..3986628 --- /dev/null +++ b/include/alsa/seqmid.h @@ -0,0 +1,490 @@ +/** + * \file include/seqmid.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_SEQMID_H +#define __ALSA_SEQMID_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup SeqMiddle Sequencer Middle Level Interface + *  Sequencer Middle Level Interface + *  \ingroup Sequencer + *  \{ + */ + +/** + * \brief initialize event record + * \param ev event record pointer + *  + * This macro clears the given event record pointer to the default status. + */ +#define snd_seq_ev_clear(ev) \ +	memset(ev, 0, sizeof(snd_seq_event_t)) + +/** + * \brief set the tag for given event + * \param ev event record + * \param t event tag + * + * This macro sets the tag to the given event record. + */ +#define snd_seq_ev_set_tag(ev,t) \ +	((ev)->tag = (t)) + +/** + * \brief set the explicit destination + * \param ev event record + * \param c destination client id + * \param p destination port id + * + * This macro sets the client and port id numbers to the given event record. + * + * \sa snd_seq_ev_set_subs() + */ +#define snd_seq_ev_set_dest(ev,c,p) \ +	((ev)->dest.client = (c), (ev)->dest.port = (p)) + +/** + * \brief set broadcasting to subscribers + * \param ev event record + * + * This macro sets the destination as the subscribers. + * + * \sa snd_seq_ev_set_dest() + */ +#define snd_seq_ev_set_subs(ev) \ +	((ev)->dest.client = SND_SEQ_ADDRESS_SUBSCRIBERS,\ +	 (ev)->dest.port = SND_SEQ_ADDRESS_UNKNOWN) + +/** + * \brief set broadcasting to all clients/ports + * \param ev event record + * + * This macro sets the destination as the broadcasting. + * + * \sa snd_seq_ev_set_dest() + */ +#define snd_seq_ev_set_broadcast(ev) \ +	((ev)->dest.client = SND_SEQ_ADDRESS_BROADCAST,\ +	 (ev)->dest.port = SND_SEQ_ADDRESS_BROADCAST) + +/** + * \brief set the source port + * \param ev event record + * \param p source port id + * + * This macro sets the source port id number. + */ +#define snd_seq_ev_set_source(ev,p) \ +	((ev)->source.port = (p)) + +/** + * \brief set direct passing mode (without queued) + * \param ev event instance + * + * This macro sets the event to the direct passing mode + * to be delivered immediately without queueing. + *  + * \sa snd_seq_ev_schedule_tick(), snd_seq_ev_schedule_real() + */ +#define snd_seq_ev_set_direct(ev) \ +	((ev)->queue = SND_SEQ_QUEUE_DIRECT) + +/** + * \brief set tick-scheduling mode on queue + * \param ev event instance + * \param q queue id to schedule + * \param relative relative time-stamp if non-zero + * \param ttick tick time-stamp to be delivered + * + * This macro sets the scheduling of the event in the + * MIDI tick mode. + * + * \sa snd_seq_ev_schedule_real(), snd_seq_ev_set_direct() + */ +#define snd_seq_ev_schedule_tick(ev, q, relative, ttick) \ +	((ev)->flags &= ~(SND_SEQ_TIME_STAMP_MASK | SND_SEQ_TIME_MODE_MASK),\ +	 (ev)->flags |= SND_SEQ_TIME_STAMP_TICK,\ +	 (ev)->flags |= (relative) ? SND_SEQ_TIME_MODE_REL : SND_SEQ_TIME_MODE_ABS,\ +	 (ev)->time.tick = (ttick),\ +	 (ev)->queue = (q)) + +/** + * \brief set real-time-scheduling mode on queue + * \param ev event instance + * \param q queue id to schedule + * \param relative relative time-stamp if non-zero + * \param rtime time-stamp to be delivered + * + * This macro sets the scheduling of the event in the + * realtime mode. + * + * \sa snd_seq_ev_schedule_tick(), snd_seq_ev_set_direct() + */ +#define snd_seq_ev_schedule_real(ev, q, relative, rtime) \ +	((ev)->flags &= ~(SND_SEQ_TIME_STAMP_MASK | SND_SEQ_TIME_MODE_MASK),\ +	 (ev)->flags |= SND_SEQ_TIME_STAMP_REAL,\ +	 (ev)->flags |= (relative) ? SND_SEQ_TIME_MODE_REL : SND_SEQ_TIME_MODE_ABS,\ +	 (ev)->time.time = *(rtime),\ +	 (ev)->queue = (q)) + +/** + * \brief set event priority + * \param ev event instance + * \param high_prior 1 for high priority mode + */ +#define snd_seq_ev_set_priority(ev, high_prior) \ +	((ev)->flags &= ~SND_SEQ_PRIORITY_MASK,\ +	 (ev)->flags |= (high_prior) ? SND_SEQ_PRIORITY_HIGH : SND_SEQ_PRIORITY_NORMAL) + +/** + * \brief set fixed data + * \param ev event instance + * + * Sets the event length mode as fixed size. + * + * \sa snd_seq_ev_set_variable(), snd_seq_ev_set_varusr() + */ +#define snd_seq_ev_set_fixed(ev) \ +	((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\ +	 (ev)->flags |= SND_SEQ_EVENT_LENGTH_FIXED) + +/** + * \brief set variable data + * \param ev event instance + * \param datalen length of the external data + * \param dataptr pointer of the external data + * + * Sets the event length mode as variable length and stores the data. + * + * \sa snd_seq_ev_set_fixed(), snd_seq_ev_set_varusr() + */ +#define snd_seq_ev_set_variable(ev, datalen, dataptr) \ +	((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\ +	 (ev)->flags |= SND_SEQ_EVENT_LENGTH_VARIABLE,\ +	 (ev)->data.ext.len = (datalen),\ +	 (ev)->data.ext.ptr = (dataptr)) + +/** + * \brief set varusr data + * \param ev event instance + * \param datalen length of the external data + * \param dataptr pointer of the external data + * + * Sets the event length mode as variable user-space data and stores the data. + * + * \sa snd_seq_ev_set_fixed(), snd_seq_ev_set_variable() + */ +#define snd_seq_ev_set_varusr(ev, datalen, dataptr) \ +	((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\ +	 (ev)->flags |= SND_SEQ_EVENT_LENGTH_VARUSR,\ +	 (ev)->data.ext.len = (datalen),\ +	 (ev)->data.ext.ptr = (dataptr)) + +/** + * \brief set queue controls + * \param ev event record + * \param typ event type + * \param q queue id + * \param val control value + */ +#define snd_seq_ev_set_queue_control(ev, typ, q, val) \ +	((ev)->type = (typ),\ +	 snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\ +	 (ev)->data.queue.queue = (q),\ +	 (ev)->data.queue.param.value = (val)) + +/** + * \brief set the start queue event + * \param ev event record + * \param q queue id to start + * + * \sa snd_seq_ev_set_queue_stop(), snd_seq_ev_set_queue_continue() + */ +#define snd_seq_ev_set_queue_start(ev, q) \ +	snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_START, q, 0) + +/** + * \brief set the stop queue event + * \param ev event record + * \param q queue id to stop + * + * \sa snd_seq_ev_set_queue_start(), snd_seq_ev_set_queue_continue() + */ +#define snd_seq_ev_set_queue_stop(ev, q) \ +	snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_STOP, q, 0) + +/** + * \brief set the stop queue event + * \param ev event record + * \param q queue id to continue + * + * \sa snd_seq_ev_set_queue_start(), snd_seq_ev_set_queue_stop() + */ +#define snd_seq_ev_set_queue_continue(ev, q) \ +	snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_CONTINUE, q, 0) + +/** + * \brief set the stop queue event + * \param ev event record + * \param q queue id to change tempo + * \param val the new tempo value + */ +#define snd_seq_ev_set_queue_tempo(ev, q, val) \ +	snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_TEMPO, q, val) + +/** + * \brief set the real-time position of a queue + * \param ev event record + * \param q queue id to change tempo + * \param rtime the new real-time pointer + */ +#define snd_seq_ev_set_queue_pos_real(ev, q, rtime) \ +	((ev)->type = SND_SEQ_EVENT_SETPOS_TIME,\ +	 snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\ +	 (ev)->data.queue.queue = (q),\ +	 (ev)->data.queue.param.time.time = *(rtime)) + +/** + * \brief set the tick-time position of a queue + * \param ev event record + * \param q queue id to change tempo + * \param ttime the new tick-time + */ +#define snd_seq_ev_set_queue_pos_tick(ev, q, ttime) \ +	((ev)->type = SND_SEQ_EVENT_SETPOS_TICK,\ +	 snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\ +	 (ev)->data.queue.queue = (q),\ +	 (ev)->data.queue.param.time.tick = (ttime)) + +/* set and send a queue control event */ +int snd_seq_control_queue(snd_seq_t *seq, int q, int type, int value, snd_seq_event_t *ev); + +/** + * \brief start the specified queue + * \param seq sequencer handle + * \param q queue id to start + * \param ev optional event record (see #snd_seq_control_queue) + */ +#define snd_seq_start_queue(seq, q, ev) \ +	snd_seq_control_queue(seq, q, SND_SEQ_EVENT_START, 0, ev) + +/** + * \brief stop the specified queue + * \param seq sequencer handle + * \param q queue id to stop + * \param ev optional event record (see #snd_seq_control_queue) + */ +#define snd_seq_stop_queue(seq, q, ev) \ +	snd_seq_control_queue(seq, q, SND_SEQ_EVENT_STOP, 0, ev) + +/** + * \brief continue the specified queue + * \param seq sequencer handle + * \param q queue id to continue + * \param ev optional event record (see #snd_seq_control_queue) + */ +#define snd_seq_continue_queue(seq, q, ev) \ +	snd_seq_control_queue(seq, q, SND_SEQ_EVENT_CONTINUE, 0, ev) + +/** + * \brief change the tempo of the specified queue + * \param seq sequencer handle + * \param q queue id + * \param tempo the new tempo value + * \param ev optional event record (see #snd_seq_control_queue) + */ +#define snd_seq_change_queue_tempo(seq, q, tempo, ev) \ +	snd_seq_control_queue(seq, q, SND_SEQ_EVENT_TEMPO, tempo, ev) + +/* create a port - simple version - return the port number */ +int snd_seq_create_simple_port(snd_seq_t *seq, const char *name, +			       unsigned int caps, unsigned int type); +/* delete the port */ +int snd_seq_delete_simple_port(snd_seq_t *seq, int port); + +/* simple subscription between this port and another port +   (w/o exclusive & time conversion) +   */ +int snd_seq_connect_from(snd_seq_t *seq, int my_port, int src_client, int src_port); +int snd_seq_connect_to(snd_seq_t *seq, int my_port, int dest_client, int dest_port); +int snd_seq_disconnect_from(snd_seq_t *seq, int my_port, int src_client, int src_port); +int snd_seq_disconnect_to(snd_seq_t *seq, int my_port, int dest_client, int dest_port); + +/* + * set client information + */ +int snd_seq_set_client_name(snd_seq_t *seq, const char *name); +int snd_seq_set_client_event_filter(snd_seq_t *seq, int event_type); +int snd_seq_set_client_pool_output(snd_seq_t *seq, size_t size); +int snd_seq_set_client_pool_output_room(snd_seq_t *seq, size_t size); +int snd_seq_set_client_pool_input(snd_seq_t *seq, size_t size); +/* sync output queue */ +int snd_seq_sync_output_queue(snd_seq_t *seq); + +/* + * parse the given string and get the sequencer address + */ +int snd_seq_parse_address(snd_seq_t *seq, snd_seq_addr_t *addr, const char *str); + +/* + * reset client input/output pool + */ +int snd_seq_reset_pool_output(snd_seq_t *seq); +int snd_seq_reset_pool_input(snd_seq_t *seq); + +/** + * \brief set note event + * \param ev event record + * \param ch channel number + * \param key note key + * \param vel velocity + * \param dur duration (in tick or msec) + */ +#define snd_seq_ev_set_note(ev, ch, key, vel, dur) \ +	((ev)->type = SND_SEQ_EVENT_NOTE,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.note.channel = (ch),\ +	 (ev)->data.note.note = (key),\ +	 (ev)->data.note.velocity = (vel),\ +	 (ev)->data.note.duration = (dur)) + +/** + * \brief set note-on event + * \param ev event record + * \param ch channel number + * \param key note key + * \param vel velocity + */ +#define snd_seq_ev_set_noteon(ev, ch, key, vel) \ +	((ev)->type = SND_SEQ_EVENT_NOTEON,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.note.channel = (ch),\ +	 (ev)->data.note.note = (key),\ +	 (ev)->data.note.velocity = (vel)) + +/** + * \brief set note-off event + * \param ev event record + * \param ch channel number + * \param key note key + * \param vel velocity + */ +#define snd_seq_ev_set_noteoff(ev, ch, key, vel) \ +	((ev)->type = SND_SEQ_EVENT_NOTEOFF,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.note.channel = (ch),\ +	 (ev)->data.note.note = (key),\ +	 (ev)->data.note.velocity = (vel)) + +/** + * \brief set key-pressure event + * \param ev event record + * \param ch channel number + * \param key note key + * \param vel velocity + */ +#define snd_seq_ev_set_keypress(ev,ch,key,vel) \ +	((ev)->type = SND_SEQ_EVENT_KEYPRESS,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.note.channel = (ch),\ +	 (ev)->data.note.note = (key),\ +	 (ev)->data.note.velocity = (vel)) + +/** + * \brief set MIDI controller event + * \param ev event record + * \param ch channel number + * \param cc controller number + * \param val control value + */ +#define snd_seq_ev_set_controller(ev,ch,cc,val) \ +	((ev)->type = SND_SEQ_EVENT_CONTROLLER,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.control.channel = (ch),\ +	 (ev)->data.control.param = (cc),\ +	 (ev)->data.control.value = (val)) + +/** + * \brief set program change event + * \param ev event record + * \param ch channel number + * \param val program number + */ +#define snd_seq_ev_set_pgmchange(ev,ch,val) \ +	((ev)->type = SND_SEQ_EVENT_PGMCHANGE,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.control.channel = (ch),\ +	 (ev)->data.control.value = (val)) + +/** + * \brief set pitch-bend event + * \param ev event record + * \param ch channel number + * \param val pitch bend; zero centered from -8192 to 8191 + */ +#define snd_seq_ev_set_pitchbend(ev,ch,val) \ +	((ev)->type = SND_SEQ_EVENT_PITCHBEND,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.control.channel = (ch),\ +	 (ev)->data.control.value = (val)) + +/** + * \brief set channel pressure event + * \param ev event record + * \param ch channel number + * \param val channel pressure value + */ +#define snd_seq_ev_set_chanpress(ev,ch,val) \ +	((ev)->type = SND_SEQ_EVENT_CHANPRESS,\ +	 snd_seq_ev_set_fixed(ev),\ +	 (ev)->data.control.channel = (ch),\ +	 (ev)->data.control.value = (val)) + +/** + * \brief set sysex event + * \param ev event record + * \param datalen length of sysex data + * \param dataptr sysex data pointer + * + * the sysex data must contain the start byte 0xf0 and the end byte 0xf7. + */ +#define snd_seq_ev_set_sysex(ev,datalen,dataptr) \ +	((ev)->type = SND_SEQ_EVENT_SYSEX,\ +	 snd_seq_ev_set_variable(ev, datalen, dataptr)) + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_SEQMID_H */ + diff --git a/include/alsa/sound/asoc.h b/include/alsa/sound/asoc.h new file mode 100644 index 0000000..bb8aec7 --- /dev/null +++ b/include/alsa/sound/asoc.h @@ -0,0 +1,572 @@ +/* + * uapi/sound/asoc.h -- ALSA SoC Firmware Controls and DAPM + * + * Copyright (C) 2012 Texas Instruments Inc. + * Copyright (C) 2015 Intel Corporation. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * Simple file API to load FW that includes mixers, coefficients, DAPM graphs, + * algorithms, equalisers, DAIs, widgets etc. +*/ + +#ifndef __LINUX_UAPI_SND_ASOC_H +#define __LINUX_UAPI_SND_ASOC_H + +/* + * Maximum number of channels topology kcontrol can represent. + */ +#define SND_SOC_TPLG_MAX_CHAN		8 + +/* + * Maximum number of PCM formats capability + */ +#define SND_SOC_TPLG_MAX_FORMATS	16 + +/* + * Maximum number of PCM stream configs + */ +#define SND_SOC_TPLG_STREAM_CONFIG_MAX  8 + +/* + * Maximum number of physical link's hardware configs + */ +#define SND_SOC_TPLG_HW_CONFIG_MAX	8 + +/* individual kcontrol info types - can be mixed with other types */ +#define SND_SOC_TPLG_CTL_VOLSW		1 +#define SND_SOC_TPLG_CTL_VOLSW_SX	2 +#define SND_SOC_TPLG_CTL_VOLSW_XR_SX	3 +#define SND_SOC_TPLG_CTL_ENUM		4 +#define SND_SOC_TPLG_CTL_BYTES		5 +#define SND_SOC_TPLG_CTL_ENUM_VALUE	6 +#define SND_SOC_TPLG_CTL_RANGE		7 +#define SND_SOC_TPLG_CTL_STROBE		8 + + +/* individual widget kcontrol info types - can be mixed with other types */ +#define SND_SOC_TPLG_DAPM_CTL_VOLSW		64 +#define SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE	65 +#define SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT		66 +#define SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE	67 +#define SND_SOC_TPLG_DAPM_CTL_PIN		68 + +/* DAPM widget types - add new items to the end */ +#define SND_SOC_TPLG_DAPM_INPUT		0 +#define SND_SOC_TPLG_DAPM_OUTPUT	1 +#define SND_SOC_TPLG_DAPM_MUX		2 +#define SND_SOC_TPLG_DAPM_MIXER		3 +#define SND_SOC_TPLG_DAPM_PGA		4 +#define SND_SOC_TPLG_DAPM_OUT_DRV	5 +#define SND_SOC_TPLG_DAPM_ADC		6 +#define SND_SOC_TPLG_DAPM_DAC		7 +#define SND_SOC_TPLG_DAPM_SWITCH	8 +#define SND_SOC_TPLG_DAPM_PRE		9 +#define SND_SOC_TPLG_DAPM_POST		10 +#define SND_SOC_TPLG_DAPM_AIF_IN	11 +#define SND_SOC_TPLG_DAPM_AIF_OUT	12 +#define SND_SOC_TPLG_DAPM_DAI_IN	13 +#define SND_SOC_TPLG_DAPM_DAI_OUT	14 +#define SND_SOC_TPLG_DAPM_DAI_LINK	15 +#define SND_SOC_TPLG_DAPM_BUFFER	16 +#define SND_SOC_TPLG_DAPM_SCHEDULER	17 +#define SND_SOC_TPLG_DAPM_EFFECT	18 +#define SND_SOC_TPLG_DAPM_SIGGEN	19 +#define SND_SOC_TPLG_DAPM_SRC		20 +#define SND_SOC_TPLG_DAPM_ASRC		21 +#define SND_SOC_TPLG_DAPM_ENCODER	22 +#define SND_SOC_TPLG_DAPM_DECODER	23 +#define SND_SOC_TPLG_DAPM_LAST		SND_SOC_TPLG_DAPM_DECODER + +/* Header magic number and string sizes */ +#define SND_SOC_TPLG_MAGIC		0x41536F43 /* ASoC */ + +/* string sizes */ +#define SND_SOC_TPLG_NUM_TEXTS		16 + +/* ABI version */ +#define SND_SOC_TPLG_ABI_VERSION	0x5	/* current version */ +#define SND_SOC_TPLG_ABI_VERSION_MIN	0x4	/* oldest version supported */ + +/* Max size of TLV data */ +#define SND_SOC_TPLG_TLV_SIZE		32 + +/* + * File and Block header data types. + * Add new generic and vendor types to end of list. + * Generic types are handled by the core whilst vendors types are passed + * to the component drivers for handling. + */ +#define SND_SOC_TPLG_TYPE_MIXER		1 +#define SND_SOC_TPLG_TYPE_BYTES		2 +#define SND_SOC_TPLG_TYPE_ENUM		3 +#define SND_SOC_TPLG_TYPE_DAPM_GRAPH	4 +#define SND_SOC_TPLG_TYPE_DAPM_WIDGET	5 +#define SND_SOC_TPLG_TYPE_DAI_LINK	6 +#define SND_SOC_TPLG_TYPE_PCM		7 +#define SND_SOC_TPLG_TYPE_MANIFEST	8 +#define SND_SOC_TPLG_TYPE_CODEC_LINK	9 +#define SND_SOC_TPLG_TYPE_BACKEND_LINK	10 +#define SND_SOC_TPLG_TYPE_PDATA		11 +#define SND_SOC_TPLG_TYPE_DAI		12 +#define SND_SOC_TPLG_TYPE_MAX		SND_SOC_TPLG_TYPE_DAI + +/* vendor block IDs - please add new vendor types to end */ +#define SND_SOC_TPLG_TYPE_VENDOR_FW	1000 +#define SND_SOC_TPLG_TYPE_VENDOR_CONFIG	1001 +#define SND_SOC_TPLG_TYPE_VENDOR_COEFF	1002 +#define SND_SOC_TPLG_TYPEVENDOR_CODEC	1003 + +#define SND_SOC_TPLG_STREAM_PLAYBACK	0 +#define SND_SOC_TPLG_STREAM_CAPTURE	1 + +/* vendor tuple types */ +#define SND_SOC_TPLG_TUPLE_TYPE_UUID	0 +#define SND_SOC_TPLG_TUPLE_TYPE_STRING	1 +#define SND_SOC_TPLG_TUPLE_TYPE_BOOL	2 +#define SND_SOC_TPLG_TUPLE_TYPE_BYTE	3 +#define SND_SOC_TPLG_TUPLE_TYPE_WORD	4 +#define SND_SOC_TPLG_TUPLE_TYPE_SHORT	5 + +/* DAI flags */ +#define SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_RATES         (1 << 0) +#define SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_CHANNELS      (1 << 1) +#define SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_SAMPLEBITS    (1 << 2) + +/* DAI clock gating */ +#define SND_SOC_TPLG_DAI_CLK_GATE_UNDEFINED	0 +#define SND_SOC_TPLG_DAI_CLK_GATE_GATED	1 +#define SND_SOC_TPLG_DAI_CLK_GATE_CONT		2 + +/* DAI mclk_direction */ +#define SND_SOC_TPLG_MCLK_CO            0 /* for codec, mclk is output */ +#define SND_SOC_TPLG_MCLK_CI            1 /* for codec, mclk is input */ + +/* DAI physical PCM data formats. + * Add new formats to the end of the list. + */ +#define SND_SOC_DAI_FORMAT_I2S          1 /* I2S mode */ +#define SND_SOC_DAI_FORMAT_RIGHT_J      2 /* Right Justified mode */ +#define SND_SOC_DAI_FORMAT_LEFT_J       3 /* Left Justified mode */ +#define SND_SOC_DAI_FORMAT_DSP_A        4 /* L data MSB after FRM LRC */ +#define SND_SOC_DAI_FORMAT_DSP_B        5 /* L data MSB during FRM LRC */ +#define SND_SOC_DAI_FORMAT_AC97         6 /* AC97 */ +#define SND_SOC_DAI_FORMAT_PDM          7 /* Pulse density modulation */ + +/* left and right justified also known as MSB and LSB respectively */ +#define SND_SOC_DAI_FORMAT_MSB          SND_SOC_DAI_FORMAT_LEFT_J +#define SND_SOC_DAI_FORMAT_LSB          SND_SOC_DAI_FORMAT_RIGHT_J + +/* DAI link flags */ +#define SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_RATES         (1 << 0) +#define SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_CHANNELS      (1 << 1) +#define SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_SAMPLEBITS    (1 << 2) +#define SND_SOC_TPLG_LNK_FLGBIT_VOICE_WAKEUP            (1 << 3) + +/* DAI topology BCLK parameter + * For the backwards capability, by default codec is bclk master + */ +#define SND_SOC_TPLG_BCLK_CM         0 /* codec is bclk master */ +#define SND_SOC_TPLG_BCLK_CS         1 /* codec is bclk slave */ + +/* DAI topology FSYNC parameter + * For the backwards capability, by default codec is fsync master + */ +#define SND_SOC_TPLG_FSYNC_CM         0 /* codec is fsync master */ +#define SND_SOC_TPLG_FSYNC_CS         1 /* codec is fsync slave */ + +/* + * Block Header. + * This header precedes all object and object arrays below. + */ +struct snd_soc_tplg_hdr { +	__le32 magic;		/* magic number */ +	__le32 abi;		/* ABI version */ +	__le32 version;		/* optional vendor specific version details */ +	__le32 type;		/* SND_SOC_TPLG_TYPE_ */ +	__le32 size;		/* size of this structure */ +	__le32 vendor_type;	/* optional vendor specific type info */ +	__le32 payload_size;	/* data bytes, excluding this header */ +	__le32 index;		/* identifier for block */ +	__le32 count;		/* number of elements in block */ +} __attribute__((packed)); + +/* vendor tuple for uuid */ +struct snd_soc_tplg_vendor_uuid_elem { +	__le32 token; +	char uuid[16]; +} __attribute__((packed)); + +/* vendor tuple for a bool/byte/short/word value */ +struct snd_soc_tplg_vendor_value_elem { +	__le32 token; +	__le32 value; +} __attribute__((packed)); + +/* vendor tuple for string */ +struct snd_soc_tplg_vendor_string_elem { +	__le32 token; +	char string[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +} __attribute__((packed)); + +struct snd_soc_tplg_vendor_array { +	__le32 size;	/* size in bytes of the array, including all elements */ +	__le32 type;	/* SND_SOC_TPLG_TUPLE_TYPE_ */ +	__le32 num_elems;	/* number of elements in array */ +	union { +		struct snd_soc_tplg_vendor_uuid_elem uuid[0]; +		struct snd_soc_tplg_vendor_value_elem value[0]; +		struct snd_soc_tplg_vendor_string_elem string[0]; +	}; +} __attribute__((packed)); + +/* + * Private data. + * All topology objects may have private data that can be used by the driver or + * firmware. Core will ignore this data. + */ +struct snd_soc_tplg_private { +	__le32 size;	/* in bytes of private data */ +	union { +		char data[0]; +		struct snd_soc_tplg_vendor_array array[0]; +	}; +} __attribute__((packed)); + +/* + * Kcontrol TLV data. + */ +struct snd_soc_tplg_tlv_dbscale { +	__le32 min; +	__le32 step; +	__le32 mute; +} __attribute__((packed)); + +struct snd_soc_tplg_ctl_tlv { +	__le32 size;	/* in bytes of this structure */ +	__le32 type;	/* SNDRV_CTL_TLVT_*, type of TLV */ +	union { +		__le32 data[SND_SOC_TPLG_TLV_SIZE]; +		struct snd_soc_tplg_tlv_dbscale scale; +	}; +} __attribute__((packed)); + +/* + * Kcontrol channel data + */ +struct snd_soc_tplg_channel { +	__le32 size;	/* in bytes of this structure */ +	__le32 reg; +	__le32 shift; +	__le32 id;	/* ID maps to Left, Right, LFE etc */ +} __attribute__((packed)); + +/* + * Genericl Operations IDs, for binding Kcontrol or Bytes ext ops + * Kcontrol ops need get/put/info. + * Bytes ext ops need get/put. + */ +struct snd_soc_tplg_io_ops { +	__le32 get; +	__le32 put; +	__le32 info; +} __attribute__((packed)); + +/* + * kcontrol header + */ +struct snd_soc_tplg_ctl_hdr { +	__le32 size;	/* in bytes of this structure */ +	__le32 type; +	char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	__le32 access; +	struct snd_soc_tplg_io_ops ops; +	struct snd_soc_tplg_ctl_tlv tlv; +} __attribute__((packed)); + +/* + * Stream Capabilities + */ +struct snd_soc_tplg_stream_caps { +	__le32 size;		/* in bytes of this structure */ +	char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	__le64 formats;	/* supported formats SNDRV_PCM_FMTBIT_* */ +	__le32 rates;		/* supported rates SNDRV_PCM_RATE_* */ +	__le32 rate_min;	/* min rate */ +	__le32 rate_max;	/* max rate */ +	__le32 channels_min;	/* min channels */ +	__le32 channels_max;	/* max channels */ +	__le32 periods_min;	/* min number of periods */ +	__le32 periods_max;	/* max number of periods */ +	__le32 period_size_min;	/* min period size bytes */ +	__le32 period_size_max;	/* max period size bytes */ +	__le32 buffer_size_min;	/* min buffer size bytes */ +	__le32 buffer_size_max;	/* max buffer size bytes */ +	__le32 sig_bits;        /* number of bits of content */ +} __attribute__((packed)); + +/* + * FE or BE Stream configuration supported by SW/FW + */ +struct snd_soc_tplg_stream { +	__le32 size;		/* in bytes of this structure */ +	char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; /* Name of the stream */ +	__le64 format;		/* SNDRV_PCM_FMTBIT_* */ +	__le32 rate;		/* SNDRV_PCM_RATE_* */ +	__le32 period_bytes;	/* size of period in bytes */ +	__le32 buffer_bytes;	/* size of buffer in bytes */ +	__le32 channels;	/* channels */ +} __attribute__((packed)); + + +/* + * Describes a physical link's runtime supported hardware config, + * i.e. hardware audio formats. + */ +struct snd_soc_tplg_hw_config { +	__le32 size;            /* in bytes of this structure */ +	__le32 id;		/* unique ID - - used to match */ +	__le32 fmt;		/* SND_SOC_DAI_FORMAT_ format value */ +	__u8 clock_gated;	/* SND_SOC_TPLG_DAI_CLK_GATE_ value */ +	__u8 invert_bclk;	/* 1 for inverted BCLK, 0 for normal */ +	__u8 invert_fsync;	/* 1 for inverted frame clock, 0 for normal */ +	__u8 bclk_master;	/* SND_SOC_TPLG_BCLK_ value */ +	__u8 fsync_master;	/* SND_SOC_TPLG_FSYNC_ value */ +	__u8 mclk_direction;    /* SND_SOC_TPLG_MCLK_ value */ +	__le16 reserved;	/* for 32bit alignment */ +	__le32 mclk_rate;	/* MCLK or SYSCLK freqency in Hz */ +	__le32 bclk_rate;	/* BCLK freqency in Hz */ +	__le32 fsync_rate;	/* frame clock in Hz */ +	__le32 tdm_slots;	/* number of TDM slots in use */ +	__le32 tdm_slot_width;	/* width in bits for each slot */ +	__le32 tx_slots;	/* bit mask for active Tx slots */ +	__le32 rx_slots;	/* bit mask for active Rx slots */ +	__le32 tx_channels;	/* number of Tx channels */ +	__le32 tx_chanmap[SND_SOC_TPLG_MAX_CHAN]; /* array of slot number */ +	__le32 rx_channels;	/* number of Rx channels */ +	__le32 rx_chanmap[SND_SOC_TPLG_MAX_CHAN]; /* array of slot number */ +} __attribute__((packed)); + +/* + * Manifest. List totals for each payload type. Not used in parsing, but will + * be passed to the component driver before any other objects in order for any + * global component resource allocations. + * + * File block representation for manifest :- + * +-----------------------------------+----+ + * | struct snd_soc_tplg_hdr           |  1 | + * +-----------------------------------+----+ + * | struct snd_soc_tplg_manifest      |  1 | + * +-----------------------------------+----+ + */ +struct snd_soc_tplg_manifest { +	__le32 size;		/* in bytes of this structure */ +	__le32 control_elems;	/* number of control elements */ +	__le32 widget_elems;	/* number of widget elements */ +	__le32 graph_elems;	/* number of graph elements */ +	__le32 pcm_elems;	/* number of PCM elements */ +	__le32 dai_link_elems;	/* number of DAI link elements */ +	__le32 dai_elems;	/* number of physical DAI elements */ +	__le32 reserved[20];	/* reserved for new ABI element types */ +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); + +/* + * Mixer kcontrol. + * + * File block representation for mixer kcontrol :- + * +-----------------------------------+----+ + * | struct snd_soc_tplg_hdr           |  1 | + * +-----------------------------------+----+ + * | struct snd_soc_tplg_mixer_control |  N | + * +-----------------------------------+----+ + */ +struct snd_soc_tplg_mixer_control { +	struct snd_soc_tplg_ctl_hdr hdr; +	__le32 size;	/* in bytes of this structure */ +	__le32 min; +	__le32 max; +	__le32 platform_max; +	__le32 invert; +	__le32 num_channels; +	struct snd_soc_tplg_channel channel[SND_SOC_TPLG_MAX_CHAN]; +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); + +/* + * Enumerated kcontrol + * + * File block representation for enum kcontrol :- + * +-----------------------------------+----+ + * | struct snd_soc_tplg_hdr           |  1 | + * +-----------------------------------+----+ + * | struct snd_soc_tplg_enum_control  |  N | + * +-----------------------------------+----+ + */ +struct snd_soc_tplg_enum_control { +	struct snd_soc_tplg_ctl_hdr hdr; +	__le32 size;	/* in bytes of this structure */ +	__le32 num_channels; +	struct snd_soc_tplg_channel channel[SND_SOC_TPLG_MAX_CHAN]; +	__le32 items; +	__le32 mask; +	__le32 count; +	char texts[SND_SOC_TPLG_NUM_TEXTS][SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	__le32 values[SND_SOC_TPLG_NUM_TEXTS * SNDRV_CTL_ELEM_ID_NAME_MAXLEN / 4]; +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); + +/* + * Bytes kcontrol + * + * File block representation for bytes kcontrol :- + * +-----------------------------------+----+ + * | struct snd_soc_tplg_hdr           |  1 | + * +-----------------------------------+----+ + * | struct snd_soc_tplg_bytes_control |  N | + * +-----------------------------------+----+ + */ +struct snd_soc_tplg_bytes_control { +	struct snd_soc_tplg_ctl_hdr hdr; +	__le32 size;	/* in bytes of this structure */ +	__le32 max; +	__le32 mask; +	__le32 base; +	__le32 num_regs; +	struct snd_soc_tplg_io_ops ext_ops; +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); + +/* + * DAPM Graph Element + * + * File block representation for DAPM graph elements :- + * +-------------------------------------+----+ + * | struct snd_soc_tplg_hdr             |  1 | + * +-------------------------------------+----+ + * | struct snd_soc_tplg_dapm_graph_elem |  N | + * +-------------------------------------+----+ + */ +struct snd_soc_tplg_dapm_graph_elem { +	char sink[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	char control[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	char source[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +} __attribute__((packed)); + +/* + * DAPM Widget. + * + * File block representation for DAPM widget :- + * +-------------------------------------+-----+ + * | struct snd_soc_tplg_hdr             |  1  | + * +-------------------------------------+-----+ + * | struct snd_soc_tplg_dapm_widget     |  N  | + * +-------------------------------------+-----+ + * |   struct snd_soc_tplg_enum_control  | 0|1 | + * |   struct snd_soc_tplg_mixer_control | 0|N | + * +-------------------------------------+-----+ + * + * Optional enum or mixer control can be appended to the end of each widget + * in the block. + */ +struct snd_soc_tplg_dapm_widget { +	__le32 size;		/* in bytes of this structure */ +	__le32 id;		/* SND_SOC_DAPM_CTL */ +	char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	char sname[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; + +	__le32 reg;		/* negative reg = no direct dapm */ +	__le32 shift;		/* bits to shift */ +	__le32 mask;		/* non-shifted mask */ +	__le32 subseq;		/* sort within widget type */ +	__le32 invert;		/* invert the power bit */ +	__le32 ignore_suspend;	/* kept enabled over suspend */ +	__le16 event_flags; +	__le16 event_type; +	__le32 num_kcontrols; +	struct snd_soc_tplg_private priv; +	/* +	 * kcontrols that relate to this widget +	 * follow here after widget private data +	 */ +} __attribute__((packed)); + + +/* + * Describes SW/FW specific features of PCM (FE DAI & DAI link). + * + * File block representation for PCM :- + * +-----------------------------------+-----+ + * | struct snd_soc_tplg_hdr           |  1  | + * +-----------------------------------+-----+ + * | struct snd_soc_tplg_pcm           |  N  | + * +-----------------------------------+-----+ + */ +struct snd_soc_tplg_pcm { +	__le32 size;		/* in bytes of this structure */ +	char pcm_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	char dai_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; +	__le32 pcm_id;		/* unique ID - used to match with DAI link */ +	__le32 dai_id;		/* unique ID - used to match */ +	__le32 playback;	/* supports playback mode */ +	__le32 capture;		/* supports capture mode */ +	__le32 compress;	/* 1 = compressed; 0 = PCM */ +	struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; /* for DAI link */ +	__le32 num_streams;	/* number of streams */ +	struct snd_soc_tplg_stream_caps caps[2]; /* playback and capture for DAI */ +	__le32 flag_mask;       /* bitmask of flags to configure */ +	__le32 flags;           /* SND_SOC_TPLG_LNK_FLGBIT_* flag value */ +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); + + +/* + * Describes the physical link runtime supported configs or params + * + * File block representation for physical link config :- + * +-----------------------------------+-----+ + * | struct snd_soc_tplg_hdr           |  1  | + * +-----------------------------------+-----+ + * | struct snd_soc_tplg_link_config   |  N  | + * +-----------------------------------+-----+ + */ +struct snd_soc_tplg_link_config { +	__le32 size;            /* in bytes of this structure */ +	__le32 id;              /* unique ID - used to match */ +	char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; /* name - used to match */ +	char stream_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; /* stream name - used to match */ +	struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; /* supported configs playback and captrure */ +	__le32 num_streams;     /* number of streams */ +	struct snd_soc_tplg_hw_config hw_config[SND_SOC_TPLG_HW_CONFIG_MAX]; /* hw configs */ +	__le32 num_hw_configs;         /* number of hw configs */ +	__le32 default_hw_config_id;   /* default hw config ID for init */ +	__le32 flag_mask;       /* bitmask of flags to configure */ +	__le32 flags;           /* SND_SOC_TPLG_LNK_FLGBIT_* flag value */ +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); + +/* + * Describes SW/FW specific features of physical DAI. + * It can be used to configure backend DAIs for DPCM. + * + * File block representation for physical DAI :- + * +-----------------------------------+-----+ + * | struct snd_soc_tplg_hdr           |  1  | + * +-----------------------------------+-----+ + * | struct snd_soc_tplg_dai           |  N  | + * +-----------------------------------+-----+ + */ +struct snd_soc_tplg_dai { +	__le32 size;            /* in bytes of this structure */ +	char dai_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; /* name - used to match */ +	__le32 dai_id;          /* unique ID - used to match */ +	__le32 playback;        /* supports playback mode */ +	__le32 capture;         /* supports capture mode */ +	struct snd_soc_tplg_stream_caps caps[2]; /* playback and capture for DAI */ +	__le32 flag_mask;       /* bitmask of flags to configure */ +	__le32 flags;           /* SND_SOC_TPLG_DAI_FLGBIT_* */ +	struct snd_soc_tplg_private priv; +} __attribute__((packed)); +#endif diff --git a/include/alsa/sound/asound_fm.h b/include/alsa/sound/asound_fm.h new file mode 100644 index 0000000..c49bb4a --- /dev/null +++ b/include/alsa/sound/asound_fm.h @@ -0,0 +1,134 @@ +#ifndef __SOUND_ASOUND_FM_H +#define __SOUND_ASOUND_FM_H + +/* + *  Advanced Linux Sound Architecture - ALSA + * + *  Interface file between ALSA driver & user space + *  Copyright (c) 1994-98 by Jaroslav Kysela <perex@perex.cz>, + *                           4Front Technologies + * + *  Direct FM control + * + *   This program is free software; you can redistribute it and/or modify + *   it under the terms of the GNU General Public License as published by + *   the Free Software Foundation; either version 2 of the License, or + *   (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU General Public License for more details. + * + *   You should have received a copy of the GNU General Public License + *   along with this program; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#define SNDRV_DM_FM_MODE_OPL2	0x00 +#define SNDRV_DM_FM_MODE_OPL3	0x01 + +struct snd_dm_fm_info { +	unsigned char fm_mode;		/* OPL mode, see SNDRV_DM_FM_MODE_XXX */ +	unsigned char rhythm;		/* percussion mode flag */ +}; + +/* + *  Data structure composing an FM "note" or sound event. + */ + +struct snd_dm_fm_voice { +	unsigned char op;		/* operator cell (0 or 1) */ +	unsigned char voice;		/* FM voice (0 to 17) */ + +	unsigned char am;		/* amplitude modulation */ +	unsigned char vibrato;		/* vibrato effect */ +	unsigned char do_sustain;	/* sustain phase */ +	unsigned char kbd_scale;	/* keyboard scaling */ +	unsigned char harmonic;		/* 4 bits: harmonic and multiplier */ +	unsigned char scale_level;	/* 2 bits: decrease output freq rises */ +	unsigned char volume;		/* 6 bits: volume */ + +	unsigned char attack;		/* 4 bits: attack rate */ +	unsigned char decay;		/* 4 bits: decay rate */ +	unsigned char sustain;		/* 4 bits: sustain level */ +	unsigned char release;		/* 4 bits: release rate */ + +	unsigned char feedback;		/* 3 bits: feedback for op0 */ +	unsigned char connection;	/* 0 for serial, 1 for parallel */ +	unsigned char left;		/* stereo left */ +	unsigned char right;		/* stereo right */ +	unsigned char waveform;		/* 3 bits: waveform shape */ +}; + +/* + *  This describes an FM note by its voice, octave, frequency number (10bit) + *  and key on/off. + */ + +struct snd_dm_fm_note { +	unsigned char voice;	/* 0-17 voice channel */ +	unsigned char octave;	/* 3 bits: what octave to play */ +	unsigned int fnum;	/* 10 bits: frequency number */ +	unsigned char key_on;	/* set for active, clear for silent */ +}; + +/* + *  FM parameters that apply globally to all voices, and thus are not "notes" + */ + +struct snd_dm_fm_params { +	unsigned char am_depth;		/* amplitude modulation depth (1=hi) */ +	unsigned char vib_depth;	/* vibrato depth (1=hi) */ +	unsigned char kbd_split;	/* keyboard split */ +	unsigned char rhythm;		/* percussion mode select */ + +	/* This block is the percussion instrument data */ +	unsigned char bass; +	unsigned char snare; +	unsigned char tomtom; +	unsigned char cymbal; +	unsigned char hihat; +}; + +/* + *  FM mode ioctl settings + */ + +#define SNDRV_DM_FM_IOCTL_INFO		_IOR('H', 0x20, struct snd_dm_fm_info) +#define SNDRV_DM_FM_IOCTL_RESET		_IO ('H', 0x21) +#define SNDRV_DM_FM_IOCTL_PLAY_NOTE	_IOW('H', 0x22, struct snd_dm_fm_note) +#define SNDRV_DM_FM_IOCTL_SET_VOICE	_IOW('H', 0x23, struct snd_dm_fm_voice) +#define SNDRV_DM_FM_IOCTL_SET_PARAMS	_IOW('H', 0x24, struct snd_dm_fm_params) +#define SNDRV_DM_FM_IOCTL_SET_MODE	_IOW('H', 0x25, int) +/* for OPL3 only */ +#define SNDRV_DM_FM_IOCTL_SET_CONNECTION	_IOW('H', 0x26, int) +/* SBI patch management */ +#define SNDRV_DM_FM_IOCTL_CLEAR_PATCHES	_IO ('H', 0x40) + +#define SNDRV_DM_FM_OSS_IOCTL_RESET		0x20 +#define SNDRV_DM_FM_OSS_IOCTL_PLAY_NOTE		0x21 +#define SNDRV_DM_FM_OSS_IOCTL_SET_VOICE		0x22 +#define SNDRV_DM_FM_OSS_IOCTL_SET_PARAMS	0x23 +#define SNDRV_DM_FM_OSS_IOCTL_SET_MODE		0x24 +#define SNDRV_DM_FM_OSS_IOCTL_SET_OPL		0x25 + +/* + * Patch Record - fixed size for write + */ + +#define FM_KEY_SBI	"SBI\032" +#define FM_KEY_2OP	"2OP\032" +#define FM_KEY_4OP	"4OP\032" + +struct sbi_patch { +	unsigned char prog; +	unsigned char bank; +	char key[4]; +	char name[25]; +	char extension[7]; +	unsigned char data[32]; +}; + +#endif /* __SOUND_ASOUND_FM_H */ diff --git a/include/alsa/sound/emu10k1.h b/include/alsa/sound/emu10k1.h new file mode 100644 index 0000000..ff2113a --- /dev/null +++ b/include/alsa/sound/emu10k1.h @@ -0,0 +1,349 @@ +#ifndef __SOUND_EMU10K1_H +#define __SOUND_EMU10K1_H + +/* + *  Copyright (c) by Jaroslav Kysela <perex@perex.cz>, + *		     Creative Labs, Inc. + *  Definitions for EMU10K1 (SB Live!) chips + * + * + *   This program is free software; you can redistribute it and/or modify + *   it under the terms of the GNU General Public License as published by + *   the Free Software Foundation; either version 2 of the License, or + *   (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU General Public License for more details. + * + *   You should have received a copy of the GNU General Public License + *   along with this program; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#include <stdint.h> + +/* + * ---- FX8010 ---- + */ + +#define EMU10K1_CARD_CREATIVE			0x00000000 +#define EMU10K1_CARD_EMUAPS			0x00000001 + +#define EMU10K1_FX8010_PCM_COUNT		8 + +/* instruction set */ +#define iMAC0	 0x00	/* R = A + (X * Y >> 31)   ; saturation */ +#define iMAC1	 0x01	/* R = A + (-X * Y >> 31)  ; saturation */ +#define iMAC2	 0x02	/* R = A + (X * Y >> 31)   ; wraparound */ +#define iMAC3	 0x03	/* R = A + (-X * Y >> 31)  ; wraparound */ +#define iMACINT0 0x04	/* R = A + X * Y	   ; saturation */ +#define iMACINT1 0x05	/* R = A + X * Y	   ; wraparound (31-bit) */ +#define iACC3	 0x06	/* R = A + X + Y	   ; saturation */ +#define iMACMV   0x07	/* R = A, acc += X * Y >> 31 */ +#define iANDXOR  0x08	/* R = (A & X) ^ Y */ +#define iTSTNEG  0x09	/* R = (A >= Y) ? X : ~X */ +#define iLIMITGE 0x0a	/* R = (A >= Y) ? X : Y */ +#define iLIMITLT 0x0b	/* R = (A < Y) ? X : Y */ +#define iLOG	 0x0c	/* R = linear_data, A (log_data), X (max_exp), Y (format_word) */ +#define iEXP	 0x0d	/* R = log_data, A (linear_data), X (max_exp), Y (format_word) */ +#define iINTERP  0x0e	/* R = A + (X * (Y - A) >> 31)  ; saturation */ +#define iSKIP    0x0f	/* R = A (cc_reg), X (count), Y (cc_test) */ + +/* GPRs */ +#define FXBUS(x)	(0x00 + (x))	/* x = 0x00 - 0x0f */ +#define EXTIN(x)	(0x10 + (x))	/* x = 0x00 - 0x0f */ +#define EXTOUT(x)	(0x20 + (x))	/* x = 0x00 - 0x0f */ +#define C_00000000	0x40 +#define C_00000001	0x41 +#define C_00000002	0x42 +#define C_00000003	0x43 +#define C_00000004	0x44 +#define C_00000008	0x45 +#define C_00000010	0x46 +#define C_00000020	0x47 +#define C_00000100	0x48 +#define C_00010000	0x49 +#define C_00080000	0x4a +#define C_10000000	0x4b +#define C_20000000	0x4c +#define C_40000000	0x4d +#define C_80000000	0x4e +#define C_7fffffff	0x4f +#define C_ffffffff	0x50 +#define C_fffffffe	0x51 +#define C_c0000000	0x52 +#define C_4f1bbcdc	0x53 +#define C_5a7ef9db	0x54 +#define C_00100000	0x55		/* ?? */ +#define GPR_ACCU	0x56		/* ACCUM, accumulator */ +#define GPR_COND	0x57		/* CCR, condition register */ +#define GPR_NOISE0	0x58		/* noise source */ +#define GPR_NOISE1	0x59		/* noise source */ +#define GPR_IRQ		0x5a		/* IRQ register */ +#define GPR_DBAC	0x5b		/* TRAM Delay Base Address Counter */ +#define GPR(x)		(FXGPREGBASE + (x)) /* free GPRs: x = 0x00 - 0xff */ +#define ITRAM_DATA(x)	(TANKMEMDATAREGBASE + 0x00 + (x)) /* x = 0x00 - 0x7f */ +#define ETRAM_DATA(x)	(TANKMEMDATAREGBASE + 0x80 + (x)) /* x = 0x00 - 0x1f */ +#define ITRAM_ADDR(x)	(TANKMEMADDRREGBASE + 0x00 + (x)) /* x = 0x00 - 0x7f */ +#define ETRAM_ADDR(x)	(TANKMEMADDRREGBASE + 0x80 + (x)) /* x = 0x00 - 0x1f */ + +#define A_FXBUS(x)	(0x00 + (x))	/* x = 0x00 - 0x3f? */ +#define A_EXTIN(x)	(0x40 + (x))	/* x = 0x00 - 0x1f? */ +#define A_EXTOUT(x)	(0x60 + (x))	/* x = 0x00 - 0x1f? */ +#define A_GPR(x)	(A_FXGPREGBASE + (x)) + +/* cc_reg constants */ +#define CC_REG_NORMALIZED C_00000001 +#define CC_REG_BORROW	C_00000002 +#define CC_REG_MINUS	C_00000004 +#define CC_REG_ZERO	C_00000008 +#define CC_REG_SATURATE	C_00000010 +#define CC_REG_NONZERO	C_00000100 + +/* FX buses */ +#define FXBUS_PCM_LEFT		0x00 +#define FXBUS_PCM_RIGHT		0x01 +#define FXBUS_PCM_LEFT_REAR	0x02 +#define FXBUS_PCM_RIGHT_REAR	0x03 +#define FXBUS_MIDI_LEFT		0x04 +#define FXBUS_MIDI_RIGHT	0x05 +#define FXBUS_PCM_CENTER	0x06 +#define FXBUS_PCM_LFE		0x07 +#define FXBUS_PCM_LEFT_FRONT	0x08 +#define FXBUS_PCM_RIGHT_FRONT	0x09 +#define FXBUS_MIDI_REVERB	0x0c +#define FXBUS_MIDI_CHORUS	0x0d +#define FXBUS_PCM_LEFT_SIDE	0x0e +#define FXBUS_PCM_RIGHT_SIDE	0x0f +#define FXBUS_PT_LEFT		0x14 +#define FXBUS_PT_RIGHT		0x15 + +/* Inputs */ +#define EXTIN_AC97_L	   0x00	/* AC'97 capture channel - left */ +#define EXTIN_AC97_R	   0x01	/* AC'97 capture channel - right */ +#define EXTIN_SPDIF_CD_L   0x02	/* internal S/PDIF CD - onboard - left */ +#define EXTIN_SPDIF_CD_R   0x03	/* internal S/PDIF CD - onboard - right */ +#define EXTIN_ZOOM_L	   0x04	/* Zoom Video I2S - left */ +#define EXTIN_ZOOM_R	   0x05	/* Zoom Video I2S - right */ +#define EXTIN_TOSLINK_L	   0x06	/* LiveDrive - TOSLink Optical - left */ +#define EXTIN_TOSLINK_R    0x07	/* LiveDrive - TOSLink Optical - right */ +#define EXTIN_LINE1_L	   0x08	/* LiveDrive - Line/Mic 1 - left */ +#define EXTIN_LINE1_R	   0x09	/* LiveDrive - Line/Mic 1 - right */ +#define EXTIN_COAX_SPDIF_L 0x0a	/* LiveDrive - Coaxial S/PDIF - left */ +#define EXTIN_COAX_SPDIF_R 0x0b /* LiveDrive - Coaxial S/PDIF - right */ +#define EXTIN_LINE2_L	   0x0c	/* LiveDrive - Line/Mic 2 - left */ +#define EXTIN_LINE2_R	   0x0d	/* LiveDrive - Line/Mic 2 - right */ + +/* Outputs */ +#define EXTOUT_AC97_L	   0x00	/* AC'97 playback channel - left */ +#define EXTOUT_AC97_R	   0x01	/* AC'97 playback channel - right */ +#define EXTOUT_TOSLINK_L   0x02	/* LiveDrive - TOSLink Optical - left */ +#define EXTOUT_TOSLINK_R   0x03	/* LiveDrive - TOSLink Optical - right */ +#define EXTOUT_AC97_CENTER 0x04	/* SB Live 5.1 - center */ +#define EXTOUT_AC97_LFE	   0x05 /* SB Live 5.1 - LFE */ +#define EXTOUT_HEADPHONE_L 0x06	/* LiveDrive - Headphone - left */ +#define EXTOUT_HEADPHONE_R 0x07	/* LiveDrive - Headphone - right */ +#define EXTOUT_REAR_L	   0x08	/* Rear channel - left */ +#define EXTOUT_REAR_R	   0x09	/* Rear channel - right */ +#define EXTOUT_ADC_CAP_L   0x0a	/* ADC Capture buffer - left */ +#define EXTOUT_ADC_CAP_R   0x0b	/* ADC Capture buffer - right */ +#define EXTOUT_MIC_CAP	   0x0c	/* MIC Capture buffer */ +#define EXTOUT_AC97_REAR_L 0x0d	/* SB Live 5.1 (c) 2003 - Rear Left */ +#define EXTOUT_AC97_REAR_R 0x0e	/* SB Live 5.1 (c) 2003 - Rear Right */ +#define EXTOUT_ACENTER	   0x11 /* Analog Center */ +#define EXTOUT_ALFE	   0x12 /* Analog LFE */ + +/* Audigy Inputs */ +#define A_EXTIN_AC97_L		0x00	/* AC'97 capture channel - left */ +#define A_EXTIN_AC97_R		0x01	/* AC'97 capture channel - right */ +#define A_EXTIN_SPDIF_CD_L	0x02	/* digital CD left */ +#define A_EXTIN_SPDIF_CD_R	0x03	/* digital CD left */ +#define A_EXTIN_OPT_SPDIF_L     0x04    /* audigy drive Optical SPDIF - left */ +#define A_EXTIN_OPT_SPDIF_R     0x05    /*                              right */  +#define A_EXTIN_LINE2_L		0x08	/* audigy drive line2/mic2 - left */ +#define A_EXTIN_LINE2_R		0x09	/*                           right */ +#define A_EXTIN_ADC_L		0x0a    /* Philips ADC - left */ +#define A_EXTIN_ADC_R		0x0b    /*               right */ +#define A_EXTIN_AUX2_L		0x0c	/* audigy drive aux2 - left */ +#define A_EXTIN_AUX2_R		0x0d	/*                   - right */ + +/* Audigiy Outputs */ +#define A_EXTOUT_FRONT_L	0x00	/* digital front left */ +#define A_EXTOUT_FRONT_R	0x01	/*               right */ +#define A_EXTOUT_CENTER		0x02	/* digital front center */ +#define A_EXTOUT_LFE		0x03	/* digital front lfe */ +#define A_EXTOUT_HEADPHONE_L	0x04	/* headphone audigy drive left */ +#define A_EXTOUT_HEADPHONE_R	0x05	/*                        right */ +#define A_EXTOUT_REAR_L		0x06	/* digital rear left */ +#define A_EXTOUT_REAR_R		0x07	/*              right */ +#define A_EXTOUT_AFRONT_L	0x08	/* analog front left */ +#define A_EXTOUT_AFRONT_R	0x09	/*              right */ +#define A_EXTOUT_ACENTER	0x0a	/* analog center */ +#define A_EXTOUT_ALFE		0x0b	/* analog LFE */ +#define A_EXTOUT_ASIDE_L	0x0c	/* analog side left  - Audigy 2 ZS */ +#define A_EXTOUT_ASIDE_R	0x0d	/*             right - Audigy 2 ZS */ +#define A_EXTOUT_AREAR_L	0x0e	/* analog rear left */ +#define A_EXTOUT_AREAR_R	0x0f	/*             right */ +#define A_EXTOUT_AC97_L		0x10	/* AC97 left (front) */ +#define A_EXTOUT_AC97_R		0x11	/*      right */ +#define A_EXTOUT_ADC_CAP_L	0x16	/* ADC capture buffer left */ +#define A_EXTOUT_ADC_CAP_R	0x17	/*                    right */ +#define A_EXTOUT_MIC_CAP	0x18	/* Mic capture buffer */ + +/* Audigy constants */ +#define A_C_00000000	0xc0 +#define A_C_00000001	0xc1 +#define A_C_00000002	0xc2 +#define A_C_00000003	0xc3 +#define A_C_00000004	0xc4 +#define A_C_00000008	0xc5 +#define A_C_00000010	0xc6 +#define A_C_00000020	0xc7 +#define A_C_00000100	0xc8 +#define A_C_00010000	0xc9 +#define A_C_00000800	0xca +#define A_C_10000000	0xcb +#define A_C_20000000	0xcc +#define A_C_40000000	0xcd +#define A_C_80000000	0xce +#define A_C_7fffffff	0xcf +#define A_C_ffffffff	0xd0 +#define A_C_fffffffe	0xd1 +#define A_C_c0000000	0xd2 +#define A_C_4f1bbcdc	0xd3 +#define A_C_5a7ef9db	0xd4 +#define A_C_00100000	0xd5 +#define A_GPR_ACCU	0xd6		/* ACCUM, accumulator */ +#define A_GPR_COND	0xd7		/* CCR, condition register */ +#define A_GPR_NOISE0	0xd8		/* noise source */ +#define A_GPR_NOISE1	0xd9		/* noise source */ +#define A_GPR_IRQ	0xda		/* IRQ register */ +#define A_GPR_DBAC	0xdb		/* TRAM Delay Base Address Counter - internal */ +#define A_GPR_DBACE	0xde		/* TRAM Delay Base Address Counter - external */ + +/* definitions for debug register */ +#define EMU10K1_DBG_ZC			0x80000000	/* zero tram counter */ +#define EMU10K1_DBG_SATURATION_OCCURED	0x02000000	/* saturation control */ +#define EMU10K1_DBG_SATURATION_ADDR	0x01ff0000	/* saturation address */ +#define EMU10K1_DBG_SINGLE_STEP		0x00008000	/* single step mode */ +#define EMU10K1_DBG_STEP		0x00004000	/* start single step */ +#define EMU10K1_DBG_CONDITION_CODE	0x00003e00	/* condition code */ +#define EMU10K1_DBG_SINGLE_STEP_ADDR	0x000001ff	/* single step address */ + +/* tank memory address line */ +#ifndef __KERNEL__ +#define TANKMEMADDRREG_ADDR_MASK 0x000fffff	/* 20 bit tank address field			*/ +#define TANKMEMADDRREG_CLEAR	 0x00800000	/* Clear tank memory				*/ +#define TANKMEMADDRREG_ALIGN	 0x00400000	/* Align read or write relative to tank access	*/ +#define TANKMEMADDRREG_WRITE	 0x00200000	/* Write to tank memory				*/ +#define TANKMEMADDRREG_READ	 0x00100000	/* Read from tank memory			*/ +#endif + +typedef struct { +	unsigned int internal_tram_size;	/* in samples */ +	unsigned int external_tram_size;	/* in samples */ +	char fxbus_names[16][32];		/* names of FXBUSes */ +	char extin_names[16][32];		/* names of external inputs */ +	char extout_names[32][32];		/* names of external outputs */ +	unsigned int gpr_controls;		/* count of GPR controls */ +} emu10k1_fx8010_info_t; + +#define EMU10K1_GPR_TRANSLATION_NONE		0 +#define EMU10K1_GPR_TRANSLATION_TABLE100	1 +#define EMU10K1_GPR_TRANSLATION_BASS		2 +#define EMU10K1_GPR_TRANSLATION_TREBLE		3 +#define EMU10K1_GPR_TRANSLATION_ONOFF		4 + +enum emu10k1_ctl_elem_iface { +	EMU10K1_CTL_ELEM_IFACE_MIXER = 2,	/* virtual mixer device */ +	EMU10K1_CTL_ELEM_IFACE_PCM = 3,		/* PCM device */ +}; + +typedef struct { +	unsigned int pad;		/* don't use */ +	int iface;			/* interface identifier */ +	unsigned int device;		/* device/client number */ +	unsigned int subdevice;		/* subdevice (substream) number */ +	unsigned char name[44];		/* ASCII name of item */  +	unsigned int index;		/* index of item */ +} emu10k1_ctl_elem_id_t; + +typedef struct { +	emu10k1_ctl_elem_id_t id;	/* full control ID definition */ +	unsigned int vcount;		/* visible count */ +	unsigned int count;		/* count of GPR (1..16) */ +	unsigned short gpr[32];		/* GPR number(s) */ +	unsigned int value[32];		/* initial values */ +	unsigned int min;		/* minimum range */ +	unsigned int max;		/* maximum range */ +	unsigned int translation;	/* translation type (EMU10K1_GPR_TRANSLATION*) */ +	unsigned int *tlv; +} emu10k1_fx8010_control_gpr_t; + +typedef struct { +	char name[128]; + +	unsigned long gpr_valid[0x200/(sizeof(unsigned long)*8)]; /* bitmask of valid initializers */ +	uint32_t *gpr_map;		  /* initializers */ + +	unsigned int gpr_add_control_count; /* count of GPR controls to add/replace */ +	emu10k1_fx8010_control_gpr_t *gpr_add_controls; /* GPR controls to add/replace */ + +	unsigned int gpr_del_control_count; /* count of GPR controls to remove */ +	emu10k1_ctl_elem_id_t *gpr_del_controls; /* IDs of GPR controls to remove */ + +	unsigned int gpr_list_control_count; /* count of GPR controls to list */ +	unsigned int gpr_list_control_total; /* total count of GPR controls */ +	emu10k1_fx8010_control_gpr_t *gpr_list_controls; /* listed GPR controls */ + +	unsigned long tram_valid[0x100/(sizeof(unsigned long)*8)]; /* bitmask of valid initializers */ +	uint32_t *tram_data_map;	/* data initializers */ +	uint32_t *tram_addr_map;	/* map initializers */ + +	unsigned long code_valid[1024/(sizeof(unsigned long)*8)];  /* bitmask of valid instructions */ +	uint32_t *code;			/* one instruction - 64 bits */ +} emu10k1_fx8010_code_t; + +typedef struct { +	unsigned int address;		/* 31.bit == 1 -> external TRAM */ +	unsigned int size;		/* size in samples (4 bytes) */ +	unsigned int *samples;		/* pointer to samples (20-bit) */ +					/* NULL->clear memory */ +} emu10k1_fx8010_tram_t; + +typedef struct { +	unsigned int substream;		/* substream number */ +	unsigned int res1;		/* reserved */ +	unsigned int channels;		/* 16-bit channels count, zero = remove this substream */ +	unsigned int tram_start;	/* ring buffer position in TRAM (in samples) */ +	unsigned int buffer_size;	/* count of buffered samples */ +	unsigned short gpr_size;		/* GPR containing size of ringbuffer in samples (host) */ +	unsigned short gpr_ptr;		/* GPR containing current pointer in the ring buffer (host = reset, FX8010) */ +	unsigned short gpr_count;	/* GPR containing count of samples between two interrupts (host) */ +	unsigned short gpr_tmpcount;	/* GPR containing current count of samples to interrupt (host = set, FX8010) */ +	unsigned short gpr_trigger;	/* GPR containing trigger (activate) information (host) */ +	unsigned short gpr_running;	/* GPR containing info if PCM is running (FX8010) */ +	unsigned char pad;		/* reserved */ +	unsigned char etram[32];	/* external TRAM address & data (one per channel) */ +	unsigned int res2;		/* reserved */ +} emu10k1_fx8010_pcm_t; + +#define SNDRV_EMU10K1_IOCTL_INFO	_IOR ('H', 0x10, emu10k1_fx8010_info_t) +#define SNDRV_EMU10K1_IOCTL_CODE_POKE	_IOW ('H', 0x11, emu10k1_fx8010_code_t) +#define SNDRV_EMU10K1_IOCTL_CODE_PEEK	_IOWR('H', 0x12, emu10k1_fx8010_code_t) +#define SNDRV_EMU10K1_IOCTL_TRAM_SETUP	_IOW ('H', 0x20, int) +#define SNDRV_EMU10K1_IOCTL_TRAM_POKE	_IOW ('H', 0x21, emu10k1_fx8010_tram_t) +#define SNDRV_EMU10K1_IOCTL_TRAM_PEEK	_IOWR('H', 0x22, emu10k1_fx8010_tram_t) +#define SNDRV_EMU10K1_IOCTL_PCM_POKE	_IOW ('H', 0x30, emu10k1_fx8010_pcm_t) +#define SNDRV_EMU10K1_IOCTL_PCM_PEEK	_IOWR('H', 0x31, emu10k1_fx8010_pcm_t) +#define SNDRV_EMU10K1_IOCTL_PVERSION	_IOR ('H', 0x40, int) +#define SNDRV_EMU10K1_IOCTL_STOP	_IO  ('H', 0x80) +#define SNDRV_EMU10K1_IOCTL_CONTINUE	_IO  ('H', 0x81) +#define SNDRV_EMU10K1_IOCTL_ZERO_TRAM_COUNTER _IO ('H', 0x82) +#define SNDRV_EMU10K1_IOCTL_SINGLE_STEP	_IOW ('H', 0x83, int) +#define SNDRV_EMU10K1_IOCTL_DBG_READ	_IOR ('H', 0x84, int) + +#endif	/* __SOUND_EMU10K1_H */ diff --git a/include/alsa/sound/hdsp.h b/include/alsa/sound/hdsp.h new file mode 100644 index 0000000..5adaf7b --- /dev/null +++ b/include/alsa/sound/hdsp.h @@ -0,0 +1,113 @@ +#ifndef __SOUND_HDSP_H +#define __SOUND_HDSP_H + +/* + *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org) + *     + *   This program is free software; you can redistribute it and/or modify + *   it under the terms of the GNU General Public License as published by + *   the Free Software Foundation; either version 2 of the License, or + *   (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU General Public License for more details. + * + *   You should have received a copy of the GNU General Public License + *   along with this program; if not, write to the Free Software + *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +#include <stdint.h> + +#define HDSP_MATRIX_MIXER_SIZE 2048 + +typedef enum { +	Digiface, +	Multiface, +	H9652, +	H9632, +	RPM, +	Undefined, +} HDSP_IO_Type; + +typedef struct _snd_hdsp_peak_rms hdsp_peak_rms_t; + +struct _snd_hdsp_peak_rms { +	uint32_t input_peaks[26]; +	uint32_t playback_peaks[26]; +	uint32_t output_peaks[28]; +	uint64_t input_rms[26]; +	uint64_t playback_rms[26]; +	/* These are only used for H96xx cards */ +	uint64_t output_rms[26]; +}; + +#define SNDRV_HDSP_IOCTL_GET_PEAK_RMS _IOR('H', 0x40, hdsp_peak_rms_t) + +typedef struct _snd_hdsp_config_info hdsp_config_info_t; + +struct _snd_hdsp_config_info { +	unsigned char pref_sync_ref; +	unsigned char wordclock_sync_check; +	unsigned char spdif_sync_check; +	unsigned char adatsync_sync_check; +	unsigned char adat_sync_check[3]; +	unsigned char spdif_in; +	unsigned char spdif_out; +	unsigned char spdif_professional; +	unsigned char spdif_emphasis; +	unsigned char spdif_nonaudio; +	unsigned int spdif_sample_rate; +	unsigned int system_sample_rate; +	unsigned int autosync_sample_rate; +	unsigned char system_clock_mode; +	unsigned char clock_source; +	unsigned char autosync_ref; +	unsigned char line_out; +	unsigned char passthru;  +	unsigned char da_gain; +	unsigned char ad_gain; +	unsigned char phone_gain; +	unsigned char xlr_breakout_cable; +	unsigned char analog_extension_board; +}; + +#define SNDRV_HDSP_IOCTL_GET_CONFIG_INFO _IOR('H', 0x41, hdsp_config_info_t) + +typedef struct _snd_hdsp_firmware hdsp_firmware_t; + +struct _snd_hdsp_firmware { +	void *firmware_data;	/* 24413 x 4 bytes */ +}; + +#define SNDRV_HDSP_IOCTL_UPLOAD_FIRMWARE _IOW('H', 0x42, hdsp_firmware_t) + +typedef struct _snd_hdsp_version hdsp_version_t; + +struct _snd_hdsp_version { +	HDSP_IO_Type io_type; +	unsigned short firmware_rev; +}; + +#define SNDRV_HDSP_IOCTL_GET_VERSION _IOR('H', 0x43, hdsp_version_t) + +typedef struct _snd_hdsp_mixer hdsp_mixer_t; + +struct _snd_hdsp_mixer { +	unsigned short matrix[HDSP_MATRIX_MIXER_SIZE]; +}; + +#define SNDRV_HDSP_IOCTL_GET_MIXER _IOR('H', 0x44, hdsp_mixer_t) + +typedef struct _snd_hdsp_9632_aeb hdsp_9632_aeb_t; + +struct _snd_hdsp_9632_aeb { +	int aebi; +	int aebo; +}; + +#define SNDRV_HDSP_IOCTL_GET_9632_AEB _IOR('H', 0x45, hdsp_9632_aeb_t) + +#endif /* __SOUND_HDSP_H */ diff --git a/include/alsa/sound/hdspm.h b/include/alsa/sound/hdspm.h new file mode 100644 index 0000000..fe9c5f6 --- /dev/null +++ b/include/alsa/sound/hdspm.h @@ -0,0 +1,229 @@ +#ifndef __SOUND_HDSPM_H +#define __SOUND_HDSPM_H +/* + *   Copyright (C) 2003 Winfried Ritsch (IEM) + *   based on hdsp.h from Thomas Charbonnel (thomas@undata.org) + * + * + *   This program is free software; you can redistribute it and/or modify + *   it under the terms of the GNU General Public License as published by + *   the Free Software Foundation; either version 2 of the License, or + *   (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU General Public License for more details. + * + *   You should have received a copy of the GNU General Public License + *   along with this program; if not, write to the Free Software + *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +/* Maximum channels is 64 even on 56Mode you have 64playbacks to matrix */ +#define HDSPM_MAX_CHANNELS      64 + +enum hdspm_io_type { +	MADI, +	MADIface, +	AIO, +	AES32, +	RayDAT +}; + +enum hdspm_speed { +	ss, +	ds, +	qs +}; + +/* -------------------- IOCTL Peak/RMS Meters -------------------- */ + +struct hdspm_peak_rms { +	uint32_t input_peaks[64]; +	uint32_t playback_peaks[64]; +	uint32_t output_peaks[64]; + +	uint64_t input_rms[64]; +	uint64_t playback_rms[64]; +	uint64_t output_rms[64]; + +	uint8_t speed; /* enum {ss, ds, qs} */ +	int status2; +}; + +#define SNDRV_HDSPM_IOCTL_GET_PEAK_RMS \ +	_IOR('H', 0x42, struct hdspm_peak_rms) + +/* ------------ CONFIG block IOCTL ---------------------- */ + +struct hdspm_config { +	unsigned char pref_sync_ref; +	unsigned char wordclock_sync_check; +	unsigned char madi_sync_check; +	unsigned int system_sample_rate; +	unsigned int autosync_sample_rate; +	unsigned char system_clock_mode; +	unsigned char clock_source; +	unsigned char autosync_ref; +	unsigned char line_out; +	unsigned int passthru; +	unsigned int analog_out; +}; + +#define SNDRV_HDSPM_IOCTL_GET_CONFIG \ +	_IOR('H', 0x41, struct hdspm_config) + +/** + * If there's a TCO (TimeCode Option) board installed, + * there are further options and status data available. + * The hdspm_ltc structure contains the current SMPTE + * timecode and some status information and can be + * obtained via SNDRV_HDSPM_IOCTL_GET_LTC or in the + * hdspm_status struct. + **/ + +enum hdspm_ltc_format { +	format_invalid, +	fps_24, +	fps_25, +	fps_2997, +	fps_30 +}; + +enum hdspm_ltc_frame { +	frame_invalid, +	drop_frame, +	full_frame +}; + +enum hdspm_ltc_input_format { +	ntsc, +	pal, +	no_video +}; + +struct hdspm_ltc { +	unsigned int ltc; + +	enum hdspm_ltc_format format; +	enum hdspm_ltc_frame frame; +	enum hdspm_ltc_input_format input_format; +}; + +#define SNDRV_HDSPM_IOCTL_GET_LTC _IOR('H', 0x46, struct hdspm_ltc) + +/** + * The status data reflects the device's current state + * as determined by the card's configuration and + * connection status. + **/ + +enum hdspm_sync { +	hdspm_sync_no_lock = 0, +	hdspm_sync_lock = 1, +	hdspm_sync_sync = 2 +}; + +enum hdspm_madi_input { +	hdspm_input_optical = 0, +	hdspm_input_coax = 1 +}; + +enum hdspm_madi_channel_format { +	hdspm_format_ch_64 = 0, +	hdspm_format_ch_56 = 1 +}; + +enum hdspm_madi_frame_format { +	hdspm_frame_48 = 0, +	hdspm_frame_96 = 1 +}; + +enum hdspm_syncsource { +	syncsource_wc = 0, +	syncsource_madi = 1, +	syncsource_tco = 2, +	syncsource_sync = 3, +	syncsource_none = 4 +}; + +struct hdspm_status { +	uint8_t card_type; /* enum hdspm_io_type */ +	enum hdspm_syncsource autosync_source; + +	uint64_t card_clock; +	uint32_t master_period; + +	union { +		struct { +			uint8_t sync_wc; /* enum hdspm_sync */ +			uint8_t sync_madi; /* enum hdspm_sync */ +			uint8_t sync_tco; /* enum hdspm_sync */ +			uint8_t sync_in; /* enum hdspm_sync */ +			uint8_t madi_input; /* enum hdspm_madi_input */ +			uint8_t channel_format; /* enum hdspm_madi_channel_format */ +			uint8_t frame_format; /* enum hdspm_madi_frame_format */ +		} madi; +	} card_specific; +}; + +#define SNDRV_HDSPM_IOCTL_GET_STATUS \ +	_IOR('H', 0x47, struct hdspm_status) + +/** + * Get information about the card and its add-ons. + **/ + +#define HDSPM_ADDON_TCO 1 + +struct hdspm_version { +	uint8_t card_type; /* enum hdspm_io_type */ +	char cardname[20]; +	unsigned int serial; +	unsigned short firmware_rev; +	int addons; +}; + +#define SNDRV_HDSPM_IOCTL_GET_VERSION _IOR('H', 0x48, struct hdspm_version) + +/* ------------- get Matrix Mixer IOCTL --------------- */ + +/* MADI mixer: 64inputs+64playback in 64outputs = 8192 => *4Byte = + * 32768 Bytes + */ + +/* organisation is 64 channelfader in a continous memory block */ +/* equivalent to hardware definition, maybe for future feature of mmap of + * them + */ +/* each of 64 outputs has 64 infader and 64 outfader: +   Ins to Outs mixer[out].in[in], Outstreams to Outs mixer[out].pb[pb] */ + +#define HDSPM_MIXER_CHANNELS HDSPM_MAX_CHANNELS + +struct hdspm_channelfader { +	unsigned int in[HDSPM_MIXER_CHANNELS]; +	unsigned int pb[HDSPM_MIXER_CHANNELS]; +}; + +struct hdspm_mixer { +	struct hdspm_channelfader ch[HDSPM_MIXER_CHANNELS]; +}; + +struct hdspm_mixer_ioctl { +	struct hdspm_mixer *mixer; +}; + +/* use indirect access due to the limit of ioctl bit size */ +#define SNDRV_HDSPM_IOCTL_GET_MIXER _IOR('H', 0x44, struct hdspm_mixer_ioctl) + +/* typedefs for compatibility to user-space */ +typedef struct hdspm_peak_rms hdspm_peak_rms_t; +typedef struct hdspm_config_info hdspm_config_info_t; +typedef struct hdspm_version hdspm_version_t; +typedef struct hdspm_channelfader snd_hdspm_channelfader_t; +typedef struct hdspm_mixer hdspm_mixer_t; + + +#endif diff --git a/include/alsa/sound/sb16_csp.h b/include/alsa/sound/sb16_csp.h new file mode 100644 index 0000000..68c9b11 --- /dev/null +++ b/include/alsa/sound/sb16_csp.h @@ -0,0 +1,115 @@ +#ifndef __SOUND_SB16_CSP_H +#define __SOUND_SB16_CSP_H + +/* + *  Copyright (c) 1999 by Uros Bizjak <uros@kss-loka.si> + *                        Takashi Iwai <tiwai@suse.de> + * + *  SB16ASP/AWE32 CSP control + * + *   This program is free software; you can redistribute it and/or modify  + *   it under the terms of the GNU General Public License as published by + *   the Free Software Foundation; either version 2 of the License, or + *   (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU General Public License for more details. + * + *   You should have received a copy of the GNU General Public License + *   along with this program; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +/* CSP modes */ +#define SNDRV_SB_CSP_MODE_NONE		0x00 +#define SNDRV_SB_CSP_MODE_DSP_READ	0x01	/* Record from DSP */ +#define SNDRV_SB_CSP_MODE_DSP_WRITE	0x02	/* Play to DSP */ +#define SNDRV_SB_CSP_MODE_QSOUND		0x04	/* QSound */ + +/* CSP load flags */ +#define SNDRV_SB_CSP_LOAD_FROMUSER	0x01 +#define SNDRV_SB_CSP_LOAD_INITBLOCK	0x02 + +/* CSP sample width */ +#define SNDRV_SB_CSP_SAMPLE_8BIT		0x01 +#define SNDRV_SB_CSP_SAMPLE_16BIT		0x02 + +/* CSP channels */ +#define SNDRV_SB_CSP_MONO			0x01 +#define SNDRV_SB_CSP_STEREO		0x02 + +/* CSP rates */ +#define SNDRV_SB_CSP_RATE_8000		0x01 +#define SNDRV_SB_CSP_RATE_11025		0x02 +#define SNDRV_SB_CSP_RATE_22050		0x04 +#define SNDRV_SB_CSP_RATE_44100		0x08 +#define SNDRV_SB_CSP_RATE_ALL		0x0f + +/* CSP running state */ +#define SNDRV_SB_CSP_ST_IDLE		0x00 +#define SNDRV_SB_CSP_ST_LOADED		0x01 +#define SNDRV_SB_CSP_ST_RUNNING		0x02 +#define SNDRV_SB_CSP_ST_PAUSED		0x04 +#define SNDRV_SB_CSP_ST_AUTO		0x08 +#define SNDRV_SB_CSP_ST_QSOUND		0x10 + +/* maximum QSound value (180 degrees right) */ +#define SNDRV_SB_CSP_QSOUND_MAX_RIGHT	0x20 + +/* maximum microcode RIFF file size */ +#define SNDRV_SB_CSP_MAX_MICROCODE_FILE_SIZE	0x3000 + +/* microcode header */ +typedef struct snd_sb_csp_mc_header { +	char codec_name[16];		/* id name of codec */ +	unsigned short func_req;	/* requested function */ +} snd_sb_csp_mc_header_t; + +/* microcode to be loaded */ +typedef struct snd_sb_csp_microcode { +	snd_sb_csp_mc_header_t info; +	unsigned char data[SNDRV_SB_CSP_MAX_MICROCODE_FILE_SIZE]; +} snd_sb_csp_microcode_t; + +/* start CSP with sample_width in mono/stereo */ +typedef struct snd_sb_csp_start { +	int sample_width;	/* sample width, look above */ +	int channels;		/* channels, look above */ +} snd_sb_csp_start_t; + +/* CSP information */ +typedef struct snd_sb_csp_info { +	char codec_name[16];		/* id name of codec */ +	unsigned short func_nr;		/* function number */ +	unsigned int acc_format;	/* accepted PCM formats */ +	unsigned short acc_channels;	/* accepted channels */ +	unsigned short acc_width;	/* accepted sample width */ +	unsigned short acc_rates;	/* accepted sample rates */ +	unsigned short csp_mode;	/* CSP mode, see above */ +	unsigned short run_channels;	/* current channels  */ +	unsigned short run_width;	/* current sample width */ +	unsigned short version;		/* version id: 0x10 - 0x1f */ +	unsigned short state;		/* state bits */ +} snd_sb_csp_info_t; + +/* HWDEP controls */ +/* get CSP information */ +#define SNDRV_SB_CSP_IOCTL_INFO		_IOR('H', 0x10, snd_sb_csp_info_t) +/* load microcode to CSP */ +#define SNDRV_SB_CSP_IOCTL_LOAD_CODE	_IOW('H', 0x11, snd_sb_csp_microcode_t) +/* unload microcode from CSP */ +#define SNDRV_SB_CSP_IOCTL_UNLOAD_CODE	_IO('H', 0x12) +/* start CSP */ +#define SNDRV_SB_CSP_IOCTL_START	_IOW('H', 0x13, snd_sb_csp_start_t) +/* stop CSP */ +#define SNDRV_SB_CSP_IOCTL_STOP		_IO('H', 0x14) +/* pause CSP and DMA transfer */ +#define SNDRV_SB_CSP_IOCTL_PAUSE	_IO('H', 0x15) +/* restart CSP and DMA transfer */ +#define SNDRV_SB_CSP_IOCTL_RESTART	_IO('H', 0x16) + + +#endif /* __SOUND_SB16_CSP */ diff --git a/include/alsa/sound/sscape_ioctl.h b/include/alsa/sound/sscape_ioctl.h new file mode 100644 index 0000000..c6653eb --- /dev/null +++ b/include/alsa/sound/sscape_ioctl.h @@ -0,0 +1,21 @@ +#ifndef SSCAPE_IOCTL_H +#define SSCAPE_IOCTL_H + + +struct sscape_bootblock +{ +  unsigned char code[256]; +  unsigned version; +}; + +#define SSCAPE_MICROCODE_SIZE  65536 + +struct sscape_microcode +{ +  unsigned char *code; +}; + +#define SND_SSCAPE_LOAD_BOOTB  _IOWR('P', 100, struct sscape_bootblock) +#define SND_SSCAPE_LOAD_MCODE  _IOW ('P', 101, struct sscape_microcode) + +#endif diff --git a/include/alsa/sound/tlv.h b/include/alsa/sound/tlv.h new file mode 100644 index 0000000..2ea4768 --- /dev/null +++ b/include/alsa/sound/tlv.h @@ -0,0 +1,116 @@ +/* + *   This program is free software; you can redistribute it and/or modify + *   it under the terms of the GNU General Public License as published by + *   the Free Software Foundation; either version 2 of the License, or + *   (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU General Public License for more details. + */ + +#ifndef __UAPI_SOUND_TLV_H +#define __UAPI_SOUND_TLV_H + +#define SNDRV_CTL_TLVT_CONTAINER 0	/* one level down - group of TLVs */ +#define SNDRV_CTL_TLVT_DB_SCALE	1       /* dB scale */ +#define SNDRV_CTL_TLVT_DB_LINEAR 2	/* linear volume */ +#define SNDRV_CTL_TLVT_DB_RANGE 3	/* dB range container */ +#define SNDRV_CTL_TLVT_DB_MINMAX 4	/* dB scale with min/max */ +#define SNDRV_CTL_TLVT_DB_MINMAX_MUTE 5	/* dB scale with min/max with mute */ + +/* + * channel-mapping TLV items + *  TLV length must match with num_channels + */ +#define SNDRV_CTL_TLVT_CHMAP_FIXED	0x101	/* fixed channel position */ +#define SNDRV_CTL_TLVT_CHMAP_VAR	0x102	/* channels freely swappable */ +#define SNDRV_CTL_TLVT_CHMAP_PAIRED	0x103	/* pair-wise swappable */ + +/* + * TLV structure is right behind the struct snd_ctl_tlv: + *   unsigned int type  	- see SNDRV_CTL_TLVT_* + *   unsigned int length + *   .... data aligned to sizeof(unsigned int), use + *        block_length = (length + (sizeof(unsigned int) - 1)) & + *                       ~(sizeof(unsigned int) - 1)) .... + */ +#define SNDRV_CTL_TLVD_ITEM(type, ...) \ +	(type), SNDRV_CTL_TLVD_LENGTH(__VA_ARGS__), __VA_ARGS__ +#define SNDRV_CTL_TLVD_LENGTH(...) \ +	((unsigned int)sizeof((const unsigned int[]) { __VA_ARGS__ })) + +/* Accessor offsets for TLV data items */ +#define SNDRV_CTL_TLVO_TYPE		0 +#define SNDRV_CTL_TLVO_LEN		1 + +#define SNDRV_CTL_TLVD_CONTAINER_ITEM(...) \ +	SNDRV_CTL_TLVD_ITEM(SNDRV_CTL_TLVT_CONTAINER, __VA_ARGS__) +#define SNDRV_CTL_TLVD_DECLARE_CONTAINER(name, ...) \ +	unsigned int name[] = { \ +		SNDRV_CTL_TLVD_CONTAINER_ITEM(__VA_ARGS__) \ +	} + +#define SNDRV_CTL_TLVD_DB_SCALE_MASK	0xffff +#define SNDRV_CTL_TLVD_DB_SCALE_MUTE	0x10000 +#define SNDRV_CTL_TLVD_DB_SCALE_ITEM(min, step, mute) \ +	SNDRV_CTL_TLVD_ITEM(SNDRV_CTL_TLVT_DB_SCALE, \ +			    (min), \ +			    ((step) & SNDRV_CTL_TLVD_DB_SCALE_MASK) | \ +			     ((mute) ? SNDRV_CTL_TLVD_DB_SCALE_MUTE : 0)) +#define SNDRV_CTL_TLVD_DECLARE_DB_SCALE(name, min, step, mute) \ +	unsigned int name[] = { \ +		SNDRV_CTL_TLVD_DB_SCALE_ITEM(min, step, mute) \ +	} + +/* Accessor offsets for min, mute and step items in dB scale type TLV */ +#define SNDRV_CTL_TLVO_DB_SCALE_MIN		2 +#define SNDRV_CTL_TLVO_DB_SCALE_MUTE_AND_STEP	3 + +/* dB scale specified with min/max values instead of step */ +#define SNDRV_CTL_TLVD_DB_MINMAX_ITEM(min_dB, max_dB) \ +	SNDRV_CTL_TLVD_ITEM(SNDRV_CTL_TLVT_DB_MINMAX, (min_dB), (max_dB)) +#define SNDRV_CTL_TLVD_DB_MINMAX_MUTE_ITEM(min_dB, max_dB) \ +	SNDRV_CTL_TLVD_ITEM(SNDRV_CTL_TLVT_DB_MINMAX_MUTE, (min_dB), (max_dB)) +#define SNDRV_CTL_TLVD_DECLARE_DB_MINMAX(name, min_dB, max_dB) \ +	unsigned int name[] = { \ +		SNDRV_CTL_TLVD_DB_MINMAX_ITEM(min_dB, max_dB) \ +	} +#define SNDRV_CTL_TLVD_DECLARE_DB_MINMAX_MUTE(name, min_dB, max_dB) \ +	unsigned int name[] = { \ +		SNDRV_CTL_TLVD_DB_MINMAX_MUTE_ITEM(min_dB, max_dB) \ +	} + +/* Accessor offsets for min, max items in db-minmax types of TLV. */ +#define SNDRV_CTL_TLVO_DB_MINMAX_MIN	2 +#define SNDRV_CTL_TLVO_DB_MINMAX_MAX	3 + +/* linear volume between min_dB and max_dB (.01dB unit) */ +#define SNDRV_CTL_TLVD_DB_LINEAR_ITEM(min_dB, max_dB) \ +	SNDRV_CTL_TLVD_ITEM(SNDRV_CTL_TLVT_DB_LINEAR, (min_dB), (max_dB)) +#define SNDRV_CTL_TLVD_DECLARE_DB_LINEAR(name, min_dB, max_dB) \ +	unsigned int name[] = { \ +		SNDRV_CTL_TLVD_DB_LINEAR_ITEM(min_dB, max_dB) \ +	} + +/* Accessor offsets for min, max items in db-linear type of TLV. */ +#define SNDRV_CTL_TLVO_DB_LINEAR_MIN	2 +#define SNDRV_CTL_TLVO_DB_LINEAR_MAX	3 + +/* dB range container: + * Items in dB range container must be ordered by their values and by their + * dB values. This implies that larger values must correspond with larger + * dB values (which is also required for all other mixer controls). + */ +/* Each item is: <min> <max> <TLV> */ +#define SNDRV_CTL_TLVD_DB_RANGE_ITEM(...) \ +	SNDRV_CTL_TLVD_ITEM(SNDRV_CTL_TLVT_DB_RANGE, __VA_ARGS__) +#define SNDRV_CTL_TLVD_DECLARE_DB_RANGE(name, ...) \ +	unsigned int name[] = { \ +		SNDRV_CTL_TLVD_DB_RANGE_ITEM(__VA_ARGS__) \ +	} + +#define SNDRV_CTL_TLVD_DB_GAIN_MUTE	-9999999 + +#endif diff --git a/include/alsa/sound/type_compat.h b/include/alsa/sound/type_compat.h new file mode 100644 index 0000000..e973ff3 --- /dev/null +++ b/include/alsa/sound/type_compat.h @@ -0,0 +1,42 @@ +#ifndef __TYPE_COMPAT_H +#define __TYPE_COMPAT_H + +#ifndef DOC_HIDDEN +#include <stdint.h> +typedef uint8_t __u8; +typedef uint16_t __u16; +typedef uint32_t __u32; +typedef int8_t __s8; +typedef int16_t __s16; +typedef int32_t __s32; + +#include <endian.h> +#include <byteswap.h> +#if __BYTE_ORDER == __LITTLE_ENDIAN +#define __cpu_to_le32(x) (x) +#define __cpu_to_be32(x) bswap_32(x) +#define __cpu_to_le16(x) (x) +#define __cpu_to_be16(x) bswap_16(x) +#else +#define __cpu_to_le32(x) bswap_32(x) +#define __cpu_to_be32(x) (x) +#define __cpu_to_le16(x) bswap_16(x) +#define __cpu_to_be16(x) (x) +#endif + +#define __le32_to_cpu __cpu_to_le32 +#define __be32_to_cpu __cpu_to_be32 +#define __le16_to_cpu __cpu_to_le16 +#define __be16_to_cpu __cpu_to_be16 + +#define __le64 __u64 +#define __le32 __u32 +#define __le16 __u16 +#define __le8  __u8 +#define __be64 __u64 +#define __be32 __u32 +#define __be16 __u16 +#define __be8  __u8 +#endif /* DOC_HIDDEN */ + +#endif /* __TYPE_COMPAT_H */ diff --git a/include/alsa/timer.h b/include/alsa/timer.h new file mode 100644 index 0000000..dc5ca69 --- /dev/null +++ b/include/alsa/timer.h @@ -0,0 +1,259 @@ +/** + * \file include/timer.h + * \brief Application interface library for the ALSA driver + * \author Jaroslav Kysela <perex@perex.cz> + * \author Abramo Bagnara <abramo@alsa-project.org> + * \author Takashi Iwai <tiwai@suse.de> + * \date 1998-2001 + * + * Application interface library for the ALSA driver + */ +/* + *   This library is free software; you can redistribute it and/or modify + *   it under the terms of the GNU Lesser General Public License as + *   published by the Free Software Foundation; either version 2.1 of + *   the License, or (at your option) any later version. + * + *   This program is distributed in the hope that it will be useful, + *   but WITHOUT ANY WARRANTY; without even the implied warranty of + *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *   GNU Lesser General Public License for more details. + * + *   You should have received a copy of the GNU Lesser General Public + *   License along with this library; if not, write to the Free Software + *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + */ + +#ifndef __ALSA_TIMER_H +#define __ALSA_TIMER_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup Timer Timer Interface + *  Timer Interface. See \ref timer page for more details. + *  \{ + */ + +/** dlsym version for interface entry callback */ +#define SND_TIMER_DLSYM_VERSION		_dlsym_timer_001 +/** dlsym version for interface entry callback */ +#define SND_TIMER_QUERY_DLSYM_VERSION	_dlsym_timer_query_001 + +/** timer identification structure */ +typedef struct _snd_timer_id snd_timer_id_t; +/** timer global info structure */ +typedef struct _snd_timer_ginfo snd_timer_ginfo_t; +/** timer global params structure */ +typedef struct _snd_timer_gparams snd_timer_gparams_t; +/** timer global status structure */ +typedef struct _snd_timer_gstatus snd_timer_gstatus_t; +/** timer info structure */ +typedef struct _snd_timer_info snd_timer_info_t; +/** timer params structure */ +typedef struct _snd_timer_params snd_timer_params_t; +/** timer status structure */ +typedef struct _snd_timer_status snd_timer_status_t; +/** timer master class */ +typedef enum _snd_timer_class { +	SND_TIMER_CLASS_NONE = -1,	/**< invalid */ +	SND_TIMER_CLASS_SLAVE = 0,	/**< slave timer */ +	SND_TIMER_CLASS_GLOBAL,		/**< global timer */ +	SND_TIMER_CLASS_CARD,		/**< card timer */ +	SND_TIMER_CLASS_PCM,		/**< PCM timer */ +	SND_TIMER_CLASS_LAST = SND_TIMER_CLASS_PCM	/**< last timer */ +} snd_timer_class_t; + +/** timer slave class */ +typedef enum _snd_timer_slave_class { +	SND_TIMER_SCLASS_NONE = 0,		/**< none */ +	SND_TIMER_SCLASS_APPLICATION,		/**< for internal use */ +	SND_TIMER_SCLASS_SEQUENCER,		/**< sequencer timer */ +	SND_TIMER_SCLASS_OSS_SEQUENCER,		/**< OSS sequencer timer */ +	SND_TIMER_SCLASS_LAST = SND_TIMER_SCLASS_OSS_SEQUENCER	/**< last slave timer */ +} snd_timer_slave_class_t; + +/** timer read event identification */ +typedef enum _snd_timer_event { +	SND_TIMER_EVENT_RESOLUTION = 0,	/* val = resolution in ns */ +	SND_TIMER_EVENT_TICK,		/* val = ticks */ +	SND_TIMER_EVENT_START,		/* val = resolution in ns */ +	SND_TIMER_EVENT_STOP,		/* val = 0 */ +	SND_TIMER_EVENT_CONTINUE,	/* val = resolution in ns */ +	SND_TIMER_EVENT_PAUSE,		/* val = 0 */ +	SND_TIMER_EVENT_EARLY,		/* val = 0 */ +	SND_TIMER_EVENT_SUSPEND,	/* val = 0 */ +	SND_TIMER_EVENT_RESUME,		/* val = resolution in ns */ +	/* master timer events for slave timer instances */ +	SND_TIMER_EVENT_MSTART = SND_TIMER_EVENT_START + 10, +	SND_TIMER_EVENT_MSTOP = SND_TIMER_EVENT_STOP + 10, +	SND_TIMER_EVENT_MCONTINUE = SND_TIMER_EVENT_CONTINUE + 10, +	SND_TIMER_EVENT_MPAUSE = SND_TIMER_EVENT_PAUSE + 10, +	SND_TIMER_EVENT_MSUSPEND = SND_TIMER_EVENT_SUSPEND + 10, +	SND_TIMER_EVENT_MRESUME = SND_TIMER_EVENT_RESUME + 10	 +} snd_timer_event_t; + +/** timer read structure */ +typedef struct _snd_timer_read { +	unsigned int resolution;	/**< tick resolution in nanoseconds */ +        unsigned int ticks;		/**< count of happened ticks */ +} snd_timer_read_t; + +/** timer tstamp + event read structure */ +typedef struct _snd_timer_tread { +	snd_timer_event_t event;	/**< Timer event */ +	snd_htimestamp_t tstamp;	/**< Time stamp of each event */ +	unsigned int val;		/**< Event value */ +} snd_timer_tread_t; + +/** global timer - system */ +#define SND_TIMER_GLOBAL_SYSTEM 0 +/** global timer - RTC */ +#define SND_TIMER_GLOBAL_RTC	1	/* Obsoleted, due to enough legacy. */ +/** global timer - HPET */ +#define SND_TIMER_GLOBAL_HPET	2 +/** global timer - HRTIMER */ +#define SND_TIMER_GLOBAL_HRTIMER 3 + +/** timer open mode flag - non-blocking behaviour */ +#define SND_TIMER_OPEN_NONBLOCK		(1<<0) +/** use timestamps and event notification - enhanced read */ +#define SND_TIMER_OPEN_TREAD		(1<<1) + +/** timer handle type */ +typedef enum _snd_timer_type { +	/** Kernel level HwDep */ +	SND_TIMER_TYPE_HW = 0, +	/** Shared memory client timer (not yet implemented) */ +	SND_TIMER_TYPE_SHM, +	/** INET client timer (not yet implemented) */ +	SND_TIMER_TYPE_INET +} snd_timer_type_t; + +/** timer query handle */ +typedef struct _snd_timer_query snd_timer_query_t; +/** timer handle */ +typedef struct _snd_timer snd_timer_t; + + +int snd_timer_query_open(snd_timer_query_t **handle, const char *name, int mode); +int snd_timer_query_open_lconf(snd_timer_query_t **handle, const char *name, int mode, snd_config_t *lconf); +int snd_timer_query_close(snd_timer_query_t *handle); +int snd_timer_query_next_device(snd_timer_query_t *handle, snd_timer_id_t *tid); +int snd_timer_query_info(snd_timer_query_t *handle, snd_timer_ginfo_t *info); +int snd_timer_query_params(snd_timer_query_t *handle, snd_timer_gparams_t *params); +int snd_timer_query_status(snd_timer_query_t *handle, snd_timer_gstatus_t *status); + +int snd_timer_open(snd_timer_t **handle, const char *name, int mode); +int snd_timer_open_lconf(snd_timer_t **handle, const char *name, int mode, snd_config_t *lconf); +int snd_timer_close(snd_timer_t *handle); +int snd_async_add_timer_handler(snd_async_handler_t **handler, snd_timer_t *timer, +				snd_async_callback_t callback, void *private_data); +snd_timer_t *snd_async_handler_get_timer(snd_async_handler_t *handler); +int snd_timer_poll_descriptors_count(snd_timer_t *handle); +int snd_timer_poll_descriptors(snd_timer_t *handle, struct pollfd *pfds, unsigned int space); +int snd_timer_poll_descriptors_revents(snd_timer_t *timer, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); +int snd_timer_info(snd_timer_t *handle, snd_timer_info_t *timer); +int snd_timer_params(snd_timer_t *handle, snd_timer_params_t *params); +int snd_timer_status(snd_timer_t *handle, snd_timer_status_t *status); +int snd_timer_start(snd_timer_t *handle); +int snd_timer_stop(snd_timer_t *handle); +int snd_timer_continue(snd_timer_t *handle); +ssize_t snd_timer_read(snd_timer_t *handle, void *buffer, size_t size); + +size_t snd_timer_id_sizeof(void); +/** allocate #snd_timer_id_t container on stack */ +#define snd_timer_id_alloca(ptr) __snd_alloca(ptr, snd_timer_id) +int snd_timer_id_malloc(snd_timer_id_t **ptr); +void snd_timer_id_free(snd_timer_id_t *obj); +void snd_timer_id_copy(snd_timer_id_t *dst, const snd_timer_id_t *src); + +void snd_timer_id_set_class(snd_timer_id_t *id, int dev_class); +int snd_timer_id_get_class(snd_timer_id_t *id); +void snd_timer_id_set_sclass(snd_timer_id_t *id, int dev_sclass); +int snd_timer_id_get_sclass(snd_timer_id_t *id); +void snd_timer_id_set_card(snd_timer_id_t *id, int card); +int snd_timer_id_get_card(snd_timer_id_t *id); +void snd_timer_id_set_device(snd_timer_id_t *id, int device); +int snd_timer_id_get_device(snd_timer_id_t *id); +void snd_timer_id_set_subdevice(snd_timer_id_t *id, int subdevice); +int snd_timer_id_get_subdevice(snd_timer_id_t *id); + +size_t snd_timer_ginfo_sizeof(void); +/** allocate #snd_timer_ginfo_t container on stack */ +#define snd_timer_ginfo_alloca(ptr) __snd_alloca(ptr, snd_timer_ginfo) +int snd_timer_ginfo_malloc(snd_timer_ginfo_t **ptr); +void snd_timer_ginfo_free(snd_timer_ginfo_t *obj); +void snd_timer_ginfo_copy(snd_timer_ginfo_t *dst, const snd_timer_ginfo_t *src); + +int snd_timer_ginfo_set_tid(snd_timer_ginfo_t *obj, snd_timer_id_t *tid); +snd_timer_id_t *snd_timer_ginfo_get_tid(snd_timer_ginfo_t *obj); +unsigned int snd_timer_ginfo_get_flags(snd_timer_ginfo_t *obj); +int snd_timer_ginfo_get_card(snd_timer_ginfo_t *obj); +char *snd_timer_ginfo_get_id(snd_timer_ginfo_t *obj); +char *snd_timer_ginfo_get_name(snd_timer_ginfo_t *obj); +unsigned long snd_timer_ginfo_get_resolution(snd_timer_ginfo_t *obj); +unsigned long snd_timer_ginfo_get_resolution_min(snd_timer_ginfo_t *obj); +unsigned long snd_timer_ginfo_get_resolution_max(snd_timer_ginfo_t *obj); +unsigned int snd_timer_ginfo_get_clients(snd_timer_ginfo_t *obj); + +size_t snd_timer_info_sizeof(void); +/** allocate #snd_timer_info_t container on stack */ +#define snd_timer_info_alloca(ptr) __snd_alloca(ptr, snd_timer_info) +int snd_timer_info_malloc(snd_timer_info_t **ptr); +void snd_timer_info_free(snd_timer_info_t *obj); +void snd_timer_info_copy(snd_timer_info_t *dst, const snd_timer_info_t *src); + +int snd_timer_info_is_slave(snd_timer_info_t * info); +int snd_timer_info_get_card(snd_timer_info_t * info); +const char *snd_timer_info_get_id(snd_timer_info_t * info); +const char *snd_timer_info_get_name(snd_timer_info_t * info); +long snd_timer_info_get_resolution(snd_timer_info_t * info); + +size_t snd_timer_params_sizeof(void); +/** allocate #snd_timer_params_t container on stack */ +#define snd_timer_params_alloca(ptr) __snd_alloca(ptr, snd_timer_params) +int snd_timer_params_malloc(snd_timer_params_t **ptr); +void snd_timer_params_free(snd_timer_params_t *obj); +void snd_timer_params_copy(snd_timer_params_t *dst, const snd_timer_params_t *src); + +int snd_timer_params_set_auto_start(snd_timer_params_t * params, int auto_start); +int snd_timer_params_get_auto_start(snd_timer_params_t * params); +int snd_timer_params_set_exclusive(snd_timer_params_t * params, int exclusive); +int snd_timer_params_get_exclusive(snd_timer_params_t * params); +int snd_timer_params_set_early_event(snd_timer_params_t * params, int early_event); +int snd_timer_params_get_early_event(snd_timer_params_t * params); +void snd_timer_params_set_ticks(snd_timer_params_t * params, long ticks); +long snd_timer_params_get_ticks(snd_timer_params_t * params); +void snd_timer_params_set_queue_size(snd_timer_params_t * params, long queue_size); +long snd_timer_params_get_queue_size(snd_timer_params_t * params); +void snd_timer_params_set_filter(snd_timer_params_t * params, unsigned int filter); +unsigned int snd_timer_params_get_filter(snd_timer_params_t * params); + +size_t snd_timer_status_sizeof(void); +/** allocate #snd_timer_status_t container on stack */ +#define snd_timer_status_alloca(ptr) __snd_alloca(ptr, snd_timer_status) +int snd_timer_status_malloc(snd_timer_status_t **ptr); +void snd_timer_status_free(snd_timer_status_t *obj); +void snd_timer_status_copy(snd_timer_status_t *dst, const snd_timer_status_t *src); + +snd_htimestamp_t snd_timer_status_get_timestamp(snd_timer_status_t * status); +long snd_timer_status_get_resolution(snd_timer_status_t * status); +long snd_timer_status_get_lost(snd_timer_status_t * status); +long snd_timer_status_get_overrun(snd_timer_status_t * status); +long snd_timer_status_get_queue(snd_timer_status_t * status); + +/* deprecated functions, for compatibility */ +long snd_timer_info_get_ticks(snd_timer_info_t * info); + +/** \} */ + +#ifdef __cplusplus +} +#endif + +#endif /** __ALSA_TIMER_H */ + diff --git a/include/alsa/topology.h b/include/alsa/topology.h new file mode 100644 index 0000000..27da730 --- /dev/null +++ b/include/alsa/topology.h @@ -0,0 +1,1115 @@ +/* + * + *  This library is free software; you can redistribute it and/or modify + *  it under the terms of the GNU Lesser General Public License as + *  published by the Free Software Foundation; either version 2.1 of + *  the License, or (at your option) any later version. + * + *  This program is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU Lesser General Public License for more details. + * + *  You should have received a copy of the GNU Lesser General Public + *  License along with this library; if not, write to the Free Software + *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + *  Copyright (C) 2015 Intel Corporation + * + */ + +#ifndef __ALSA_TOPOLOGY_H +#define __ALSA_TOPOLOGY_H + +#include <stdint.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \defgroup topology Topology Interface + * \{ + */ + +/*! \page topology ALSA Topology Interface + * + * The topology interface allows developers to define DSP topologies in a text + * file format and to convert the text topology to a binary topology + * representation that can be understood by the kernel. The topology core + * currently recognises the following object types :- + * + *  * Controls (mixer, enumerated and byte) including TLV data. + *  * PCMs (Front End DAI & DAI link) + *  * DAPM widgets + *  * DAPM graph elements. + *  * Physical DAI & DAI links + *  * Private data for each object type. + *  * Manifest (containing count of each object type) + * + * <h3>Topology File Format</h3> + * + * The topology text format uses the standard ALSA configuration file format to + * describe each topology object type. This allows topology objects to include + * other topology objects as part of their definition. i.e. a TLV data object + * can be shared amongst many control objects that use the same TLV data. + * + * + * <h4>Controls</h4> + * Topology audio controls can belong to three different types :- + *   * Mixer control + *   * Enumerated control + *   * Byte control + * + * Each control type can contain TLV data, private data, operations and also + * belong to widget objects.<br> + * + * <h5>Control Operations</h5> + * Driver Kcontrol callback info(), get() and put() operations are mapped with + * the CTL ops section in topology configuration files. The ctl ops section can + * assign operations using the standard names (listed below) for the standard + * kcontrol types or use ID numbers (>256) to map to bespoke driver controls.<br> + * + * <pre> + * + *	ops."ctl" { + *		info "volsw" + *		get "257" + *		put "257" + *	} + * + * </pre> + * + * This mapping shows info() using the standard "volsw" info callback whilst + * the get() and put() are mapped to bespoke driver callbacks. <br> + * + * The Standard operations names for control get(), put() and info calls + * are :- + *  * volsw + *  * volsw_sx + *  * volsw_xr_sx + *  * enum + *  * bytes + *  * enum_value + *  * range + *  * strobe + * +* <h5>Control Access</h5> + * Controls access can be specified using the "access" section. If no "access" + * section is defined then default RW access flags are set for normal and TLV + * controls. + * + * <pre> + *	access [ + *		read + *		write + *		tlv_command + *	] + * </pre> + * + * The standard access flags are as follows :- + *  * read + *  * write + *  * read_write + *  * volatile + *  * timestamp + *  * tlv_read + *  * tlv_write + *  * tlv_read_write + *  * tlv_command + *  * inactive + *  * lock + *  * owner + *  * tlv_callback + *  * user + * + * <h5>Control TLV Data</h5> + * Controls can also use TLV data to represent dB information. This can be done + * by defining a TLV section and using the TLV section within the control. + * The TLV data for DBScale types are defined as follows :- + * + * <pre> + *	scale { + *		min "-9000" + *		step "300" + *		mute "1" + *	} + * </pre> + * + * Where the meanings and values for min, step and mute are exactly the same + * as defined in driver code. + * + * <h5>Control Channel Mapping</h5> + * Controls can also specify which channels they are mapped with. This is useful + * for userspace as it allows applications to determine the correct control + * channel for Left and Right etc. Channel maps are defined as follows :- + * + * <pre> + *	channel."name" { + *		reg "0" + *		shift "0" + *	} + * </pre> + * + * The channel map reg is the register offset for the control, shift is the + * bit shift within the register for the channel and the section name is the + * channel name and can be one of the following :- + * + * <pre> + *  * mono		# mono stream + *  * fl 		# front left + *  * fr		# front right + *  * rl		# rear left + *  * rr		# rear right + *  * fc		# front center + *  * lfe		# LFE + *  * sl		# side left + *  * sr		# side right + *  * rc		# rear center + *  * flc		# front left center + *  * frc		# front right center + *  * rlc		# rear left center + *  * rrc		# rear right center + *  * flw		# front left wide + *  * frw		# front right wide + *  * flh		# front left high + *  * fch		# front center high + *  * frh		# front right high + *  * tc		# top center + *  * tfl		# top front left + *  * tfr		# top front right + *  * tfc		# top front center + *  * trl		# top rear left + *  * trr		# top rear right + *  * trc		# top rear center + *  * tflc		# top front left center + *  * tfrc		# top front right center + *  * tsl		# top side left + *  * tsr		# top side right + *  * llfe		# left LFE + *  * rlfe		# right LFE + *  * bc		# bottom center + *  * blc		# bottom left center + *  * brc		# bottom right center + * </pre> + * + *  <h5>Control Private Data</h5> + * Controls can also have private data. This can be done by defining a private + * data section and including the section within the control. The private data + * section is defined as follows :- + * + * <pre> + * SectionData."pdata for EQU1" { + *	file "/path/to/file" + *	bytes "0x12,0x34,0x56,0x78" + *	shorts "0x1122,0x3344,0x5566,0x7788" + *	words "0xaabbccdd,0x11223344,0x66aa77bb,0xefef1234" + *	tuples "section id of the vendor tuples" + * }; + * </pre> + * The file, bytes, shorts, words and tuples keywords are all mutually + * exclusive as the private data should only be taken from one source. + * The private data can either be read from a separate file or defined in + * the topology file using the bytes, shorts, words or tuples keywords. + * The keyword tuples is to define vendor specific tuples. Please refer to + * section Vendor Tokens and Vendor tuples. + * + * It's easy to use a vendor tuples object to define a C structure instance. + * And a data section can include multiple vendor tuples objects: + * + * <pre> + * SectionData."data element name" { + *	index "1"	#Index number + *	tuples [ + *		"id of the 1st vendor tuples section" + *		"id of the 2nd vendor tuples section" + *		... + *	] + * }; + * </pre> + * + * <h5>How to define an element with private data</h5> + * An element can refer to a single data section or multiple data + * sections. + * + * <h6>To refer to a single data section:</h6> + * <pre> + * Sectionxxx."element name" { + *    ... + *	data "name of data section"		# optional private data + * } + * </pre> + * + * <h6>To refer to multiple data sections:</h6> + * <pre> + * Sectionxxx."element name" { + *	... + *	data [						# optional private data + *		"name of 1st data section" + *		"name of 2nd data section" + *		... + *	] + * } + * </pre> + * And data of these sections will be merged in the same order as they are + * in the list, as the element's private data for kernel. + * + * </pre> + * + *  <h6>Vendor Tokens</h6> + * A vendor token list is defined as a new section. Each token element is + * a pair of string ID and integer value. And both the ID and value are + * vendor-specific. + * + * <pre> + * SectionVendorTokens."id of the vendor tokens" { + *	comment "optional comments" + *	VENDOR_TOKEN_ID1 "1" + *	VENDOR_TOKEN_ID2 "2" + *	VENDOR_TOKEN_ID3 "3" + *	... + * } + * </pre> + * + *  <h6>Vendor Tuples</h6> + * Vendor tuples are defined as a new section. It contains a reference to + * a vendor token list and several tuple arrays. + * All arrays share a vendor token list, defined by the tokens keyword. + * Each tuple array is for a specific type, defined by the string following + * the tuples keyword. Supported types are: string, uuid, bool, byte, + * short and word. + * + * <pre> + * SectionVendorTuples."id of the vendor tuples" { + *	tokens "id of the vendor tokens" + * + *	tuples."string" { + *		VENDOR_TOKEN_ID1 "character string" + *		... + *	} + * + *	tuples."uuid" {			# 16 characters separated by commas + *		VENDOR_TOKEN_ID2 "0x01,0x02,...,0x0f" + *		... + *	} + * + *	tuples."bool" { + *		VENDOR_TOKEN_ID3 "true/false" + *		... + *	} + * + *	tuples."byte" { + *		VENDOR_TOKEN_ID4 "0x11" + *		VENDOR_TOKEN_ID5 "0x22" + *		... + *	} + * + *	tuples."short" { + *		VENDOR_TOKEN_ID6 "0x1122" + *		VENDOR_TOKEN_ID7 "0x3344" + *		... + *	} + * + *	tuples."word" { + *		VENDOR_TOKEN_ID8 "0x11223344" + *		VENDOR_TOKEN_ID9 "0x55667788" + *		... + *	} + * } + * </pre> + * To define multiple vendor tuples of same type, please append some + * characters after the type string ("string", "uuid", "bool", "byte", "short" + * or "word"), to avoid ID duplication in the SectionVendorTuples.<br> + * The parser will check the first few characters in ID to get the tuple type. + * Here is an example: + * <pre> + * SectionVendorTuples."id of the vendor tuples" { + *    ... + *	tuples."word.module0" { + *		VENDOR_TOKEN_PARAM_ID1 "0x00112233" + *		VENDOR_TOKEN_PARAM_ID2 "0x44556677" + *		... + *	} + * + *	tuples."word.module2" { + *		VENDOR_TOKEN_PARAM_ID1 "0x11223344" + *		VENDOR_TOKEN_PARAM_ID2 "0x55667788" + *		... + *	} + *	... + * } + * + * </pre> + * + * <h5>Mixer Controls</h5> + * A mixer control is defined as a new section that can include channel mapping, + * TLV data, callback operations and private data. The mixer section also + * includes a few other config options that are shown here :- + * + * <pre> + * SectionControlMixer."mixer name" { + *	comment "optional comments" + * + *	index "1"			# Index number + * + *	channel."name" {		# Channel maps + *	   .... + *	} + * + *	ops."ctl" {			# Ops callback functions + *	   .... + *	} + * + *	max "32"			# Max control value + *	invert "0"			# Whether control values are inverted + * + *	tlv "tld_data"			# optional TLV data + * + *	data "pdata for mixer1"		# optional private data + * } + * </pre> + * + * The section name is used to define the mixer name. The index number can be + * used to identify topology objects groups(index "0" is common, fit for all + * user cases).This allows driver operations on objects with index number N and + * can be used to add/remove pipelines of objects whilst other objects are + * unaffected. + * + * <h5>Byte Controls</h5> + * A byte control is defined as a new section that can include channel mapping, + * TLV data, callback operations and private data. The bytes section also + * includes a few other config options that are shown here :- + * + * <pre> + * SectionControlBytes."name" { + *	comment "optional comments" + * + *	index "1"			# Index number + * + *	channel."name" {		# Channel maps + *	   .... + *	} + * + *	ops."ctl" {			# Ops callback functions + *	   .... + *	} + * + *	base "0"			# Register base + *	num_regs "16"			# Number of registers + *	mask "0xff"			# Mask + *	max "255"			# Maximum value + * + *	tlv "tld_data"			# optional TLV data + * + *	data "pdata for mixer1"		# optional private data + * } + * </pre> + * + * <h5>Enumerated Controls</h5> + * A enumerated control is defined as a new section (like mixer and byte) that + * can include channel mapping, callback operations, private data and + * text strings to represent the enumerated control options.<br> + * + * The text strings for the enumerated controls are defined in a separate + * section as follows :- + * + * <pre> + * SectionText."name" { + * + *		Values [ + *			"value1" + *			"value2" +			"value3" + *		] + * } + * </pre> + * + * All the enumerated text values are listed in the values list.<br> + * The enumerated control is similar to the other controls and defined as + * follows :- + * + * <pre> + * SectionControlMixer."name" { + *	comment "optional comments" + * + *	index "1"			# Index number + * + *	texts "EQU1"			# Enumerated text items + * + *	channel."name" {		# Channel maps + *	   .... + *	} + * + *	ops."ctl" {			# Ops callback functions + *	   .... + *	} + * + *	data "pdata for mixer1"		# optional private data + * } + * </pre> + * + * <h4>DAPM Graph</h4> + * DAPM graphs can easily be defined using the topology file. The format is + * very similar to the DAPM graph kernel format. :- + * + * <pre> + * SectionGraph."dsp" { + *	index "1"			# Index number + * + *	lines [ + *		"sink1, control, source1" + *		"sink2, , source2" + *	] + * } + * </pre> + * + * The lines in the graph are defined as a variable size list of sinks, + * controls and sources. The control name is optional as some graph lines have + * no associated controls. The section name can be used to differentiate the + * graph with other graphs, it's not used by the kernel atm. + * + * <h4>DAPM Widgets</h4> + * DAPM widgets are similar to controls in that they can include many other + * objects. Widgets can contain private data, mixer controls and enum controls. + * + * The following widget types are supported and match the driver types :- + * + *  * input + *  * output + *  * mux + *  * mixer + *  * pga + *  * out_drv + *  * adc + *  * dac + *  * switch + *  * pre + *  * post + *  * aif_in + *  * aif_out + *  * dai_in + *  * dai_out + *  * dai_link + * + * Widgets are defined as follows :- + * + * <pre> + * SectionWidget."name" { + * + *	index "1"			# Index number + * + *	type "aif_in"			# Widget type - detailed above + *	stream_name "name"		# Stream name + * + *	no_pm "true"			# No PM control bit. + *	reg "20"			# PM bit register offset + *	shift "0"			# PM bit register shift + *	invert "1			# PM bit is inverted + *	subseq "8"			# subsequence number + * + *	event_type "1"			# DAPM widget event type + *	event_flags "1"			# DAPM widget event flags + * + *	mixer "name"			# Optional Mixer Control + *	enum "name"			# Optional Enum Control + * + *	data "name"			# optional private data + * } + * </pre> + * + * The section name is the widget name. The mixer and enum fields are mutually + * exclusive and used to include controls into the widget. The index and data + * fields are the same for widgets as they are for controls whilst the other + * fields map on very closely to the driver widget fields. + * + * <h5>Widget Private Data</h5> + * Widget can have private data. For the format of the private data, please + * refer to section Control Private Data. + * + * <h4>PCM Capabilities</h4> + * Topology can also define the PCM capabilities of front end or physical DAIs. + * Capabilities can be defined with the following section :- + * + * <pre> + * SectionPCMCapabilities."name" { + * + *	formats "S24_LE,S16_LE"		# Supported formats + *	rates "48000"			# Supported rates + *	rate_min "48000"		# Max supported sample rate + *	rate_max "48000"		# Min supported sample rate + *	channels_min "2"		# Min number of channels + *	channels_max "2"		# max number of channels + * } + * </pre> + * The supported formats use the same naming convention as the driver macros. + * The PCM capabilities name can be referred to and included by PCM and + * physical DAI sections. + * + * <h4>PCM Configurations</h4> + * PCM runtime configurations can be defined for playback and capture stream + * directions with the following section  :- + * + * <pre> + * SectionPCMConfig."name" { + * + *	config."playback" {		# playback config + *		format "S16_LE"		# playback format + *		rate "48000"		# playback sample rate + *		channels "2"		# playback channels + *		tdm_slot "0xf"		# playback TDM slot + *	} + * + *	config."capture" {		# capture config + *		format "S16_LE"		# capture format + *		rate "48000"		# capture sample rate + *		channels "2"		# capture channels + *		tdm_slot "0xf"		# capture TDM slot + *	} + * } + * </pre> + * + * The supported formats use the same naming convention as the driver macros. + * The PCM configuration name can be referred to and included by PCM and + * physical link sections. + * + * <h4>PCM (Front-end DAI & DAI link) </h4> + * PCM sections define the supported capabilities and configurations for + * supported playback and capture streams, names and flags for front end + * DAI & DAI links. Topology kernel driver will use a PCM object to create + * a pair of FE DAI & DAI links. + * + * <pre> + * SectionPCM."name" { + * + *	index "1"			# Index number + * + *	id "0"				# used for binding to the PCM + * + *	dai."name of front-end DAI" { + *		id "0"		# used for binding to the front-end DAI + *	} + * + *	pcm."playback" { + *		capabilities "capabilities1"	# capabilities for playback + * + *		configs [		# supported configs for playback + *			"config1" + *			"config2" + *		] + *	} + * + *	pcm."capture" { + *		capabilities "capabilities2"	# capabilities for capture + * + *		configs [		# supported configs for capture + *			"config1" + *			"config2" + *			"config3" + *		] + *	} + * + *	# Optional boolean flags + *	symmetric_rates			"true" + *	symmetric_channels		"true" + *	symmetric_sample_bits		"false" + * + *	data "name"			# optional private data + * } + * </pre> + * + * <h4>Physical DAI Link Configurations</h4> + * The runtime configurations of a physical DAI link can be defined by + * SectionLink. <br> Backend DAI links belong to physical links, and can + * be configured by either SectionLink or SectionBE, with same syntax. + * But SectionBE is deprecated atm since the internal processing is + * actually same. + * + * <pre> + * SectionLink."name" { + * + *	index "1"			# Index number + * + *	id "0"				# used for binding to the link + * + *	stream_name "name"		# used for binding to the link + * + *	hw_configs [	# runtime supported HW configurations, optional + *		"config1" + *		"config2" + *		... + *	] + * + *	default_hw_conf_id "1"		#default HW config ID for init + * + *	# Optional boolean flags + *	symmetric_rates			"true" + *	symmetric_channels		"false" + *	symmetric_sample_bits		"true" + * + *	data "name"			# optional private data + * } + * </pre> + * + * A physical link can refer to multiple runtime supported hardware + * configurations, which is defined by SectionHWConfig. + * + * <pre> + * SectionHWConfig."name" { + * + *	id "1"				# used for binding to the config + *	format "I2S"			# physical audio format. + *	bclk   "master"			# Platform is master of bit clock + *	fsync  "slave"			# Platform is slave of fsync + * } + * </pre> + * + * <h4>Physical DAI</h4> + * A physical DAI (e.g. backend DAI for DPCM) is defined as a new section + * that can include a unique ID, playback and capture stream capabilities, + * optional flags, and private data. <br> + * Its PCM stream capablities are same as those for PCM objects, + * please refer to section 'PCM Capabilities'. + * + * <pre> + * SectionDAI."name" { + * + *	index "1"			# Index number + * + *	id "0"				# used for binding to the Backend DAI + * + *	pcm."playback" { + *		capabilities "capabilities1"	# capabilities for playback + *	} + * + *	pcm."capture" { + *		capabilities "capabilities2"	# capabilities for capture + *	} + * + *	symmetric_rates "true"			# optional flags + *	symmetric_channels "true" + *	symmetric_sample_bits "false" + * + *	data "name"			# optional private data + * } + * </pre> + * + * <h4>Manifest Private Data</h4> + * Manfiest may have private data. Users need to define a manifest section + * and add the references to 1 or multiple data sections. Please refer to + * section 'How to define an element with private data'. <br> + * And the text conf file can have at most 1 manifest section. <br><br> + * + * Manifest section is defined as follows :- + * + * <pre> + * SectionManifest"name" { + * + *	data "name"			# optional private data + * } + * </pre> + * + * <h4>Include other files</h4> + * Users may include other files in a text conf file via alsaconf syntax + * <path/to/configuration-file>. This allows users to define common info + * in separate files (e.g. vendor tokens, tuples) and share them for + * different platforms, thus save the total size of config files. <br> + * Users can also specifiy additional configuraiton directories relative + * to "/usr/share/alsa/" to search the included files,  via alsaconf syntax + * <searchfdir:/relative-path/to/usr/share/alsa>. <br><br> + * + * For example, file A and file B are two text conf files for platform X, + * they will be installed to /usr/share/alsa/topology/platformx. If we + * need file A to include file B, in file A we can add: <br> + * + * <searchdir:topology/platformx> <br> + * <name-of-file-B> <br><br> + * + * ALSA conf will search and open an included file in the following order + * of priority: + *  1. directly open the file by its name; + *  2. search for the file name in "/usr/share/alsa"; + *  3. search for the file name in user specified subdirectories under + *     "/usr/share/alsa". + * + * The order of the included files need not to be same as their + * dependencies, since the topology library will load them all before + * parsing their dependencies. <br> + * + * The configuration directories defined by a file will only be used to search + * the files included by this file. + */ + +/** Maximum number of channels supported in one control */ +#define SND_TPLG_MAX_CHAN		8 + +/** Topology context */ +typedef struct snd_tplg snd_tplg_t; + +/** Topology object types */ +enum snd_tplg_type { +	SND_TPLG_TYPE_TLV = 0,		/*!< TLV Data */ +	SND_TPLG_TYPE_MIXER,		/*!< Mixer control*/ +	SND_TPLG_TYPE_ENUM,		/*!< Enumerated control */ +	SND_TPLG_TYPE_TEXT,		/*!< Text data */ +	SND_TPLG_TYPE_DATA,		/*!< Private data */ +	SND_TPLG_TYPE_BYTES,		/*!< Byte control */ +	SND_TPLG_TYPE_STREAM_CONFIG,	/*!< PCM Stream configuration */ +	SND_TPLG_TYPE_STREAM_CAPS,	/*!< PCM Stream capabilities */ +	SND_TPLG_TYPE_PCM,		/*!< PCM stream device */ +	SND_TPLG_TYPE_DAPM_WIDGET,	/*!< DAPM widget */ +	SND_TPLG_TYPE_DAPM_GRAPH,	/*!< DAPM graph elements */ +	SND_TPLG_TYPE_BE,		/*!< BE DAI link */ +	SND_TPLG_TYPE_CC,		/*!< Hostless codec <-> codec link */ +	SND_TPLG_TYPE_MANIFEST,		/*!< Topology manifest */ +	SND_TPLG_TYPE_TOKEN,		/*!< Vendor tokens */ +	SND_TPLG_TYPE_TUPLE,		/*!< Vendor tuples */ +	SND_TPLG_TYPE_LINK,		/*!< Physical DAI link */ +	SND_TPLG_TYPE_HW_CONFIG,	/*!< Link HW config */ +	SND_TPLG_TYPE_DAI,		/*!< Physical DAI */ +}; + +/** Fit for all user cases */ +#define SND_TPLG_INDEX_ALL  0 + +/** + * \brief Create a new topology parser instance. + * \return New topology parser instance + */ +snd_tplg_t *snd_tplg_new(void); + +/** + * \brief Free a topology parser instance. + * \param tplg Topology parser instance + */ +void snd_tplg_free(snd_tplg_t *tplg); + +/** + * \brief Parse and build topology text file into binary file. + * \param tplg Topology instance. + * \param infile Topology text input file to be parsed + * \param outfile Binary topology output file. + * \return Zero on success, otherwise a negative error code + */ +int snd_tplg_build_file(snd_tplg_t *tplg, const char *infile, +	const char *outfile); + +/** + * \brief Enable verbose reporting of binary file output + * \param tplg Topology Instance + * \param verbose Enable verbose output level if non zero + */ +void snd_tplg_verbose(snd_tplg_t *tplg, int verbose); + +/** \struct snd_tplg_tlv_template + * \brief Template type for all TLV objects. + */ +struct snd_tplg_tlv_template { +	int type;	 /*!< TLV type SNDRV_CTL_TLVT_ */ +}; + +/** \struct snd_tplg_tlv_dbscale_template + * \brief Template type for TLV Scale objects. + */ +struct snd_tplg_tlv_dbscale_template { +	struct snd_tplg_tlv_template hdr;	/*!< TLV type header */ +	int min;			/*!< dB minimum value in 0.1dB */ +	int step;			/*!< dB step size in 0.1dB */ +	int mute;			/*!< is min dB value mute ? */ +}; + +/** \struct snd_tplg_channel_template + * \brief Template type for single channel mapping. + */ +struct snd_tplg_channel_elem { +	int size;	/*!< size in bytes of this structure */ +	int reg;	/*!< channel control register */ +	int shift;	/*!< channel shift for control bits */ +	int id;		/*!< ID maps to Left, Right, LFE etc */ +}; + +/** \struct snd_tplg_channel_map_template + * \brief Template type for channel mapping. + */ +struct snd_tplg_channel_map_template { +	int num_channels;	/*!< number of channel mappings */ +	struct snd_tplg_channel_elem channel[SND_TPLG_MAX_CHAN];	/*!< mapping */ +}; + +/** \struct snd_tplg_pdata_template + * \brief Template type for private data objects. + */ +struct snd_tplg_pdata_template { +	unsigned int length;	/*!< data length */ +	const void *data;	/*!< data */ +}; + +/** \struct snd_tplg_io_ops_template + * \brief Template type for object operations mapping. + */ +struct snd_tplg_io_ops_template { +	int get;	/*!< get callback ID */ +	int put;	/*!< put callback ID */ +	int info;	/*!< info callback ID */ +}; + +/** \struct snd_tplg_ctl_template + * \brief Template type for control objects. + */ +struct snd_tplg_ctl_template { +	int type;		/*!< Control type */ +	const char *name;	/*!< Control name */ +	int access;		/*!< Control access */ +	struct snd_tplg_io_ops_template ops;	/*!< operations */ +	struct snd_tplg_tlv_template *tlv; /*!< non NULL means we have TLV data */ +}; + +/** \struct snd_tplg_mixer_template + * \brief Template type for mixer control objects. + */ +struct snd_tplg_mixer_template { +	struct snd_tplg_ctl_template hdr;	/*!< control type header */ +	struct snd_tplg_channel_map_template *map;	/*!< channel map */ +	int min;	/*!< min value for mixer */ +	int max;	/*!< max value for mixer */ +	int platform_max;	/*!< max value for platform control */ +	int invert;	/*!< whether controls bits are inverted */ +	struct snd_soc_tplg_private *priv;	/*!< control private data */ +}; + +/** \struct snd_tplg_enum_template + * \brief Template type for enumerated control objects. + */ +struct snd_tplg_enum_template { +	struct snd_tplg_ctl_template hdr;	/*!< control type header */ +	struct snd_tplg_channel_map_template *map;	/*!< channel map */ +	int items;	/*!< number of enumerated items in control */ +	int mask;	/*!< register mask size */ +	const char **texts;	/*!< control text items */ +	const int **values;	/*!< control value items */ +	struct snd_soc_tplg_private *priv;	/*!< control private data */ +}; + +/** \struct snd_tplg_bytes_template + * \brief Template type for TLV Scale objects. + */ +struct snd_tplg_bytes_template { +	struct snd_tplg_ctl_template hdr;	/*!< control type header */ +	int max;		/*!< max byte control value */ +	int mask;		/*!< byte control mask */ +	int base;		/*!< base register */ +	int num_regs;		/*!< number of registers */ +	struct snd_tplg_io_ops_template ext_ops;	/*!< ops mapping */ +	struct snd_soc_tplg_private *priv;	/*!< control private data */ +}; + +/** \struct snd_tplg_graph_elem + * \brief Template type for single DAPM graph element. + */ +struct snd_tplg_graph_elem { +	const char *src;	/*!< source widget name */ +	const char *ctl;	/*!< control name or NULL if no control */ +	const char *sink;	/*!< sink widget name */ +}; + +/** \struct snd_tplg_graph_template + * \brief Template type for array of DAPM graph elements. + */ +struct snd_tplg_graph_template { +	int count;		/*!< Number of graph elements */ +	struct snd_tplg_graph_elem elem[0];	/*!< graph elements */ +}; + +/** \struct snd_tplg_widget_template + * \brief Template type for DAPM widget objects. + */ +struct snd_tplg_widget_template { +	int id;			/*!< SND_SOC_DAPM_CTL */ +	const char *name;	/*!< widget name */ +	const char *sname;	/*!< stream name (certain widgets only) */ +	int reg;		/*!< negative reg = no direct dapm */ +	int shift;		/*!< bits to shift */ +	int mask;		/*!< non-shifted mask */ +	int subseq;		/*!< sort within widget type */ +	unsigned int invert;		/*!< invert the power bit */ +	unsigned int ignore_suspend;	/*!< kept enabled over suspend */ +	unsigned short event_flags;	/*!< PM event sequence flags */ +	unsigned short event_type;	/*!< PM event sequence type */ +	struct snd_soc_tplg_private *priv;	/*!< widget private data */ +	int num_ctls;			/*!< Number of controls used by widget */ +	struct snd_tplg_ctl_template *ctl[0];	/*!< array of widget controls */ +}; + +/** \struct snd_tplg_stream_template + * \brief Stream configurations. + */ +struct snd_tplg_stream_template { +	const char *name;	/*!< name of the stream config */ +	int format;		/*!< SNDRV_PCM_FMTBIT_* */ +	int rate;		/*!< SNDRV_PCM_RATE_* */ +	int period_bytes;	/*!< size of period in bytes */ +	int buffer_bytes;	/*!< size of buffer in bytes. */ +	int channels;		/*!< number of channels */ +}; + +/** \struct snd_tplg_stream_caps_template + * \brief Stream Capabilities. + */ +struct snd_tplg_stream_caps_template { +	const char *name;	/*!< name of the stream caps */ +	uint64_t formats;	/*!< supported formats SNDRV_PCM_FMTBIT_* */ +	unsigned int rates;	/*!< supported rates SNDRV_PCM_RATE_* */ +	unsigned int rate_min;	/*!< min rate */ +	unsigned int rate_max;	/*!< max rate */ +	unsigned int channels_min;	/*!< min channels */ +	unsigned int channels_max;	/*!< max channels */ +	unsigned int periods_min;	/*!< min number of periods */ +	unsigned int periods_max;	/*!< max number of periods */ +	unsigned int period_size_min;	/*!< min period size bytes */ +	unsigned int period_size_max;	/*!< max period size bytes */ +	unsigned int buffer_size_min;	/*!< min buffer size bytes */ +	unsigned int buffer_size_max;	/*!< max buffer size bytes */ +	unsigned int sig_bits;		/*!< number of bits of content */ +}; + +/** \struct snd_tplg_pcm_template + * \brief Template type for PCM (FE DAI & DAI links). + */ +struct snd_tplg_pcm_template { +	const char *pcm_name;	/*!< PCM stream name */ +	const char *dai_name;	/*!< DAI name */ +	unsigned int pcm_id;	/*!< unique ID - used to match */ +	unsigned int dai_id;	/*!< unique ID - used to match */ +	unsigned int playback;	/*!< supports playback mode */ +	unsigned int capture;	/*!< supports capture mode */ +	unsigned int compress;	/*!< 1 = compressed; 0 = PCM */ +	struct snd_tplg_stream_caps_template *caps[2]; /*!< playback & capture for DAI */ +	unsigned int flag_mask; /*!< bitmask of flags to configure */ +	unsigned int flags;     /*!< flag value SND_SOC_TPLG_LNK_FLGBIT_* */ +	struct snd_soc_tplg_private *priv;	/*!< private data */ +	int num_streams;	/*!< number of supported configs */ +	struct snd_tplg_stream_template stream[0]; /*!< supported configs */ +}; + + /** \struct snd_tplg_hw_config_template + * \brief Template type to describe a physical link runtime supported + * hardware config, i.e. hardware audio formats. + */ +struct snd_tplg_hw_config_template { +	int id;                         /* unique ID - - used to match */ +	unsigned int fmt;               /* SND_SOC_DAI_FORMAT_ format value */ +	unsigned char clock_gated;      /* SND_SOC_TPLG_DAI_CLK_GATE_ value */ +	unsigned char  invert_bclk;     /* 1 for inverted BCLK, 0 for normal */ +	unsigned char  invert_fsync;    /* 1 for inverted frame clock, 0 for normal */ +	unsigned char  bclk_master;     /* SND_SOC_TPLG_BCLK_ value */ +	unsigned char  fsync_master;    /* SND_SOC_TPLG_FSYNC_ value */ +	unsigned char  mclk_direction;  /* SND_SOC_TPLG_MCLK_ value */ +	unsigned short reserved;        /* for 32bit alignment */ +	unsigned int mclk_rate;	        /* MCLK or SYSCLK freqency in Hz */ +	unsigned int bclk_rate;	        /* BCLK freqency in Hz */ +	unsigned int fsync_rate;        /* frame clock in Hz */ +	unsigned int tdm_slots;         /* number of TDM slots in use */ +	unsigned int tdm_slot_width;    /* width in bits for each slot */ +	unsigned int tx_slots;          /* bit mask for active Tx slots */ +	unsigned int rx_slots;          /* bit mask for active Rx slots */ +	unsigned int tx_channels;       /* number of Tx channels */ +	unsigned int *tx_chanmap;       /* array of slot number */ +	unsigned int rx_channels;       /* number of Rx channels */ +	unsigned int *rx_chanmap;       /* array of slot number */ +}; + +/** \struct snd_tplg_dai_template + * \brief Template type for physical DAI. + * It can be used to configure backend DAIs for DPCM. + */ +struct snd_tplg_dai_template { +	const char *dai_name;	/*!< DAI name */ +	unsigned int dai_id;	/*!< unique ID - used to match */ +	unsigned int playback;	/*!< supports playback mode */ +	unsigned int capture;	/*!< supports capture mode */ +	struct snd_tplg_stream_caps_template *caps[2]; /*!< playback & capture for DAI */ +	unsigned int flag_mask; /*!< bitmask of flags to configure */ +	unsigned int flags;	/*!< SND_SOC_TPLG_DAI_FLGBIT_* */ +	struct snd_soc_tplg_private *priv;	/*!< private data */ + +}; + +/** \struct snd_tplg_link_template + * \brief Template type for physical DAI Links. + */ +struct snd_tplg_link_template { +	const char *name;	/*!< link name, used to match */ +	int id;	/*!< unique ID - used to match with existing physical links */ +	const char *stream_name;        /*!< link stream name, used to match */ + +	int num_streams;	/*!< number of configs */ +	struct snd_tplg_stream_template *stream;       /*!< supported configs */ + +	struct snd_tplg_hw_config_template *hw_config; /*!< supported HW configs */ +	int num_hw_configs;		/* number of hw configs */ +	int default_hw_config_id;       /* default hw config ID for init */ + +	unsigned int flag_mask;         /* bitmask of flags to configure */ +	unsigned int flags;             /* SND_SOC_TPLG_LNK_FLGBIT_* flag value */ +	struct snd_soc_tplg_private *priv; /*!< private data */ +}; + +/** \struct snd_tplg_obj_template + * \brief Generic Template Object + */ +typedef struct snd_tplg_obj_template { +	enum snd_tplg_type type;	/*!< template object type */ +	int index;		/*!< group index for object */ +	int version;		/*!< optional vendor specific version details */ +	int vendor_type;	/*!< optional vendor specific type info */ +	union { +		struct snd_tplg_widget_template *widget;	/*!< DAPM widget */ +		struct snd_tplg_mixer_template *mixer;		/*!< Mixer control */ +		struct snd_tplg_bytes_template *bytes_ctl;	/*!< Bytes control */ +		struct snd_tplg_enum_template *enum_ctl;	/*!< Enum control */ +		struct snd_tplg_graph_template *graph;		/*!< Graph elements */ +		struct snd_tplg_pcm_template *pcm;		/*!< PCM elements */ +		struct snd_tplg_link_template *link;		/*!< physical DAI Links */ +		struct snd_tplg_dai_template *dai;		/*!< Physical DAI */ +	}; +} snd_tplg_obj_template_t; + +/** + * \brief Register topology template object. + * \param tplg Topology instance. + * \param t Template object. + * \return Zero on success, otherwise a negative error code + */ +int snd_tplg_add_object(snd_tplg_t *tplg, snd_tplg_obj_template_t *t); + +/** + * \brief Build all registered topology data into binary file. + * \param tplg Topology instance. + * \param outfile Binary topology output file. + * \return Zero on success, otherwise a negative error code + */ +int snd_tplg_build(snd_tplg_t *tplg, const char *outfile); + +/** + * \brief Attach private data to topology manifest. + * \param tplg Topology instance. + * \param data Private data. + * \param len Length of data in bytes. + * \return Zero on success, otherwise a negative error code + */ +int snd_tplg_set_manifest_data(snd_tplg_t *tplg, const void *data, int len); + +/** + * \brief Set an optional vendor specific version number. + * \param tplg Topology instance. + * \param version Vendor specific version number. + * \return Zero on success, otherwise a negative error code + */ +int snd_tplg_set_version(snd_tplg_t *tplg, unsigned int version); + +/* \} */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_TOPOLOGY_H */ diff --git a/include/alsa/use-case.h b/include/alsa/use-case.h new file mode 100644 index 0000000..5cb4f31 --- /dev/null +++ b/include/alsa/use-case.h @@ -0,0 +1,433 @@ +/** + * \file include/use-case.h + * \brief use case interface for the ALSA driver + * \author Liam Girdwood <lrg@slimlogic.co.uk> + * \author Stefan Schmidt <stefan@slimlogic.co.uk> + * \author Jaroslav Kysela <perex@perex.cz> + * \author Justin Xu <justinx@slimlogic.co.uk> + * \date 2008-2010 + */ +/* + * + *  This library is free software; you can redistribute it and/or modify + *  it under the terms of the GNU Lesser General Public License as + *  published by the Free Software Foundation; either version 2.1 of + *  the License, or (at your option) any later version. + * + *  This program is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU Lesser General Public License for more details. + * + *  You should have received a copy of the GNU Lesser General Public + *  License along with this library; if not, write to the Free Software + *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + * + *  Copyright (C) 2008-2010 SlimLogic Ltd + *  Copyright (C) 2010 Wolfson Microelectronics PLC + *  Copyright (C) 2010 Texas Instruments Inc. + * + *  Support for the verb/device/modifier core logic and API, + *  command line tool and file parser was kindly sponsored by + *  Texas Instruments Inc. + *  Support for multiple active modifiers and devices, + *  transition sequences, multiple client access and user defined use + *  cases was kindly sponsored by Wolfson Microelectronics PLC. + */ + +#ifndef __ALSA_USE_CASE_H +#define __ALSA_USE_CASE_H + +#ifdef __cplusplus +extern "C" { +#endif + +/** + *  \defgroup ucm Use Case Interface + *  The ALSA Use Case manager interface. + *  See \ref Usecase page for more details. + *  \{ + */ + +/*! \page Usecase ALSA Use Case Interface + * + * The use case manager works by configuring the sound card ALSA kcontrols to + * change the hardware digital and analog audio routing to match the requested + * device use case. The use case manager kcontrol configurations are stored in + * easy to modify text files. + * + * An audio use case can be defined by a verb and device parameter. The verb + * describes the use case action i.e. a phone call, listening to music, recording + * a conversation etc. The device describes the physical audio capture and playback + * hardware i.e. headphones, phone handset, bluetooth headset, etc. + * + * It's intended clients will mostly only need to set the use case verb and + * device for each system use case change (as the verb and device parameters + * cover most audio use cases). + * + * However there are times when a use case has to be modified at runtime. e.g. + * + *  + Incoming phone call when the device is playing music + *  + Recording sections of a phone call + *  + Playing tones during a call. + * + * In order to allow asynchronous runtime use case adaptations, we have a third + * optional modifier parameter that can be used to further configure + * the use case during live audio runtime. + * + * This interface allows clients to :- + * + *  + Query the supported use case verbs, devices and modifiers for the machine. + *  + Set and Get use case verbs, devices and modifiers for the machine. + *  + Get the ALSA PCM playback and capture device PCMs for use case verb, + *     use case device and modifier. + *  + Get the TQ parameter for each use case verb, use case device and + *     modifier. + *  + Get the ALSA master playback and capture volume/switch kcontrols + *     for each use case. + */ + + +/* + * Use Case Verb. + * + * The use case verb is the main device audio action. e.g. the "HiFi" use + * case verb will configure the audio hardware for HiFi Music playback + * and capture. + */ +#define SND_USE_CASE_VERB_INACTIVE		"Inactive"		/**< Inactive Verb */ +#define SND_USE_CASE_VERB_HIFI			"HiFi"			/**< HiFi Verb */ +#define SND_USE_CASE_VERB_HIFI_LOW_POWER	"HiFi Low Power"	/**< HiFi Low Power Verb */ +#define SND_USE_CASE_VERB_VOICE			"Voice"			/**< Voice Verb */ +#define SND_USE_CASE_VERB_VOICE_LOW_POWER	"Voice Low Power"	/**< Voice Low Power Verb */ +#define SND_USE_CASE_VERB_VOICECALL		"Voice Call"		/**< Voice Call Verb */ +#define SND_USE_CASE_VERB_IP_VOICECALL		"Voice Call IP"		/**< Voice Call IP Verb */ +#define SND_USE_CASE_VERB_ANALOG_RADIO		"FM Analog Radio"	/**< FM Analog Radio Verb */ +#define SND_USE_CASE_VERB_DIGITAL_RADIO		"FM Digital Radio"	/**< FM Digital Radio Verb */ +/* add new verbs to end of list */ + + +/* + * Use Case Device. + * + * Physical system devices the render and capture audio. Devices can be OR'ed + * together to support audio on simultaneous devices. + */ +#define SND_USE_CASE_DEV_NONE		"None"		/**< None Device */ +#define SND_USE_CASE_DEV_SPEAKER	"Speaker"	/**< Speaker Device */ +#define SND_USE_CASE_DEV_LINE		"Line"		/**< Line Device */ +#define SND_USE_CASE_DEV_HEADPHONES	"Headphones"	/**< Headphones Device */ +#define SND_USE_CASE_DEV_HEADSET	"Headset"	/**< Headset Device */ +#define SND_USE_CASE_DEV_HANDSET	"Handset"	/**< Handset Device */ +#define SND_USE_CASE_DEV_BLUETOOTH	"Bluetooth"	/**< Bluetooth Device */ +#define SND_USE_CASE_DEV_EARPIECE	"Earpiece"	/**< Earpiece Device */ +#define SND_USE_CASE_DEV_SPDIF		"SPDIF"		/**< SPDIF Device */ +#define SND_USE_CASE_DEV_HDMI		"HDMI"		/**< HDMI Device */ +/* add new devices to end of list */ + + +/* + * Use Case Modifiers. + * + * The use case modifier allows runtime configuration changes to deal with + * asynchronous events. + * + * e.g. to record a voice call :- + *  1. Set verb to SND_USE_CASE_VERB_VOICECALL (for voice call) + *  2. Set modifier SND_USE_CASE_MOD_CAPTURE_VOICE when capture required. + *  3. Call snd_use_case_get("CapturePCM") to get ALSA source PCM name + *     with captured voice pcm data. + * + * e.g. to play a ring tone when listenin to MP3 Music :- + *  1. Set verb to SND_USE_CASE_VERB_HIFI (for MP3 playback) + *  2. Set modifier to SND_USE_CASE_MOD_PLAY_TONE when incoming call happens. + *  3. Call snd_use_case_get("PlaybackPCM") to get ALSA PCM sink name for + *     ringtone pcm data. + */ +#define SND_USE_CASE_MOD_CAPTURE_VOICE		"Capture Voice"		/**< Capture Voice Modifier */ +#define SND_USE_CASE_MOD_CAPTURE_MUSIC		"Capture Music"		/**< Capture Music Modifier */ +#define SND_USE_CASE_MOD_PLAY_MUSIC		"Play Music"		/**< Play Music Modifier */ +#define SND_USE_CASE_MOD_PLAY_VOICE		"Play Voice"		/**< Play Voice Modifier */ +#define SND_USE_CASE_MOD_PLAY_TONE		"Play Tone"		/**< Play Tone Modifier */ +#define SND_USE_CASE_MOD_ECHO_REF		"Echo Reference"	/**< Echo Reference Modifier */ +/* add new modifiers to end of list */ + + +/** + * TQ - Tone Quality + * + * The interface allows clients to determine the audio TQ required for each + * use case verb and modifier. It's intended as an optional hint to the + * audio driver in order to lower power consumption. + * + */ +#define SND_USE_CASE_TQ_MUSIC		"Music"		/**< Music Tone Quality */ +#define SND_USE_CASE_TQ_VOICE		"Voice"		/**< Voice Tone Quality */ +#define SND_USE_CASE_TQ_TONES		"Tones"		/**< Tones Tone Quality */ + +/** use case container */ +typedef struct snd_use_case_mgr snd_use_case_mgr_t; + +/** + * \brief Create an identifier + * \param fmt Format (sprintf like) + * \param ... Optional arguments for sprintf like format + * \return Allocated string identifier or NULL on error + */ +char *snd_use_case_identifier(const char *fmt, ...); + +/** + * \brief Free a string list + * \param list The string list to free + * \param items Count of strings + * \return Zero if success, otherwise a negative error code + */ +int snd_use_case_free_list(const char *list[], int items); + +/** + * \brief Obtain a list of entries + * \param uc_mgr Use case manager (may be NULL - card list) + * \param identifier (may be NULL - card list) + * \param list Returned allocated list + * \return Number of list entries if success, otherwise a negative error code + * + * Defined identifiers: + *   - NULL			- get card list + *				 (in pair cardname+comment) + *   - _verbs			- get verb list + *				  (in pair verb+comment) + *   - _devices[/{verb}]	- get list of supported devices + *				  (in pair device+comment) + *   - _modifiers[/{verb}]	- get list of supported modifiers + *				  (in pair modifier+comment) + *   - TQ[/{verb}]		- get list of TQ identifiers + *   - _enadevs			- get list of enabled devices + *   - _enamods			- get list of enabled modifiers + * + *   - _supporteddevs/{modifier}|{device}[/{verb}]   - list of supported devices + *   - _conflictingdevs/{modifier}|{device}[/{verb}] - list of conflicting devices + * + *   Note that at most one of the supported/conflicting devs lists has + *   any entries, and when neither is present, all devices are supported. + * + */ +int snd_use_case_get_list(snd_use_case_mgr_t *uc_mgr, +                          const char *identifier, +                          const char **list[]); + + +/** + * \brief Get current - string + * \param uc_mgr Use case manager + * \param identifier  + * \param value Value pointer + * \return Zero if success, otherwise a negative error code + * + * Note: The returned string is dynamically allocated, use free() to + * deallocate this string. (Yes, the value parameter shouldn't be marked as + * "const", but it's too late to fix it, sorry about that.) + * + * Known identifiers: + *   - NULL 		- return current card + *   - _verb		- return current verb + *   - _file		- return configuration file loaded for current card + * + *   - [=]{NAME}[/[{modifier}|{/device}][/{verb}]] + *                      - value identifier {NAME} + *                      - Search starts at given modifier or device if any, + *                          else at a verb + *                      - Search starts at given verb if any, + *                          else current verb + *                      - Searches modifier/device, then verb, then defaults + *                      - Specify a leading "=" to search only the exact + *                        device/modifier/verb specified, and not search + *                        through each object in turn. + *                      - Examples: + *                          - "PlaybackPCM/Play Music" + *                          - "CapturePCM/SPDIF" + *                          - From ValueDefaults only: + *                              "=Variable" + *                          - From current active verb: + *                              "=Variable//" + *                          - From verb "Verb": + *                              "=Variable//Verb" + *                          - From "Modifier" in current active verb: + *                              "=Variable/Modifier/" + *                          - From "Modifier" in "Verb": + *                              "=Variable/Modifier/Verb" + * + * Recommended names for values: + *   - TQ + *      - Tone Quality + *   - PlaybackPCM + *      - full PCM playback device name + *   - PlaybackPCMIsDummy + *      - Valid values: "yes" and "no". If set to "yes", the PCM named by the + *        PlaybackPCM value is a dummy device, meaning that opening it enables + *        an audio path in the hardware, but writing to the PCM device has no + *        effect. + *   - CapturePCM + *      - full PCM capture device name + *   - CapturePCMIsDummy + *      - Valid values: "yes" and "no". If set to "yes", the PCM named by the + *        CapturePCM value is a dummy device, meaning that opening it enables + *        an audio path in the hardware, but reading from the PCM device has no + *        effect. + *   - PlaybackRate + *      - playback device sample rate + *   - PlaybackChannels + *      - playback device channel count + *   - PlaybackCTL + *      - playback control device name + *   - PlaybackVolume + *      - playback control volume ID string + *   - PlaybackSwitch + *      - playback control switch ID string + *   - CaptureRate + *      - capture device sample rate + *   - CaptureChannels + *      - capture device channel count + *   - CaptureCTL + *      - capture control device name + *   - CaptureVolume + *      - capture control volume ID string + *   - CaptureSwitch + *      - capture control switch ID string + *   - PlaybackMixer + *      - name of playback mixer + *   - PlaybackMixerID + *      - mixer playback ID + *   - CaptureMixer + *      - name of capture mixer + *   - CaptureMixerID + *      - mixer capture ID + *   - JackControl, JackDev, JackHWMute + *      - Jack information for a device. The jack status can be reported via + *        a kcontrol and/or via an input device. **JackControl** is the + *        kcontrol name of the jack, and **JackDev** is the input device id of + *        the jack (if the full input device path is /dev/input/by-id/foo, the + *        JackDev value should be "foo"). UCM configuration files should + *        contain both JackControl and JackDev when possible, because + *        applications are likely to support only one or the other. + * + *        If **JackHWMute** is set, it indicates that when the jack is plugged + *        in, the hardware automatically mutes some other device(s). The + *        JackHWMute value is a space-separated list of device names (this + *        isn't compatible with device names with spaces in them, so don't use + *        such device names!). Note that JackHWMute should be used only when + *        the hardware enforces the automatic muting. If the hardware doesn't + *        enforce any muting, it may still be tempting to set JackHWMute to + *        trick upper software layers to e.g. automatically mute speakers when + *        headphones are plugged in, but that's application policy + *        configuration that doesn't belong to UCM configuration files. + */ +int snd_use_case_get(snd_use_case_mgr_t *uc_mgr, +                     const char *identifier, +                     const char **value); + +/** + * \brief Get current - integer + * \param uc_mgr Use case manager + * \param identifier  + * \param value result  + * \return Zero if success, otherwise a negative error code + * + * Known identifiers: + *   - _devstatus/{device}	- return status for given device + *   - _modstatus/{modifier}	- return status for given modifier + */ +int snd_use_case_geti(snd_use_case_mgr_t *uc_mgr, +		      const char *identifier, +		      long *value); + +/** + * \brief Set new + * \param uc_mgr Use case manager + * \param identifier + * \param value Value + * \return Zero if success, otherwise a negative error code + * + * Known identifiers: + *   - _verb			- set current verb = value + *   - _enadev			- enable given device = value + *   - _disdev			- disable given device = value + *   - _swdev/{old_device}	- new_device = value + *				  - disable old_device and then enable new_device + *				  - if old_device is not enabled just return + *				  - check transmit sequence firstly + *   - _enamod			- enable given modifier = value + *   - _dismod			- disable given modifier = value + *   - _swmod/{old_modifier}	- new_modifier = value + *				  - disable old_modifier and then enable new_modifier + *				  - if old_modifier is not enabled just return + *				  - check transmit sequence firstly + */ +int snd_use_case_set(snd_use_case_mgr_t *uc_mgr, +                     const char *identifier, +                     const char *value); + +/** + * \brief Open and initialise use case core for sound card + * \param uc_mgr Returned use case manager pointer + * \param card_name Sound card name. + * \return zero if success, otherwise a negative error code + */ +int snd_use_case_mgr_open(snd_use_case_mgr_t **uc_mgr, const char *card_name); + + +/** + * \brief Reload and re-parse use case configuration files for sound card. + * \param uc_mgr Use case manager + * \return zero if success, otherwise a negative error code + */ +int snd_use_case_mgr_reload(snd_use_case_mgr_t *uc_mgr); + +/** + * \brief Close use case manager + * \param uc_mgr Use case manager + * \return zero if success, otherwise a negative error code + */ +int snd_use_case_mgr_close(snd_use_case_mgr_t *uc_mgr); + +/** + * \brief Reset use case manager verb, device, modifier to deafult settings. + * \param uc_mgr Use case manager + * \return zero if success, otherwise a negative error code + */ +int snd_use_case_mgr_reset(snd_use_case_mgr_t *uc_mgr); + +/* + * helper functions + */ + +/** + * \brief Obtain a list of cards + * \param list Returned allocated list + * \return Number of list entries if success, otherwise a negative error code + */ +static __inline__ int snd_use_case_card_list(const char **list[]) +{ +	return snd_use_case_get_list(NULL, NULL, list); +} + +/** + * \brief Obtain a list of verbs + * \param uc_mgr Use case manager + * \param list Returned list of verbs + * \return Number of list entries if success, otherwise a negative error code + */ +static __inline__ int snd_use_case_verb_list(snd_use_case_mgr_t *uc_mgr, +					 const char **list[]) +{ +	return snd_use_case_get_list(uc_mgr, "_verbs", list); +} + +/** + *  \} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __ALSA_USE_CASE_H */ diff --git a/include/alsa/version.h b/include/alsa/version.h new file mode 100644 index 0000000..d640ad5 --- /dev/null +++ b/include/alsa/version.h @@ -0,0 +1,15 @@ +/* + *  version.h + */ + +#define SND_LIB_MAJOR		1 /**< major number of library version */ +#define SND_LIB_MINOR		1 /**< minor number of library version */ +#define SND_LIB_SUBMINOR	7 /**< subminor number of library version */ +#define SND_LIB_EXTRAVER	1000000 /**< extra version number, used mainly for betas */ +/** library version */ +#define SND_LIB_VERSION		((SND_LIB_MAJOR<<16)|\ +				 (SND_LIB_MINOR<<8)|\ +				  SND_LIB_SUBMINOR) +/** library version (string) */ +#define SND_LIB_VERSION_STR	"1.1.7" + | 
