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