Include ALSA headers
This commit is contained in:
parent
96fde22b65
commit
883e8fa00f
39 changed files with 10251 additions and 2 deletions
|
@ -16,11 +16,11 @@ Golang bindings for [raylib](http://www.raylib.com/), a simple and easy-to-use l
|
||||||
|
|
||||||
##### Ubuntu
|
##### Ubuntu
|
||||||
|
|
||||||
apt-get install libasound2-dev libgl1-mesa-dev libxi-dev libxinerama-dev libxcursor-dev libxxf86vm-dev libxrandr-dev
|
apt-get install libgl1-mesa-dev libxi-dev libxinerama-dev libxcursor-dev libxxf86vm-dev libxrandr-dev
|
||||||
|
|
||||||
##### Fedora
|
##### Fedora
|
||||||
|
|
||||||
dnf install alsa-lib-devel mesa-libGL-devel libXi-devel libXcursor-devel libXrandr-devel libXinerama-devel
|
dnf install mesa-libGL-devel libXi-devel libXcursor-devel libXrandr-devel libXinerama-devel
|
||||||
|
|
||||||
##### macOS
|
##### macOS
|
||||||
|
|
||||||
|
|
55
raylib/external/alsa/alisp.h
vendored
Normal file
55
raylib/external/alsa/alisp.h
vendored
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
/*
|
||||||
|
* ALSA lisp implementation
|
||||||
|
* Copyright (c) 2003 by Jaroslav Kysela <perex@perex.cz>
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct alisp_cfg {
|
||||||
|
int verbose: 1,
|
||||||
|
warning: 1,
|
||||||
|
debug: 1;
|
||||||
|
snd_input_t *in; /* program code */
|
||||||
|
snd_output_t *out; /* program output */
|
||||||
|
snd_output_t *eout; /* error output */
|
||||||
|
snd_output_t *vout; /* verbose output */
|
||||||
|
snd_output_t *wout; /* warning output */
|
||||||
|
snd_output_t *dout; /* debug output */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct alisp_instance;
|
||||||
|
struct alisp_object;
|
||||||
|
struct alisp_seq_iterator;
|
||||||
|
|
||||||
|
struct alisp_cfg *alsa_lisp_default_cfg(snd_input_t *input);
|
||||||
|
void alsa_lisp_default_cfg_free(struct alisp_cfg *cfg);
|
||||||
|
int alsa_lisp(struct alisp_cfg *cfg, struct alisp_instance **instance);
|
||||||
|
void alsa_lisp_free(struct alisp_instance *instance);
|
||||||
|
int alsa_lisp_function(struct alisp_instance *instance, struct alisp_seq_iterator **result,
|
||||||
|
const char *id, const char *args, ...)
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
|
__attribute__ ((format (printf, 4, 5)))
|
||||||
|
#endif
|
||||||
|
;
|
||||||
|
void alsa_lisp_result_free(struct alisp_instance *instance,
|
||||||
|
struct alisp_seq_iterator *result);
|
||||||
|
int alsa_lisp_seq_first(struct alisp_instance *instance, const char *id,
|
||||||
|
struct alisp_seq_iterator **seq);
|
||||||
|
int alsa_lisp_seq_next(struct alisp_seq_iterator **seq);
|
||||||
|
int alsa_lisp_seq_count(struct alisp_seq_iterator *seq);
|
||||||
|
int alsa_lisp_seq_integer(struct alisp_seq_iterator *seq, long *val);
|
||||||
|
int alsa_lisp_seq_pointer(struct alisp_seq_iterator *seq, const char *ptr_id, void **ptr);
|
310
raylib/external/alsa/asoundef.h
vendored
Normal file
310
raylib/external/alsa/asoundef.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
65
raylib/external/alsa/asoundlib.h
vendored
Normal file
65
raylib/external/alsa/asoundlib.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
214
raylib/external/alsa/conf.h
vendored
Normal file
214
raylib/external/alsa/conf.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
622
raylib/external/alsa/control.h
vendored
Normal file
622
raylib/external/alsa/control.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
286
raylib/external/alsa/control_external.h
vendored
Normal file
286
raylib/external/alsa/control_external.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
85
raylib/external/alsa/error.h
vendored
Normal file
85
raylib/external/alsa/error.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
161
raylib/external/alsa/global.h
vendored
Normal file
161
raylib/external/alsa/global.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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);
|
||||||
|
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 */
|
172
raylib/external/alsa/hwdep.h
vendored
Normal file
172
raylib/external/alsa/hwdep.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
83
raylib/external/alsa/input.h
vendored
Normal file
83
raylib/external/alsa/input.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
317
raylib/external/alsa/mixer.h
vendored
Normal file
317
raylib/external/alsa/mixer.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
112
raylib/external/alsa/mixer_abst.h
vendored
Normal file
112
raylib/external/alsa/mixer_abst.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
86
raylib/external/alsa/output.h
vendored
Normal file
86
raylib/external/alsa/output.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
1329
raylib/external/alsa/pcm.h
vendored
Normal file
1329
raylib/external/alsa/pcm.h
vendored
Normal file
File diff suppressed because it is too large
Load diff
70
raylib/external/alsa/pcm_external.h
vendored
Normal file
70
raylib/external/alsa/pcm_external.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
206
raylib/external/alsa/pcm_extplug.h
vendored
Normal file
206
raylib/external/alsa/pcm_extplug.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
234
raylib/external/alsa/pcm_ioplug.h
vendored
Normal file
234
raylib/external/alsa/pcm_ioplug.h
vendored
Normal file
|
@ -0,0 +1,234 @@
|
||||||
|
/**
|
||||||
|
* \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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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_extplug_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
|
||||||
|
*/
|
||||||
|
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);
|
||||||
|
|
||||||
|
/** \} */
|
||||||
|
|
||||||
|
#endif /* __ALSA_PCM_IOPLUG_H */
|
230
raylib/external/alsa/pcm_old.h
vendored
Normal file
230
raylib/external/alsa/pcm_old.h
vendored
Normal file
|
@ -0,0 +1,230 @@
|
||||||
|
/*
|
||||||
|
* Old ALSA 0.9.x API
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef ALSA_PCM_OLD_HW_PARAMS_API
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_access,snd_pcm_hw_params_get_access@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_access_first,snd_pcm_hw_params_set_access_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_access_last,snd_pcm_hw_params_set_access_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_access(const snd_pcm_hw_params_t *params);
|
||||||
|
int snd_pcm_hw_params_test_access(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t val);
|
||||||
|
int snd_pcm_hw_params_set_access(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t val);
|
||||||
|
snd_pcm_access_t snd_pcm_hw_params_set_access_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
snd_pcm_access_t snd_pcm_hw_params_set_access_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
int snd_pcm_hw_params_set_access_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_mask_t *mask);
|
||||||
|
void snd_pcm_hw_params_get_access_mask(snd_pcm_hw_params_t *params, snd_pcm_access_mask_t *mask);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_format,snd_pcm_hw_params_get_format@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_format_first,snd_pcm_hw_params_set_format_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_format_last,snd_pcm_hw_params_set_format_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_format(const snd_pcm_hw_params_t *params);
|
||||||
|
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);
|
||||||
|
snd_pcm_format_t snd_pcm_hw_params_set_format_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
snd_pcm_format_t snd_pcm_hw_params_set_format_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
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);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_subformat,snd_pcm_hw_params_get_subformat@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_subformat_first,snd_pcm_hw_params_set_subformat_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_subformat_last,snd_pcm_hw_params_set_subformat_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_test_subformat(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t val);
|
||||||
|
int snd_pcm_hw_params_get_subformat(const snd_pcm_hw_params_t *params);
|
||||||
|
int snd_pcm_hw_params_set_subformat(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t val);
|
||||||
|
snd_pcm_subformat_t snd_pcm_hw_params_set_subformat_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
snd_pcm_subformat_t snd_pcm_hw_params_set_subformat_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
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);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_channels,snd_pcm_hw_params_get_channels@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_channels_min,snd_pcm_hw_params_get_channels_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_channels_max,snd_pcm_hw_params_get_channels_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_channels_near,snd_pcm_hw_params_set_channels_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_channels_first,snd_pcm_hw_params_set_channels_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_channels_last,snd_pcm_hw_params_set_channels_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_channels(const snd_pcm_hw_params_t *params);
|
||||||
|
unsigned int snd_pcm_hw_params_get_channels_min(const snd_pcm_hw_params_t *params);
|
||||||
|
unsigned int snd_pcm_hw_params_get_channels_max(const snd_pcm_hw_params_t *params);
|
||||||
|
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);
|
||||||
|
unsigned int snd_pcm_hw_params_set_channels_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val);
|
||||||
|
unsigned int snd_pcm_hw_params_set_channels_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
unsigned int snd_pcm_hw_params_set_channels_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_rate,snd_pcm_hw_params_get_rate@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_rate_min,snd_pcm_hw_params_get_rate_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_rate_max,snd_pcm_hw_params_get_rate_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_rate_near,snd_pcm_hw_params_set_rate_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_rate_first,snd_pcm_hw_params_set_rate_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_rate_last,snd_pcm_hw_params_set_rate_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_rate(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_rate_min(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_rate_max(const snd_pcm_hw_params_t *params, 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);
|
||||||
|
unsigned int snd_pcm_hw_params_set_rate_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_rate_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_rate_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, 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);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_period_time,snd_pcm_hw_params_get_period_time@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_period_time_min,snd_pcm_hw_params_get_period_time_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_period_time_max,snd_pcm_hw_params_get_period_time_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_period_time_near,snd_pcm_hw_params_set_period_time_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_period_time_first,snd_pcm_hw_params_set_period_time_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_period_time_last,snd_pcm_hw_params_set_period_time_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_period_time(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_period_time_min(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_period_time_max(const snd_pcm_hw_params_t *params, 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);
|
||||||
|
unsigned int snd_pcm_hw_params_set_period_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_period_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_period_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_period_size,snd_pcm_hw_params_get_period_size@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_period_size_min,snd_pcm_hw_params_get_period_size_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_period_size_max,snd_pcm_hw_params_get_period_size_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_period_size_near,snd_pcm_hw_params_set_period_size_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_period_size_first,snd_pcm_hw_params_set_period_size_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_period_size_last,snd_pcm_hw_params_set_period_size_last@ALSA_0.9");
|
||||||
|
|
||||||
|
snd_pcm_sframes_t snd_pcm_hw_params_get_period_size(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_get_period_size_min(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_get_period_size_max(const snd_pcm_hw_params_t *params, 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);
|
||||||
|
snd_pcm_uframes_t 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);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_set_period_size_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_set_period_size_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
int snd_pcm_hw_params_set_period_size_integer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_periods,snd_pcm_hw_params_get_periods@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_periods_min,snd_pcm_hw_params_get_periods_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_periods_max,snd_pcm_hw_params_get_periods_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_periods_near,snd_pcm_hw_params_set_periods_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_periods_first,snd_pcm_hw_params_set_periods_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_periods_last,snd_pcm_hw_params_set_periods_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_periods(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_periods_min(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_periods_max(const snd_pcm_hw_params_t *params, 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);
|
||||||
|
unsigned int snd_pcm_hw_params_set_periods_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_periods_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_periods_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
int snd_pcm_hw_params_set_periods_integer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_buffer_time,snd_pcm_hw_params_get_buffer_time@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_buffer_time_min,snd_pcm_hw_params_get_buffer_time_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_buffer_time_max,snd_pcm_hw_params_get_buffer_time_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_buffer_time_near,snd_pcm_hw_params_set_buffer_time_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_buffer_time_first,snd_pcm_hw_params_set_buffer_time_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_buffer_time_last,snd_pcm_hw_params_set_buffer_time_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_buffer_time(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_buffer_time_min(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_buffer_time_max(const snd_pcm_hw_params_t *params, 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);
|
||||||
|
unsigned int snd_pcm_hw_params_set_buffer_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_buffer_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_buffer_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_buffer_size,snd_pcm_hw_params_get_buffer_size@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_buffer_size_min,snd_pcm_hw_params_get_buffer_size_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_buffer_size_max,snd_pcm_hw_params_get_buffer_size_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_buffer_size_near,snd_pcm_hw_params_set_buffer_size_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_buffer_size_first,snd_pcm_hw_params_set_buffer_size_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_buffer_size_last,snd_pcm_hw_params_set_buffer_size_last@ALSA_0.9");
|
||||||
|
|
||||||
|
snd_pcm_sframes_t snd_pcm_hw_params_get_buffer_size(const snd_pcm_hw_params_t *params);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_get_buffer_size_min(const snd_pcm_hw_params_t *params);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_get_buffer_size_max(const snd_pcm_hw_params_t *params);
|
||||||
|
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);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_set_buffer_size_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_set_buffer_size_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
snd_pcm_uframes_t snd_pcm_hw_params_set_buffer_size_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_hw_params_get_tick_time,snd_pcm_hw_params_get_tick_time@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_tick_time_min,snd_pcm_hw_params_get_tick_time_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_get_tick_time_max,snd_pcm_hw_params_get_tick_time_max@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_tick_time_near,snd_pcm_hw_params_set_tick_time_near@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_tick_time_first,snd_pcm_hw_params_set_tick_time_first@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_hw_params_set_tick_time_last,snd_pcm_hw_params_set_tick_time_last@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_hw_params_get_tick_time(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_tick_time_min(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_get_tick_time_max(const snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
int snd_pcm_hw_params_test_tick_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
|
||||||
|
int snd_pcm_hw_params_set_tick_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
|
||||||
|
int snd_pcm_hw_params_set_tick_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
|
||||||
|
int snd_pcm_hw_params_set_tick_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
|
||||||
|
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);
|
||||||
|
unsigned int snd_pcm_hw_params_set_tick_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_tick_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
unsigned int snd_pcm_hw_params_set_tick_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, int *dir);
|
||||||
|
|
||||||
|
#endif /* ALSA_PCM_OLD_HW_PARAMS_API */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef ALSA_PCM_OLD_SW_PARAMS_API
|
||||||
|
|
||||||
|
asm(".symver snd_pcm_sw_params_get_tstamp_mode,snd_pcm_sw_params_get_tstamp_mode@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_sleep_min,snd_pcm_sw_params_get_sleep_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_avail_min,snd_pcm_sw_params_get_avail_min@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_xfer_align,snd_pcm_sw_params_get_xfer_align@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_start_threshold,snd_pcm_sw_params_get_start_threshold@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_stop_threshold,snd_pcm_sw_params_get_stop_threshold@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_silence_threshold,snd_pcm_sw_params_get_silence_threshold@ALSA_0.9");
|
||||||
|
asm(".symver snd_pcm_sw_params_get_silence_size,snd_pcm_sw_params_get_silence_size@ALSA_0.9");
|
||||||
|
|
||||||
|
int snd_pcm_sw_params_set_tstamp_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_tstamp_t val);
|
||||||
|
snd_pcm_tstamp_t snd_pcm_sw_params_get_tstamp_mode(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_sleep_min(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, unsigned int val);
|
||||||
|
unsigned int snd_pcm_sw_params_get_sleep_min(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_avail_min(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_sw_params_get_avail_min(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_xfer_align(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_sw_params_get_xfer_align(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_start_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_sw_params_get_start_threshold(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_stop_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_sw_params_get_stop_threshold(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_silence_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_sw_params_get_silence_threshold(const snd_pcm_sw_params_t *params);
|
||||||
|
int snd_pcm_sw_params_set_silence_size(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
|
||||||
|
snd_pcm_uframes_t snd_pcm_sw_params_get_silence_size(const snd_pcm_sw_params_t *params);
|
||||||
|
|
||||||
|
#endif /* ALSA_PCM_OLD_SW_PARAMS_API */
|
202
raylib/external/alsa/pcm_plugin.h
vendored
Normal file
202
raylib/external/alsa/pcm_plugin.h
vendored
Normal file
|
@ -0,0 +1,202 @@
|
||||||
|
/**
|
||||||
|
* \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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __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 */
|
156
raylib/external/alsa/pcm_rate.h
vendored
Normal file
156
raylib/external/alsa/pcm_rate.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
159
raylib/external/alsa/rawmidi.h
vendored
Normal file
159
raylib/external/alsa/rawmidi.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
739
raylib/external/alsa/seq.h
vendored
Normal file
739
raylib/external/alsa/seq.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
325
raylib/external/alsa/seq_event.h
vendored
Normal file
325
raylib/external/alsa/seq_event.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
65
raylib/external/alsa/seq_midi_event.h
vendored
Normal file
65
raylib/external/alsa/seq_midi_event.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
490
raylib/external/alsa/seqmid.h
vendored
Normal file
490
raylib/external/alsa/seqmid.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
551
raylib/external/alsa/sound/asoc.h
vendored
Normal file
551
raylib/external/alsa/sound/asoc.h
vendored
Normal file
|
@ -0,0 +1,551 @@
|
||||||
|
/*
|
||||||
|
* 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 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)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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; /* 1 if clock can be gated to save power */
|
||||||
|
__u8 invert_bclk; /* 1 for inverted BCLK, 0 for normal */
|
||||||
|
__u8 invert_fsync; /* 1 for inverted frame clock, 0 for normal */
|
||||||
|
__u8 bclk_master; /* 1 for master of BCLK, 0 for slave */
|
||||||
|
__u8 fsync_master; /* 1 for master of FSYNC, 0 for slave */
|
||||||
|
__u8 mclk_direction; /* 0 for input, 1 for output */
|
||||||
|
__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
|
134
raylib/external/alsa/sound/asound_fm.h
vendored
Normal file
134
raylib/external/alsa/sound/asound_fm.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
349
raylib/external/alsa/sound/emu10k1.h
vendored
Normal file
349
raylib/external/alsa/sound/emu10k1.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
113
raylib/external/alsa/sound/hdsp.h
vendored
Normal file
113
raylib/external/alsa/sound/hdsp.h
vendored
Normal file
|
@ -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 */
|
229
raylib/external/alsa/sound/hdspm.h
vendored
Normal file
229
raylib/external/alsa/sound/hdspm.h
vendored
Normal file
|
@ -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
|
115
raylib/external/alsa/sound/sb16_csp.h
vendored
Normal file
115
raylib/external/alsa/sound/sb16_csp.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
21
raylib/external/alsa/sound/sscape_ioctl.h
vendored
Normal file
21
raylib/external/alsa/sound/sscape_ioctl.h
vendored
Normal file
|
@ -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
|
100
raylib/external/alsa/sound/tlv.h
vendored
Normal file
100
raylib/external/alsa/sound/tlv.h
vendored
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
/*
|
||||||
|
* 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__ }))
|
||||||
|
|
||||||
|
#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) \
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 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) \
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 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) \
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 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
|
42
raylib/external/alsa/sound/type_compat.h
vendored
Normal file
42
raylib/external/alsa/sound/type_compat.h
vendored
Normal file
|
@ -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 */
|
259
raylib/external/alsa/timer.h
vendored
Normal file
259
raylib/external/alsa/timer.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
||||||
|
|
1115
raylib/external/alsa/topology.h
vendored
Normal file
1115
raylib/external/alsa/topology.h
vendored
Normal file
File diff suppressed because it is too large
Load diff
433
raylib/external/alsa/use-case.h
vendored
Normal file
433
raylib/external/alsa/use-case.h
vendored
Normal file
|
@ -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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 */
|
15
raylib/external/alsa/version.h
vendored
Normal file
15
raylib/external/alsa/version.h
vendored
Normal file
|
@ -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 5 /**< 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.5"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue