1/** 2 * \file include/seq.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/* 10 * Application interface library for the ALSA driver 11 * 12 * 13 * This library is free software; you can redistribute it and/or modify 14 * it under the terms of the GNU Lesser General Public License as 15 * published by the Free Software Foundation; either version 2.1 of 16 * the License, or (at your option) any later version. 17 * 18 * This program is distributed in the hope that it will be useful, 19 * but WITHOUT ANY WARRANTY; without even the implied warranty of 20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 21 * GNU Lesser General Public License for more details. 22 * 23 * You should have received a copy of the GNU Lesser General Public 24 * License along with this library; if not, write to the Free Software 25 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 26 * 27 */ 28 29#ifndef __ALSA_SEQ_H 30#define __ALSA_SEQ_H 31 32#ifdef __cplusplus 33extern "C" { 34#endif 35 36/** 37 * \defgroup Sequencer MIDI Sequencer 38 * MIDI Sequencer Interface. 39 * See \ref seq page for more details. 40 * \{ 41 */ 42 43/** dlsym version for interface entry callback */ 44#define SND_SEQ_DLSYM_VERSION _dlsym_seq_001 45 46/** Sequencer handle */ 47typedef struct _snd_seq snd_seq_t; 48 49/** 50 * sequencer opening stream types 51 */ 52#define SND_SEQ_OPEN_OUTPUT 1 /**< open for output (write) */ 53#define SND_SEQ_OPEN_INPUT 2 /**< open for input (read) */ 54#define SND_SEQ_OPEN_DUPLEX (SND_SEQ_OPEN_OUTPUT|SND_SEQ_OPEN_INPUT) /**< open for both input and output (read/write) */ 55 56/** 57 * sequencer opening mode 58 */ 59#define SND_SEQ_NONBLOCK 0x0001 /**< non-blocking mode (flag to open mode) */ 60 61/** sequencer handle type */ 62typedef enum _snd_seq_type { 63 SND_SEQ_TYPE_HW, /**< hardware */ 64 SND_SEQ_TYPE_SHM, /**< shared memory (NYI) */ 65 SND_SEQ_TYPE_INET /**< network (NYI) */ 66} snd_seq_type_t; 67 68/** special client (port) ids */ 69#define SND_SEQ_ADDRESS_UNKNOWN 253 /**< unknown source */ 70#define SND_SEQ_ADDRESS_SUBSCRIBERS 254 /**< send event to all subscribed ports */ 71#define SND_SEQ_ADDRESS_BROADCAST 255 /**< send event to all queues/clients/ports/channels */ 72 73/** known client numbers */ 74#define SND_SEQ_CLIENT_SYSTEM 0 /**< system client */ 75 76/* 77 */ 78int snd_seq_open(snd_seq_t **handle, const char *name, int streams, int mode); 79int snd_seq_open_lconf(snd_seq_t **handle, const char *name, int streams, int mode, snd_config_t *lconf); 80const char *snd_seq_name(snd_seq_t *seq); 81snd_seq_type_t snd_seq_type(snd_seq_t *seq); 82int snd_seq_close(snd_seq_t *handle); 83int snd_seq_poll_descriptors_count(snd_seq_t *handle, short events); 84int snd_seq_poll_descriptors(snd_seq_t *handle, struct pollfd *pfds, unsigned int space, short events); 85int snd_seq_poll_descriptors_revents(snd_seq_t *seq, struct pollfd *pfds, unsigned int nfds, unsigned short *revents); 86int snd_seq_nonblock(snd_seq_t *handle, int nonblock); 87int snd_seq_client_id(snd_seq_t *handle); 88 89size_t snd_seq_get_output_buffer_size(snd_seq_t *handle); 90size_t snd_seq_get_input_buffer_size(snd_seq_t *handle); 91int snd_seq_set_output_buffer_size(snd_seq_t *handle, size_t size); 92int snd_seq_set_input_buffer_size(snd_seq_t *handle, size_t size); 93 94/** system information container */ 95typedef struct _snd_seq_system_info snd_seq_system_info_t; 96 97size_t snd_seq_system_info_sizeof(void); 98/** allocate a #snd_seq_system_info_t container on stack */ 99#define snd_seq_system_info_alloca(ptr) \ 100 __snd_alloca(ptr, snd_seq_system_info) 101int snd_seq_system_info_malloc(snd_seq_system_info_t **ptr); 102void snd_seq_system_info_free(snd_seq_system_info_t *ptr); 103void snd_seq_system_info_copy(snd_seq_system_info_t *dst, const snd_seq_system_info_t *src); 104 105int snd_seq_system_info_get_queues(const snd_seq_system_info_t *info); 106int snd_seq_system_info_get_clients(const snd_seq_system_info_t *info); 107int snd_seq_system_info_get_ports(const snd_seq_system_info_t *info); 108int snd_seq_system_info_get_channels(const snd_seq_system_info_t *info); 109int snd_seq_system_info_get_cur_clients(const snd_seq_system_info_t *info); 110int snd_seq_system_info_get_cur_queues(const snd_seq_system_info_t *info); 111 112int snd_seq_system_info(snd_seq_t *handle, snd_seq_system_info_t *info); 113 114/** \} */ 115 116 117/** 118 * \defgroup SeqClient Sequencer Client Interface 119 * Sequencer Client Interface 120 * \ingroup Sequencer 121 * \{ 122 */ 123 124/** client information container */ 125typedef struct _snd_seq_client_info snd_seq_client_info_t; 126 127/** client types */ 128typedef enum snd_seq_client_type { 129 SND_SEQ_USER_CLIENT = 1, /**< user client */ 130 SND_SEQ_KERNEL_CLIENT = 2 /**< kernel client */ 131} snd_seq_client_type_t; 132 133size_t snd_seq_client_info_sizeof(void); 134/** allocate a #snd_seq_client_info_t container on stack */ 135#define snd_seq_client_info_alloca(ptr) \ 136 __snd_alloca(ptr, snd_seq_client_info) 137int snd_seq_client_info_malloc(snd_seq_client_info_t **ptr); 138void snd_seq_client_info_free(snd_seq_client_info_t *ptr); 139void snd_seq_client_info_copy(snd_seq_client_info_t *dst, const snd_seq_client_info_t *src); 140 141int snd_seq_client_info_get_client(const snd_seq_client_info_t *info); 142snd_seq_client_type_t snd_seq_client_info_get_type(const snd_seq_client_info_t *info); 143const char *snd_seq_client_info_get_name(snd_seq_client_info_t *info); 144int snd_seq_client_info_get_broadcast_filter(const snd_seq_client_info_t *info); 145int snd_seq_client_info_get_error_bounce(const snd_seq_client_info_t *info); 146const unsigned char *snd_seq_client_info_get_event_filter(const snd_seq_client_info_t *info); 147int snd_seq_client_info_get_num_ports(const snd_seq_client_info_t *info); 148int snd_seq_client_info_get_event_lost(const snd_seq_client_info_t *info); 149 150void snd_seq_client_info_set_client(snd_seq_client_info_t *info, int client); 151void snd_seq_client_info_set_name(snd_seq_client_info_t *info, const char *name); 152void snd_seq_client_info_set_broadcast_filter(snd_seq_client_info_t *info, int val); 153void snd_seq_client_info_set_error_bounce(snd_seq_client_info_t *info, int val); 154void snd_seq_client_info_set_event_filter(snd_seq_client_info_t *info, unsigned char *filter); 155 156void snd_seq_client_info_event_filter_clear(snd_seq_client_info_t *info); 157void snd_seq_client_info_event_filter_add(snd_seq_client_info_t *info, int event_type); 158void snd_seq_client_info_event_filter_del(snd_seq_client_info_t *info, int event_type); 159int snd_seq_client_info_event_filter_check(snd_seq_client_info_t *info, int event_type); 160 161int snd_seq_get_client_info(snd_seq_t *handle, snd_seq_client_info_t *info); 162int snd_seq_get_any_client_info(snd_seq_t *handle, int client, snd_seq_client_info_t *info); 163int snd_seq_set_client_info(snd_seq_t *handle, snd_seq_client_info_t *info); 164int snd_seq_query_next_client(snd_seq_t *handle, snd_seq_client_info_t *info); 165 166/* 167 */ 168 169/** client pool information container */ 170typedef struct _snd_seq_client_pool snd_seq_client_pool_t; 171 172size_t snd_seq_client_pool_sizeof(void); 173/** allocate a #snd_seq_client_pool_t container on stack */ 174#define snd_seq_client_pool_alloca(ptr) \ 175 __snd_alloca(ptr, snd_seq_client_pool) 176int snd_seq_client_pool_malloc(snd_seq_client_pool_t **ptr); 177void snd_seq_client_pool_free(snd_seq_client_pool_t *ptr); 178void snd_seq_client_pool_copy(snd_seq_client_pool_t *dst, const snd_seq_client_pool_t *src); 179 180int snd_seq_client_pool_get_client(const snd_seq_client_pool_t *info); 181size_t snd_seq_client_pool_get_output_pool(const snd_seq_client_pool_t *info); 182size_t snd_seq_client_pool_get_input_pool(const snd_seq_client_pool_t *info); 183size_t snd_seq_client_pool_get_output_room(const snd_seq_client_pool_t *info); 184size_t snd_seq_client_pool_get_output_free(const snd_seq_client_pool_t *info); 185size_t snd_seq_client_pool_get_input_free(const snd_seq_client_pool_t *info); 186void snd_seq_client_pool_set_output_pool(snd_seq_client_pool_t *info, size_t size); 187void snd_seq_client_pool_set_input_pool(snd_seq_client_pool_t *info, size_t size); 188void snd_seq_client_pool_set_output_room(snd_seq_client_pool_t *info, size_t size); 189 190int snd_seq_get_client_pool(snd_seq_t *handle, snd_seq_client_pool_t *info); 191int snd_seq_set_client_pool(snd_seq_t *handle, snd_seq_client_pool_t *info); 192 193 194/** \} */ 195 196 197/** 198 * \defgroup SeqPort Sequencer Port Interface 199 * Sequencer Port Interface 200 * \ingroup Sequencer 201 * \{ 202 */ 203 204/** port information container */ 205typedef struct _snd_seq_port_info snd_seq_port_info_t; 206 207/** known port numbers */ 208#define SND_SEQ_PORT_SYSTEM_TIMER 0 /**< system timer port */ 209#define SND_SEQ_PORT_SYSTEM_ANNOUNCE 1 /**< system announce port */ 210 211/** port capabilities (32 bits) */ 212#define SND_SEQ_PORT_CAP_READ (1<<0) /**< readable from this port */ 213#define SND_SEQ_PORT_CAP_WRITE (1<<1) /**< writable to this port */ 214 215#define SND_SEQ_PORT_CAP_SYNC_READ (1<<2) /**< allow read subscriptions */ 216#define SND_SEQ_PORT_CAP_SYNC_WRITE (1<<3) /**< allow write subscriptions */ 217 218#define SND_SEQ_PORT_CAP_DUPLEX (1<<4) /**< allow read/write duplex */ 219 220#define SND_SEQ_PORT_CAP_SUBS_READ (1<<5) /**< allow read subscription */ 221#define SND_SEQ_PORT_CAP_SUBS_WRITE (1<<6) /**< allow write subscription */ 222#define SND_SEQ_PORT_CAP_NO_EXPORT (1<<7) /**< routing not allowed */ 223 224/* port type */ 225/** Messages sent from/to this port have device-specific semantics. */ 226#define SND_SEQ_PORT_TYPE_SPECIFIC (1<<0) 227/** This port understands MIDI messages. */ 228#define SND_SEQ_PORT_TYPE_MIDI_GENERIC (1<<1) 229/** This port is compatible with the General MIDI specification. */ 230#define SND_SEQ_PORT_TYPE_MIDI_GM (1<<2) 231/** This port is compatible with the Roland GS standard. */ 232#define SND_SEQ_PORT_TYPE_MIDI_GS (1<<3) 233/** This port is compatible with the Yamaha XG specification. */ 234#define SND_SEQ_PORT_TYPE_MIDI_XG (1<<4) 235/** This port is compatible with the Roland MT-32. */ 236#define SND_SEQ_PORT_TYPE_MIDI_MT32 (1<<5) 237/** This port is compatible with the General MIDI 2 specification. */ 238#define SND_SEQ_PORT_TYPE_MIDI_GM2 (1<<6) 239/** This port understands SND_SEQ_EVENT_SAMPLE_xxx messages 240 (these are not MIDI messages). */ 241#define SND_SEQ_PORT_TYPE_SYNTH (1<<10) 242/** Instruments can be downloaded to this port 243 (with SND_SEQ_EVENT_INSTR_xxx messages sent directly). */ 244#define SND_SEQ_PORT_TYPE_DIRECT_SAMPLE (1<<11) 245/** Instruments can be downloaded to this port 246 (with SND_SEQ_EVENT_INSTR_xxx messages sent directly or through a queue). */ 247#define SND_SEQ_PORT_TYPE_SAMPLE (1<<12) 248/** This port is implemented in hardware. */ 249#define SND_SEQ_PORT_TYPE_HARDWARE (1<<16) 250/** This port is implemented in software. */ 251#define SND_SEQ_PORT_TYPE_SOFTWARE (1<<17) 252/** Messages sent to this port will generate sounds. */ 253#define SND_SEQ_PORT_TYPE_SYNTHESIZER (1<<18) 254/** This port may connect to other devices 255 (whose characteristics are not known). */ 256#define SND_SEQ_PORT_TYPE_PORT (1<<19) 257/** This port belongs to an application, such as a sequencer or editor. */ 258#define SND_SEQ_PORT_TYPE_APPLICATION (1<<20) 259 260 261size_t snd_seq_port_info_sizeof(void); 262/** allocate a #snd_seq_port_info_t container on stack */ 263#define snd_seq_port_info_alloca(ptr) \ 264 __snd_alloca(ptr, snd_seq_port_info) 265int snd_seq_port_info_malloc(snd_seq_port_info_t **ptr); 266void snd_seq_port_info_free(snd_seq_port_info_t *ptr); 267void snd_seq_port_info_copy(snd_seq_port_info_t *dst, const snd_seq_port_info_t *src); 268 269int snd_seq_port_info_get_client(const snd_seq_port_info_t *info); 270int snd_seq_port_info_get_port(const snd_seq_port_info_t *info); 271const snd_seq_addr_t *snd_seq_port_info_get_addr(const snd_seq_port_info_t *info); 272const char *snd_seq_port_info_get_name(const snd_seq_port_info_t *info); 273unsigned int snd_seq_port_info_get_capability(const snd_seq_port_info_t *info); 274unsigned int snd_seq_port_info_get_type(const snd_seq_port_info_t *info); 275int snd_seq_port_info_get_midi_channels(const snd_seq_port_info_t *info); 276int snd_seq_port_info_get_midi_voices(const snd_seq_port_info_t *info); 277int snd_seq_port_info_get_synth_voices(const snd_seq_port_info_t *info); 278int snd_seq_port_info_get_read_use(const snd_seq_port_info_t *info); 279int snd_seq_port_info_get_write_use(const snd_seq_port_info_t *info); 280int snd_seq_port_info_get_port_specified(const snd_seq_port_info_t *info); 281int snd_seq_port_info_get_timestamping(const snd_seq_port_info_t *info); 282int snd_seq_port_info_get_timestamp_real(const snd_seq_port_info_t *info); 283int snd_seq_port_info_get_timestamp_queue(const snd_seq_port_info_t *info); 284 285void snd_seq_port_info_set_client(snd_seq_port_info_t *info, int client); 286void snd_seq_port_info_set_port(snd_seq_port_info_t *info, int port); 287void snd_seq_port_info_set_addr(snd_seq_port_info_t *info, const snd_seq_addr_t *addr); 288void snd_seq_port_info_set_name(snd_seq_port_info_t *info, const char *name); 289void snd_seq_port_info_set_capability(snd_seq_port_info_t *info, unsigned int capability); 290void snd_seq_port_info_set_type(snd_seq_port_info_t *info, unsigned int type); 291void snd_seq_port_info_set_midi_channels(snd_seq_port_info_t *info, int channels); 292void snd_seq_port_info_set_midi_voices(snd_seq_port_info_t *info, int voices); 293void snd_seq_port_info_set_synth_voices(snd_seq_port_info_t *info, int voices); 294void snd_seq_port_info_set_port_specified(snd_seq_port_info_t *info, int val); 295void snd_seq_port_info_set_timestamping(snd_seq_port_info_t *info, int enable); 296void snd_seq_port_info_set_timestamp_real(snd_seq_port_info_t *info, int realtime); 297void snd_seq_port_info_set_timestamp_queue(snd_seq_port_info_t *info, int queue); 298 299int snd_seq_create_port(snd_seq_t *handle, snd_seq_port_info_t *info); 300int snd_seq_delete_port(snd_seq_t *handle, int port); 301int snd_seq_get_port_info(snd_seq_t *handle, int port, snd_seq_port_info_t *info); 302int snd_seq_get_any_port_info(snd_seq_t *handle, int client, int port, snd_seq_port_info_t *info); 303int snd_seq_set_port_info(snd_seq_t *handle, int port, snd_seq_port_info_t *info); 304int snd_seq_query_next_port(snd_seq_t *handle, snd_seq_port_info_t *info); 305 306/** \} */ 307 308 309/** 310 * \defgroup SeqSubscribe Sequencer Port Subscription 311 * Sequencer Port Subscription 312 * \ingroup Sequencer 313 * \{ 314 */ 315 316/** port subscription container */ 317typedef struct _snd_seq_port_subscribe snd_seq_port_subscribe_t; 318 319size_t snd_seq_port_subscribe_sizeof(void); 320/** allocate a #snd_seq_port_subscribe_t container on stack */ 321#define snd_seq_port_subscribe_alloca(ptr) \ 322 __snd_alloca(ptr, snd_seq_port_subscribe) 323int snd_seq_port_subscribe_malloc(snd_seq_port_subscribe_t **ptr); 324void snd_seq_port_subscribe_free(snd_seq_port_subscribe_t *ptr); 325void snd_seq_port_subscribe_copy(snd_seq_port_subscribe_t *dst, const snd_seq_port_subscribe_t *src); 326 327const snd_seq_addr_t *snd_seq_port_subscribe_get_sender(const snd_seq_port_subscribe_t *info); 328const snd_seq_addr_t *snd_seq_port_subscribe_get_dest(const snd_seq_port_subscribe_t *info); 329int snd_seq_port_subscribe_get_queue(const snd_seq_port_subscribe_t *info); 330int snd_seq_port_subscribe_get_exclusive(const snd_seq_port_subscribe_t *info); 331int snd_seq_port_subscribe_get_time_update(const snd_seq_port_subscribe_t *info); 332int snd_seq_port_subscribe_get_time_real(const snd_seq_port_subscribe_t *info); 333 334void snd_seq_port_subscribe_set_sender(snd_seq_port_subscribe_t *info, const snd_seq_addr_t *addr); 335void snd_seq_port_subscribe_set_dest(snd_seq_port_subscribe_t *info, const snd_seq_addr_t *addr); 336void snd_seq_port_subscribe_set_queue(snd_seq_port_subscribe_t *info, int q); 337void snd_seq_port_subscribe_set_exclusive(snd_seq_port_subscribe_t *info, int val); 338void snd_seq_port_subscribe_set_time_update(snd_seq_port_subscribe_t *info, int val); 339void snd_seq_port_subscribe_set_time_real(snd_seq_port_subscribe_t *info, int val); 340 341int snd_seq_get_port_subscription(snd_seq_t *handle, snd_seq_port_subscribe_t *sub); 342int snd_seq_subscribe_port(snd_seq_t *handle, snd_seq_port_subscribe_t *sub); 343int snd_seq_unsubscribe_port(snd_seq_t *handle, snd_seq_port_subscribe_t *sub); 344 345/* 346 */ 347 348/** subscription query container */ 349typedef struct _snd_seq_query_subscribe snd_seq_query_subscribe_t; 350 351/** type of query subscription */ 352typedef enum { 353 SND_SEQ_QUERY_SUBS_READ, /**< query read subscriptions */ 354 SND_SEQ_QUERY_SUBS_WRITE /**< query write subscriptions */ 355} snd_seq_query_subs_type_t; 356 357size_t snd_seq_query_subscribe_sizeof(void); 358/** allocate a #snd_seq_query_subscribe_t container on stack */ 359#define snd_seq_query_subscribe_alloca(ptr) \ 360 __snd_alloca(ptr, snd_seq_query_subscribe) 361int snd_seq_query_subscribe_malloc(snd_seq_query_subscribe_t **ptr); 362void snd_seq_query_subscribe_free(snd_seq_query_subscribe_t *ptr); 363void snd_seq_query_subscribe_copy(snd_seq_query_subscribe_t *dst, const snd_seq_query_subscribe_t *src); 364 365int snd_seq_query_subscribe_get_client(const snd_seq_query_subscribe_t *info); 366int snd_seq_query_subscribe_get_port(const snd_seq_query_subscribe_t *info); 367const snd_seq_addr_t *snd_seq_query_subscribe_get_root(const snd_seq_query_subscribe_t *info); 368snd_seq_query_subs_type_t snd_seq_query_subscribe_get_type(const snd_seq_query_subscribe_t *info); 369int snd_seq_query_subscribe_get_index(const snd_seq_query_subscribe_t *info); 370int snd_seq_query_subscribe_get_num_subs(const snd_seq_query_subscribe_t *info); 371const snd_seq_addr_t *snd_seq_query_subscribe_get_addr(const snd_seq_query_subscribe_t *info); 372int snd_seq_query_subscribe_get_queue(const snd_seq_query_subscribe_t *info); 373int snd_seq_query_subscribe_get_exclusive(const snd_seq_query_subscribe_t *info); 374int snd_seq_query_subscribe_get_time_update(const snd_seq_query_subscribe_t *info); 375int snd_seq_query_subscribe_get_time_real(const snd_seq_query_subscribe_t *info); 376 377void snd_seq_query_subscribe_set_client(snd_seq_query_subscribe_t *info, int client); 378void snd_seq_query_subscribe_set_port(snd_seq_query_subscribe_t *info, int port); 379void snd_seq_query_subscribe_set_root(snd_seq_query_subscribe_t *info, const snd_seq_addr_t *addr); 380void snd_seq_query_subscribe_set_type(snd_seq_query_subscribe_t *info, snd_seq_query_subs_type_t type); 381void snd_seq_query_subscribe_set_index(snd_seq_query_subscribe_t *info, int _index); 382 383int snd_seq_query_port_subscribers(snd_seq_t *seq, snd_seq_query_subscribe_t * subs); 384 385/** \} */ 386 387 388/** 389 * \defgroup SeqQueue Sequencer Queue Interface 390 * Sequencer Queue Interface 391 * \ingroup Sequencer 392 * \{ 393 */ 394 395/** queue information container */ 396typedef struct _snd_seq_queue_info snd_seq_queue_info_t; 397/** queue status container */ 398typedef struct _snd_seq_queue_status snd_seq_queue_status_t; 399/** queue tempo container */ 400typedef struct _snd_seq_queue_tempo snd_seq_queue_tempo_t; 401/** queue timer information container */ 402typedef struct _snd_seq_queue_timer snd_seq_queue_timer_t; 403 404/** special queue ids */ 405#define SND_SEQ_QUEUE_DIRECT 253 /**< direct dispatch */ 406 407size_t snd_seq_queue_info_sizeof(void); 408/** allocate a #snd_seq_queue_info_t container on stack */ 409#define snd_seq_queue_info_alloca(ptr) \ 410 __snd_alloca(ptr, snd_seq_queue_info) 411int snd_seq_queue_info_malloc(snd_seq_queue_info_t **ptr); 412void snd_seq_queue_info_free(snd_seq_queue_info_t *ptr); 413void snd_seq_queue_info_copy(snd_seq_queue_info_t *dst, const snd_seq_queue_info_t *src); 414 415int snd_seq_queue_info_get_queue(const snd_seq_queue_info_t *info); 416const char *snd_seq_queue_info_get_name(const snd_seq_queue_info_t *info); 417int snd_seq_queue_info_get_owner(const snd_seq_queue_info_t *info); 418int snd_seq_queue_info_get_locked(const snd_seq_queue_info_t *info); 419unsigned int snd_seq_queue_info_get_flags(const snd_seq_queue_info_t *info); 420 421void snd_seq_queue_info_set_name(snd_seq_queue_info_t *info, const char *name); 422void snd_seq_queue_info_set_owner(snd_seq_queue_info_t *info, int owner); 423void snd_seq_queue_info_set_locked(snd_seq_queue_info_t *info, int locked); 424void snd_seq_queue_info_set_flags(snd_seq_queue_info_t *info, unsigned int flags); 425 426int snd_seq_create_queue(snd_seq_t *seq, snd_seq_queue_info_t *info); 427int snd_seq_alloc_named_queue(snd_seq_t *seq, const char *name); 428int snd_seq_alloc_queue(snd_seq_t *handle); 429int snd_seq_free_queue(snd_seq_t *handle, int q); 430int snd_seq_get_queue_info(snd_seq_t *seq, int q, snd_seq_queue_info_t *info); 431int snd_seq_set_queue_info(snd_seq_t *seq, int q, snd_seq_queue_info_t *info); 432int snd_seq_query_named_queue(snd_seq_t *seq, const char *name); 433 434int snd_seq_get_queue_usage(snd_seq_t *handle, int q); 435int snd_seq_set_queue_usage(snd_seq_t *handle, int q, int used); 436 437/* 438 */ 439size_t snd_seq_queue_status_sizeof(void); 440/** allocate a #snd_seq_queue_status_t container on stack */ 441#define snd_seq_queue_status_alloca(ptr) \ 442 __snd_alloca(ptr, snd_seq_queue_status) 443int snd_seq_queue_status_malloc(snd_seq_queue_status_t **ptr); 444void snd_seq_queue_status_free(snd_seq_queue_status_t *ptr); 445void snd_seq_queue_status_copy(snd_seq_queue_status_t *dst, const snd_seq_queue_status_t *src); 446 447int snd_seq_queue_status_get_queue(const snd_seq_queue_status_t *info); 448int snd_seq_queue_status_get_events(const snd_seq_queue_status_t *info); 449snd_seq_tick_time_t snd_seq_queue_status_get_tick_time(const snd_seq_queue_status_t *info); 450const snd_seq_real_time_t *snd_seq_queue_status_get_real_time(const snd_seq_queue_status_t *info); 451unsigned int snd_seq_queue_status_get_status(const snd_seq_queue_status_t *info); 452 453int snd_seq_get_queue_status(snd_seq_t *handle, int q, snd_seq_queue_status_t *status); 454 455/* 456 */ 457size_t snd_seq_queue_tempo_sizeof(void); 458/** allocate a #snd_seq_queue_tempo_t container on stack */ 459#define snd_seq_queue_tempo_alloca(ptr) \ 460 __snd_alloca(ptr, snd_seq_queue_tempo) 461int snd_seq_queue_tempo_malloc(snd_seq_queue_tempo_t **ptr); 462void snd_seq_queue_tempo_free(snd_seq_queue_tempo_t *ptr); 463void snd_seq_queue_tempo_copy(snd_seq_queue_tempo_t *dst, const snd_seq_queue_tempo_t *src); 464 465int snd_seq_queue_tempo_get_queue(const snd_seq_queue_tempo_t *info); 466unsigned int snd_seq_queue_tempo_get_tempo(const snd_seq_queue_tempo_t *info); 467int snd_seq_queue_tempo_get_ppq(const snd_seq_queue_tempo_t *info); 468unsigned int snd_seq_queue_tempo_get_skew(const snd_seq_queue_tempo_t *info); 469unsigned int snd_seq_queue_tempo_get_skew_base(const snd_seq_queue_tempo_t *info); 470void snd_seq_queue_tempo_set_tempo(snd_seq_queue_tempo_t *info, unsigned int tempo); 471void snd_seq_queue_tempo_set_ppq(snd_seq_queue_tempo_t *info, int ppq); 472void snd_seq_queue_tempo_set_skew(snd_seq_queue_tempo_t *info, unsigned int skew); 473void snd_seq_queue_tempo_set_skew_base(snd_seq_queue_tempo_t *info, unsigned int base); 474 475int snd_seq_get_queue_tempo(snd_seq_t *handle, int q, snd_seq_queue_tempo_t *tempo); 476int snd_seq_set_queue_tempo(snd_seq_t *handle, int q, snd_seq_queue_tempo_t *tempo); 477 478/* 479 */ 480 481/** sequencer timer sources */ 482typedef enum { 483 SND_SEQ_TIMER_ALSA = 0, /* ALSA timer */ 484 SND_SEQ_TIMER_MIDI_CLOCK = 1, /* Midi Clock (CLOCK event) */ 485 SND_SEQ_TIMER_MIDI_TICK = 2 /* Midi Timer Tick (TICK event */ 486} snd_seq_queue_timer_type_t; 487 488size_t snd_seq_queue_timer_sizeof(void); 489/** allocate a #snd_seq_queue_timer_t container on stack */ 490#define snd_seq_queue_timer_alloca(ptr) \ 491 __snd_alloca(ptr, snd_seq_queue_timer) 492int snd_seq_queue_timer_malloc(snd_seq_queue_timer_t **ptr); 493void snd_seq_queue_timer_free(snd_seq_queue_timer_t *ptr); 494void snd_seq_queue_timer_copy(snd_seq_queue_timer_t *dst, const snd_seq_queue_timer_t *src); 495 496int snd_seq_queue_timer_get_queue(const snd_seq_queue_timer_t *info); 497snd_seq_queue_timer_type_t snd_seq_queue_timer_get_type(const snd_seq_queue_timer_t *info); 498const snd_timer_id_t *snd_seq_queue_timer_get_id(const snd_seq_queue_timer_t *info); 499unsigned int snd_seq_queue_timer_get_resolution(const snd_seq_queue_timer_t *info); 500 501void snd_seq_queue_timer_set_type(snd_seq_queue_timer_t *info, snd_seq_queue_timer_type_t type); 502void snd_seq_queue_timer_set_id(snd_seq_queue_timer_t *info, const snd_timer_id_t *id); 503void snd_seq_queue_timer_set_resolution(snd_seq_queue_timer_t *info, unsigned int resolution); 504 505int snd_seq_get_queue_timer(snd_seq_t *handle, int q, snd_seq_queue_timer_t *timer); 506int snd_seq_set_queue_timer(snd_seq_t *handle, int q, snd_seq_queue_timer_t *timer); 507 508/** \} */ 509 510/** 511 * \defgroup SeqEvent Sequencer Event API 512 * Sequencer Event API 513 * \ingroup Sequencer 514 * \{ 515 */ 516 517int snd_seq_free_event(snd_seq_event_t *ev); 518ssize_t snd_seq_event_length(snd_seq_event_t *ev); 519int snd_seq_event_output(snd_seq_t *handle, snd_seq_event_t *ev); 520int snd_seq_event_output_buffer(snd_seq_t *handle, snd_seq_event_t *ev); 521int snd_seq_event_output_direct(snd_seq_t *handle, snd_seq_event_t *ev); 522int snd_seq_event_input(snd_seq_t *handle, snd_seq_event_t **ev); 523int snd_seq_event_input_pending(snd_seq_t *seq, int fetch_sequencer); 524int snd_seq_drain_output(snd_seq_t *handle); 525int snd_seq_event_output_pending(snd_seq_t *seq); 526int snd_seq_extract_output(snd_seq_t *handle, snd_seq_event_t **ev); 527int snd_seq_drop_output(snd_seq_t *handle); 528int snd_seq_drop_output_buffer(snd_seq_t *handle); 529int snd_seq_drop_input(snd_seq_t *handle); 530int snd_seq_drop_input_buffer(snd_seq_t *handle); 531 532/** event removal conditionals */ 533typedef struct _snd_seq_remove_events snd_seq_remove_events_t; 534 535/** Remove conditional flags */ 536#define SND_SEQ_REMOVE_INPUT (1<<0) /**< Flush input queues */ 537#define SND_SEQ_REMOVE_OUTPUT (1<<1) /**< Flush output queues */ 538#define SND_SEQ_REMOVE_DEST (1<<2) /**< Restrict by destination q:client:port */ 539#define SND_SEQ_REMOVE_DEST_CHANNEL (1<<3) /**< Restrict by channel */ 540#define SND_SEQ_REMOVE_TIME_BEFORE (1<<4) /**< Restrict to before time */ 541#define SND_SEQ_REMOVE_TIME_AFTER (1<<5) /**< Restrict to time or after */ 542#define SND_SEQ_REMOVE_TIME_TICK (1<<6) /**< Time is in ticks */ 543#define SND_SEQ_REMOVE_EVENT_TYPE (1<<7) /**< Restrict to event type */ 544#define SND_SEQ_REMOVE_IGNORE_OFF (1<<8) /**< Do not flush off events */ 545#define SND_SEQ_REMOVE_TAG_MATCH (1<<9) /**< Restrict to events with given tag */ 546 547size_t snd_seq_remove_events_sizeof(void); 548/** allocate a #snd_seq_remove_events_t container on stack */ 549#define snd_seq_remove_events_alloca(ptr) \ 550 __snd_alloca(ptr, snd_seq_remove_events) 551int snd_seq_remove_events_malloc(snd_seq_remove_events_t **ptr); 552void snd_seq_remove_events_free(snd_seq_remove_events_t *ptr); 553void snd_seq_remove_events_copy(snd_seq_remove_events_t *dst, const snd_seq_remove_events_t *src); 554 555unsigned int snd_seq_remove_events_get_condition(const snd_seq_remove_events_t *info); 556int snd_seq_remove_events_get_queue(const snd_seq_remove_events_t *info); 557const snd_seq_timestamp_t *snd_seq_remove_events_get_time(const snd_seq_remove_events_t *info); 558const snd_seq_addr_t *snd_seq_remove_events_get_dest(const snd_seq_remove_events_t *info); 559int snd_seq_remove_events_get_channel(const snd_seq_remove_events_t *info); 560int snd_seq_remove_events_get_event_type(const snd_seq_remove_events_t *info); 561int snd_seq_remove_events_get_tag(const snd_seq_remove_events_t *info); 562 563void snd_seq_remove_events_set_condition(snd_seq_remove_events_t *info, unsigned int flags); 564void snd_seq_remove_events_set_queue(snd_seq_remove_events_t *info, int queue); 565void snd_seq_remove_events_set_time(snd_seq_remove_events_t *info, const snd_seq_timestamp_t *time); 566void snd_seq_remove_events_set_dest(snd_seq_remove_events_t *info, const snd_seq_addr_t *addr); 567void snd_seq_remove_events_set_channel(snd_seq_remove_events_t *info, int channel); 568void snd_seq_remove_events_set_event_type(snd_seq_remove_events_t *info, int type); 569void snd_seq_remove_events_set_tag(snd_seq_remove_events_t *info, int tag); 570 571int snd_seq_remove_events(snd_seq_t *handle, snd_seq_remove_events_t *info); 572 573/** \} */ 574 575/** 576 * \defgroup SeqMisc Sequencer Miscellaneous 577 * Sequencer Miscellaneous 578 * \ingroup Sequencer 579 * \{ 580 */ 581 582void snd_seq_set_bit(int nr, void *array); 583void snd_seq_unset_bit(int nr, void *array); 584int snd_seq_change_bit(int nr, void *array); 585int snd_seq_get_bit(int nr, void *array); 586 587/** \} */ 588 589 590/** 591 * \defgroup SeqEvType Sequencer Event Type Checks 592 * Sequencer Event Type Checks 593 * \ingroup Sequencer 594 * \{ 595 */ 596 597/* event type macros */ 598enum { 599 SND_SEQ_EVFLG_RESULT, 600 SND_SEQ_EVFLG_NOTE, 601 SND_SEQ_EVFLG_CONTROL, 602 SND_SEQ_EVFLG_QUEUE, 603 SND_SEQ_EVFLG_SYSTEM, 604 SND_SEQ_EVFLG_MESSAGE, 605 SND_SEQ_EVFLG_CONNECTION, 606 SND_SEQ_EVFLG_SAMPLE, 607 SND_SEQ_EVFLG_USERS, 608 SND_SEQ_EVFLG_INSTR, 609 SND_SEQ_EVFLG_QUOTE, 610 SND_SEQ_EVFLG_NONE, 611 SND_SEQ_EVFLG_RAW, 612 SND_SEQ_EVFLG_FIXED, 613 SND_SEQ_EVFLG_VARIABLE, 614 SND_SEQ_EVFLG_VARUSR 615}; 616 617enum { 618 SND_SEQ_EVFLG_NOTE_ONEARG, 619 SND_SEQ_EVFLG_NOTE_TWOARG 620}; 621 622enum { 623 SND_SEQ_EVFLG_QUEUE_NOARG, 624 SND_SEQ_EVFLG_QUEUE_TICK, 625 SND_SEQ_EVFLG_QUEUE_TIME, 626 SND_SEQ_EVFLG_QUEUE_VALUE 627}; 628 629/** 630 * Exported event type table 631 * 632 * This table is referred by snd_seq_ev_is_xxx. 633 */ 634extern const unsigned int snd_seq_event_types[]; 635 636#define _SND_SEQ_TYPE(x) (1<<(x)) /**< master type - 24bit */ 637#define _SND_SEQ_TYPE_OPT(x) ((x)<<24) /**< optional type - 8bit */ 638 639/** check the event type */ 640#define snd_seq_type_check(ev,x) (snd_seq_event_types[(ev)->type] & _SND_SEQ_TYPE(x)) 641 642/** event type check: result events */ 643#define snd_seq_ev_is_result_type(ev) \ 644 snd_seq_type_check(ev, SND_SEQ_EVFLG_RESULT) 645/** event type check: note events */ 646#define snd_seq_ev_is_note_type(ev) \ 647 snd_seq_type_check(ev, SND_SEQ_EVFLG_NOTE) 648/** event type check: control events */ 649#define snd_seq_ev_is_control_type(ev) \ 650 snd_seq_type_check(ev, SND_SEQ_EVFLG_CONTROL) 651/** event type check: channel specific events */ 652#define snd_seq_ev_is_channel_type(ev) \ 653 (snd_seq_event_types[(ev)->type] & (_SND_SEQ_TYPE(SND_SEQ_EVFLG_NOTE) | _SND_SEQ_TYPE(SND_SEQ_EVFLG_CONTROL))) 654 655/** event type check: queue control events */ 656#define snd_seq_ev_is_queue_type(ev) \ 657 snd_seq_type_check(ev, SND_SEQ_EVFLG_QUEUE) 658/** event type check: system status messages */ 659#define snd_seq_ev_is_message_type(ev) \ 660 snd_seq_type_check(ev, SND_SEQ_EVFLG_MESSAGE) 661/** event type check: system status messages */ 662#define snd_seq_ev_is_subscribe_type(ev) \ 663 snd_seq_type_check(ev, SND_SEQ_EVFLG_CONNECTION) 664/** event type check: sample messages */ 665#define snd_seq_ev_is_sample_type(ev) \ 666 snd_seq_type_check(ev, SND_SEQ_EVFLG_SAMPLE) 667/** event type check: user-defined messages */ 668#define snd_seq_ev_is_user_type(ev) \ 669 snd_seq_type_check(ev, SND_SEQ_EVFLG_USERS) 670/** event type check: instrument layer events */ 671#define snd_seq_ev_is_instr_type(ev) \ 672 snd_seq_type_check(ev, SND_SEQ_EVFLG_INSTR) 673/** event type check: fixed length events */ 674#define snd_seq_ev_is_fixed_type(ev) \ 675 snd_seq_type_check(ev, SND_SEQ_EVFLG_FIXED) 676/** event type check: variable length events */ 677#define snd_seq_ev_is_variable_type(ev) \ 678 snd_seq_type_check(ev, SND_SEQ_EVFLG_VARIABLE) 679/** event type check: user pointer events */ 680#define snd_seq_ev_is_varusr_type(ev) \ 681 snd_seq_type_check(ev, SND_SEQ_EVFLG_VARUSR) 682/** event type check: reserved for kernel */ 683#define snd_seq_ev_is_reserved(ev) \ 684 (! snd_seq_event_types[(ev)->type]) 685 686/** 687 * macros to check event flags 688 */ 689/** prior events */ 690#define snd_seq_ev_is_prior(ev) \ 691 (((ev)->flags & SND_SEQ_PRIORITY_MASK) == SND_SEQ_PRIORITY_HIGH) 692 693/** get the data length type */ 694#define snd_seq_ev_length_type(ev) \ 695 ((ev)->flags & SND_SEQ_EVENT_LENGTH_MASK) 696/** fixed length events */ 697#define snd_seq_ev_is_fixed(ev) \ 698 (snd_seq_ev_length_type(ev) == SND_SEQ_EVENT_LENGTH_FIXED) 699/** variable length events */ 700#define snd_seq_ev_is_variable(ev) \ 701 (snd_seq_ev_length_type(ev) == SND_SEQ_EVENT_LENGTH_VARIABLE) 702/** variable length on user-space */ 703#define snd_seq_ev_is_varusr(ev) \ 704 (snd_seq_ev_length_type(ev) == SND_SEQ_EVENT_LENGTH_VARUSR) 705 706/** time-stamp type */ 707#define snd_seq_ev_timestamp_type(ev) \ 708 ((ev)->flags & SND_SEQ_TIME_STAMP_MASK) 709/** event is in tick time */ 710#define snd_seq_ev_is_tick(ev) \ 711 (snd_seq_ev_timestamp_type(ev) == SND_SEQ_TIME_STAMP_TICK) 712/** event is in real-time */ 713#define snd_seq_ev_is_real(ev) \ 714 (snd_seq_ev_timestamp_type(ev) == SND_SEQ_TIME_STAMP_REAL) 715 716/** time-mode type */ 717#define snd_seq_ev_timemode_type(ev) \ 718 ((ev)->flags & SND_SEQ_TIME_MODE_MASK) 719/** scheduled in absolute time */ 720#define snd_seq_ev_is_abstime(ev) \ 721 (snd_seq_ev_timemode_type(ev) == SND_SEQ_TIME_MODE_ABS) 722/** scheduled in relative time */ 723#define snd_seq_ev_is_reltime(ev) \ 724 (snd_seq_ev_timemode_type(ev) == SND_SEQ_TIME_MODE_REL) 725 726/** direct dispatched events */ 727#define snd_seq_ev_is_direct(ev) \ 728 ((ev)->queue == SND_SEQ_QUEUE_DIRECT) 729 730/** \} */ 731 732#ifdef __cplusplus 733} 734#endif 735 736#endif /* __ALSA_SEQ_H */ 737 738