1 /** 2 * \file include/rawmidi.h 3 * \brief Application interface library for the ALSA driver 4 * \author Jaroslav Kysela <perex@perex.cz> 5 * \author Abramo Bagnara <abramo@alsa-project.org> 6 * \author Takashi Iwai <tiwai@suse.de> 7 * \date 1998-2001 8 * 9 * Application interface library for the ALSA driver 10 */ 11 /* 12 * This library is free software; you can redistribute it and/or modify 13 * it under the terms of the GNU Lesser General Public License as 14 * published by the Free Software Foundation; either version 2.1 of 15 * the License, or (at your option) any later version. 16 * 17 * This program is distributed in the hope that it will be useful, 18 * but WITHOUT ANY WARRANTY; without even the implied warranty of 19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 20 * GNU Lesser General Public License for more details. 21 * 22 * You should have received a copy of the GNU Lesser General Public 23 * License along with this library; if not, write to the Free Software 24 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 25 * 26 */ 27 28 #ifndef __ALSA_RAWMIDI_H 29 #define __ALSA_RAWMIDI_H 30 31 #ifdef __cplusplus 32 extern "C" { 33 #endif 34 35 /** 36 * \defgroup RawMidi RawMidi Interface 37 * The RawMidi Interface. See \ref rawmidi page for more details. 38 * \{ 39 */ 40 41 /** dlsym version for interface entry callback */ 42 #define SND_RAWMIDI_DLSYM_VERSION _dlsym_rawmidi_001 43 44 /** RawMidi information container */ 45 typedef struct _snd_rawmidi_info snd_rawmidi_info_t; 46 /** RawMidi settings container */ 47 typedef struct _snd_rawmidi_params snd_rawmidi_params_t; 48 /** RawMidi status container */ 49 typedef struct _snd_rawmidi_status snd_rawmidi_status_t; 50 51 /** RawMidi stream (direction) */ 52 typedef enum _snd_rawmidi_stream { 53 /** Output stream */ 54 SND_RAWMIDI_STREAM_OUTPUT = 0, 55 /** Input stream */ 56 SND_RAWMIDI_STREAM_INPUT, 57 SND_RAWMIDI_STREAM_LAST = SND_RAWMIDI_STREAM_INPUT 58 } snd_rawmidi_stream_t; 59 60 /** Append (flag to open mode) \hideinitializer */ 61 #define SND_RAWMIDI_APPEND 0x0001 62 /** Non blocking mode (flag to open mode) \hideinitializer */ 63 #define SND_RAWMIDI_NONBLOCK 0x0002 64 /** Write sync mode (Flag to open mode) \hideinitializer */ 65 #define SND_RAWMIDI_SYNC 0x0004 66 67 /** RawMidi handle */ 68 typedef struct _snd_rawmidi snd_rawmidi_t; 69 70 /** RawMidi type */ 71 typedef enum _snd_rawmidi_type { 72 /** Kernel level RawMidi */ 73 SND_RAWMIDI_TYPE_HW, 74 /** Shared memory client RawMidi (not yet implemented) */ 75 SND_RAWMIDI_TYPE_SHM, 76 /** INET client RawMidi (not yet implemented) */ 77 SND_RAWMIDI_TYPE_INET, 78 /** Virtual (sequencer) RawMidi */ 79 SND_RAWMIDI_TYPE_VIRTUAL 80 } snd_rawmidi_type_t; 81 82 /** Type of clock used with rawmidi timestamp */ 83 typedef enum _snd_rawmidi_clock { 84 SND_RAWMIDI_CLOCK_NONE = 0, 85 SND_RAWMIDI_CLOCK_REALTIME = 1, 86 SND_RAWMIDI_CLOCK_MONOTONIC = 2, 87 SND_RAWMIDI_CLOCK_MONOTONIC_RAW = 3, 88 } snd_rawmidi_clock_t; 89 90 /** Select the read mode (standard or with timestamps) */ 91 typedef enum _snd_rawmidi_read_mode { 92 SND_RAWMIDI_READ_STANDARD = 0, 93 SND_RAWMIDI_READ_TSTAMP = 1, 94 } snd_rawmidi_read_mode_t; 95 96 /** rawmidi info bit flags */ 97 #define SND_RAWMIDI_INFO_UMP 0x00000008 /* rawmidi is UMP */ 98 99 int snd_rawmidi_open(snd_rawmidi_t **in_rmidi, snd_rawmidi_t **out_rmidi, 100 const char *name, int mode); 101 int snd_rawmidi_open_lconf(snd_rawmidi_t **in_rmidi, snd_rawmidi_t **out_rmidi, 102 const char *name, int mode, snd_config_t *lconf); 103 int snd_rawmidi_close(snd_rawmidi_t *rmidi); 104 int snd_rawmidi_poll_descriptors_count(snd_rawmidi_t *rmidi); 105 int snd_rawmidi_poll_descriptors(snd_rawmidi_t *rmidi, struct pollfd *pfds, unsigned int space); 106 int snd_rawmidi_poll_descriptors_revents(snd_rawmidi_t *rawmidi, struct pollfd *pfds, unsigned int nfds, unsigned short *revent); 107 int snd_rawmidi_nonblock(snd_rawmidi_t *rmidi, int nonblock); 108 size_t snd_rawmidi_info_sizeof(void); 109 /** \hideinitializer 110 * \brief allocate an invalid #snd_rawmidi_info_t using standard alloca 111 * \param ptr returned pointer 112 */ 113 #define snd_rawmidi_info_alloca(ptr) __snd_alloca(ptr, snd_rawmidi_info) 114 int snd_rawmidi_info_malloc(snd_rawmidi_info_t **ptr); 115 void snd_rawmidi_info_free(snd_rawmidi_info_t *obj); 116 void snd_rawmidi_info_copy(snd_rawmidi_info_t *dst, const snd_rawmidi_info_t *src); 117 unsigned int snd_rawmidi_info_get_device(const snd_rawmidi_info_t *obj); 118 unsigned int snd_rawmidi_info_get_subdevice(const snd_rawmidi_info_t *obj); 119 snd_rawmidi_stream_t snd_rawmidi_info_get_stream(const snd_rawmidi_info_t *obj); 120 int snd_rawmidi_info_get_card(const snd_rawmidi_info_t *obj); 121 unsigned int snd_rawmidi_info_get_flags(const snd_rawmidi_info_t *obj); 122 const char *snd_rawmidi_info_get_id(const snd_rawmidi_info_t *obj); 123 const char *snd_rawmidi_info_get_name(const snd_rawmidi_info_t *obj); 124 const char *snd_rawmidi_info_get_subdevice_name(const snd_rawmidi_info_t *obj); 125 unsigned int snd_rawmidi_info_get_subdevices_count(const snd_rawmidi_info_t *obj); 126 unsigned int snd_rawmidi_info_get_subdevices_avail(const snd_rawmidi_info_t *obj); 127 void snd_rawmidi_info_set_device(snd_rawmidi_info_t *obj, unsigned int val); 128 void snd_rawmidi_info_set_subdevice(snd_rawmidi_info_t *obj, unsigned int val); 129 void snd_rawmidi_info_set_stream(snd_rawmidi_info_t *obj, snd_rawmidi_stream_t val); 130 int snd_rawmidi_info(snd_rawmidi_t *rmidi, snd_rawmidi_info_t * info); 131 size_t snd_rawmidi_params_sizeof(void); 132 /** \hideinitializer 133 * \brief allocate an invalid #snd_rawmidi_params_t using standard alloca 134 * \param ptr returned pointer 135 */ 136 #define snd_rawmidi_params_alloca(ptr) __snd_alloca(ptr, snd_rawmidi_params) 137 int snd_rawmidi_params_malloc(snd_rawmidi_params_t **ptr); 138 void snd_rawmidi_params_free(snd_rawmidi_params_t *obj); 139 void snd_rawmidi_params_copy(snd_rawmidi_params_t *dst, const snd_rawmidi_params_t *src); 140 int snd_rawmidi_params_set_buffer_size(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params, size_t val); 141 size_t snd_rawmidi_params_get_buffer_size(const snd_rawmidi_params_t *params); 142 int snd_rawmidi_params_set_avail_min(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params, size_t val); 143 size_t snd_rawmidi_params_get_avail_min(const snd_rawmidi_params_t *params); 144 int snd_rawmidi_params_set_no_active_sensing(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params, int val); 145 int snd_rawmidi_params_get_no_active_sensing(const snd_rawmidi_params_t *params); 146 int snd_rawmidi_params_set_read_mode(const snd_rawmidi_t *rawmidi, snd_rawmidi_params_t *params, snd_rawmidi_read_mode_t val); 147 snd_rawmidi_read_mode_t snd_rawmidi_params_get_read_mode(const snd_rawmidi_params_t *params); 148 int snd_rawmidi_params_set_clock_type(const snd_rawmidi_t *rawmidi, snd_rawmidi_params_t *params, snd_rawmidi_clock_t val); 149 snd_rawmidi_clock_t snd_rawmidi_params_get_clock_type(const snd_rawmidi_params_t *params); 150 151 int snd_rawmidi_params(snd_rawmidi_t *rmidi, snd_rawmidi_params_t * params); 152 int snd_rawmidi_params_current(snd_rawmidi_t *rmidi, snd_rawmidi_params_t *params); 153 size_t snd_rawmidi_status_sizeof(void); 154 /** \hideinitializer 155 * \brief allocate an invalid #snd_rawmidi_status_t using standard alloca 156 * \param ptr returned pointer 157 */ 158 #define snd_rawmidi_status_alloca(ptr) __snd_alloca(ptr, snd_rawmidi_status) 159 int snd_rawmidi_status_malloc(snd_rawmidi_status_t **ptr); 160 void snd_rawmidi_status_free(snd_rawmidi_status_t *obj); 161 void snd_rawmidi_status_copy(snd_rawmidi_status_t *dst, const snd_rawmidi_status_t *src); 162 void snd_rawmidi_status_get_tstamp(const snd_rawmidi_status_t *obj, snd_htimestamp_t *ptr); 163 size_t snd_rawmidi_status_get_avail(const snd_rawmidi_status_t *obj); 164 size_t snd_rawmidi_status_get_xruns(const snd_rawmidi_status_t *obj); 165 int snd_rawmidi_status(snd_rawmidi_t *rmidi, snd_rawmidi_status_t * status); 166 int snd_rawmidi_drain(snd_rawmidi_t *rmidi); 167 int snd_rawmidi_drop(snd_rawmidi_t *rmidi); 168 ssize_t snd_rawmidi_write(snd_rawmidi_t *rmidi, const void *buffer, size_t size); 169 ssize_t snd_rawmidi_read(snd_rawmidi_t *rmidi, void *buffer, size_t size); 170 ssize_t snd_rawmidi_tread(snd_rawmidi_t *rmidi, struct timespec *tstamp, void *buffer, size_t size); 171 const char *snd_rawmidi_name(snd_rawmidi_t *rmidi); 172 snd_rawmidi_type_t snd_rawmidi_type(snd_rawmidi_t *rmidi); 173 snd_rawmidi_stream_t snd_rawmidi_stream(snd_rawmidi_t *rawmidi); 174 175 /** \} */ 176 177 #ifdef __cplusplus 178 } 179 #endif 180 181 #endif /* __RAWMIDI_H */ 182 183