Mercurial > repos > rliterman > csp2
comparison CSP2/CSP2_env/env-d9b9114564458d9d-741b3de822f2aaca6c6caa4325c4afce/include/alsa/seqmid.h @ 69:33d812a61356
planemo upload commit 2e9511a184a1ca667c7be0c6321a36dc4e3d116d
author | jpayne |
---|---|
date | Tue, 18 Mar 2025 17:55:14 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
67:0e9998148a16 | 69:33d812a61356 |
---|---|
1 /** | |
2 * \file include/seqmid.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_SEQMID_H | |
29 #define __ALSA_SEQMID_H | |
30 | |
31 #ifdef __cplusplus | |
32 extern "C" { | |
33 #endif | |
34 | |
35 /** | |
36 * \defgroup SeqMiddle Sequencer Middle Level Interface | |
37 * Sequencer Middle Level Interface | |
38 * \ingroup Sequencer | |
39 * \{ | |
40 */ | |
41 | |
42 /** | |
43 * \brief initialize event record | |
44 * \param ev event record pointer | |
45 * | |
46 * This macro clears the given event record pointer to the default status. | |
47 */ | |
48 #define snd_seq_ev_clear(ev) \ | |
49 memset(ev, 0, sizeof(snd_seq_event_t)) | |
50 | |
51 /** | |
52 * \brief set the tag for given event | |
53 * \param ev event record | |
54 * \param t event tag | |
55 * | |
56 * This macro sets the tag to the given event record. | |
57 */ | |
58 #define snd_seq_ev_set_tag(ev,t) \ | |
59 ((ev)->tag = (t)) | |
60 | |
61 /** | |
62 * \brief set the explicit destination | |
63 * \param ev event record | |
64 * \param c destination client id | |
65 * \param p destination port id | |
66 * | |
67 * This macro sets the client and port id numbers to the given event record. | |
68 * | |
69 * \sa snd_seq_ev_set_subs() | |
70 */ | |
71 #define snd_seq_ev_set_dest(ev,c,p) \ | |
72 ((ev)->dest.client = (c), (ev)->dest.port = (p)) | |
73 | |
74 /** | |
75 * \brief set broadcasting to subscribers | |
76 * \param ev event record | |
77 * | |
78 * This macro sets the destination as the subscribers. | |
79 * | |
80 * \sa snd_seq_ev_set_dest() | |
81 */ | |
82 #define snd_seq_ev_set_subs(ev) \ | |
83 ((ev)->dest.client = SND_SEQ_ADDRESS_SUBSCRIBERS,\ | |
84 (ev)->dest.port = SND_SEQ_ADDRESS_UNKNOWN) | |
85 | |
86 /** | |
87 * \brief set broadcasting to all clients/ports | |
88 * \param ev event record | |
89 * | |
90 * This macro sets the destination as the broadcasting. | |
91 * | |
92 * \sa snd_seq_ev_set_dest() | |
93 */ | |
94 #define snd_seq_ev_set_broadcast(ev) \ | |
95 ((ev)->dest.client = SND_SEQ_ADDRESS_BROADCAST,\ | |
96 (ev)->dest.port = SND_SEQ_ADDRESS_BROADCAST) | |
97 | |
98 /** | |
99 * \brief set the source port | |
100 * \param ev event record | |
101 * \param p source port id | |
102 * | |
103 * This macro sets the source port id number. | |
104 */ | |
105 #define snd_seq_ev_set_source(ev,p) \ | |
106 ((ev)->source.port = (p)) | |
107 | |
108 /** | |
109 * \brief set direct passing mode (without queued) | |
110 * \param ev event instance | |
111 * | |
112 * This macro sets the event to the direct passing mode | |
113 * to be delivered immediately without queueing. | |
114 * | |
115 * \sa snd_seq_ev_schedule_tick(), snd_seq_ev_schedule_real() | |
116 */ | |
117 #define snd_seq_ev_set_direct(ev) \ | |
118 ((ev)->queue = SND_SEQ_QUEUE_DIRECT) | |
119 | |
120 /** | |
121 * \brief set tick-scheduling mode on queue | |
122 * \param ev event instance | |
123 * \param q queue id to schedule | |
124 * \param relative relative time-stamp if non-zero | |
125 * \param ttick tick time-stamp to be delivered | |
126 * | |
127 * This macro sets the scheduling of the event in the | |
128 * MIDI tick mode. | |
129 * | |
130 * \sa snd_seq_ev_schedule_real(), snd_seq_ev_set_direct() | |
131 */ | |
132 #define snd_seq_ev_schedule_tick(ev, q, relative, ttick) \ | |
133 ((ev)->flags &= ~(SND_SEQ_TIME_STAMP_MASK | SND_SEQ_TIME_MODE_MASK),\ | |
134 (ev)->flags |= SND_SEQ_TIME_STAMP_TICK,\ | |
135 (ev)->flags |= (relative) ? SND_SEQ_TIME_MODE_REL : SND_SEQ_TIME_MODE_ABS,\ | |
136 (ev)->time.tick = (ttick),\ | |
137 (ev)->queue = (q)) | |
138 | |
139 /** | |
140 * \brief set real-time-scheduling mode on queue | |
141 * \param ev event instance | |
142 * \param q queue id to schedule | |
143 * \param relative relative time-stamp if non-zero | |
144 * \param rtime time-stamp to be delivered | |
145 * | |
146 * This macro sets the scheduling of the event in the | |
147 * realtime mode. | |
148 * | |
149 * \sa snd_seq_ev_schedule_tick(), snd_seq_ev_set_direct() | |
150 */ | |
151 #define snd_seq_ev_schedule_real(ev, q, relative, rtime) \ | |
152 ((ev)->flags &= ~(SND_SEQ_TIME_STAMP_MASK | SND_SEQ_TIME_MODE_MASK),\ | |
153 (ev)->flags |= SND_SEQ_TIME_STAMP_REAL,\ | |
154 (ev)->flags |= (relative) ? SND_SEQ_TIME_MODE_REL : SND_SEQ_TIME_MODE_ABS,\ | |
155 (ev)->time.time = *(rtime),\ | |
156 (ev)->queue = (q)) | |
157 | |
158 /** | |
159 * \brief set event priority | |
160 * \param ev event instance | |
161 * \param high_prior 1 for high priority mode | |
162 */ | |
163 #define snd_seq_ev_set_priority(ev, high_prior) \ | |
164 ((ev)->flags &= ~SND_SEQ_PRIORITY_MASK,\ | |
165 (ev)->flags |= (high_prior) ? SND_SEQ_PRIORITY_HIGH : SND_SEQ_PRIORITY_NORMAL) | |
166 | |
167 /** | |
168 * \brief set fixed data | |
169 * \param ev event instance | |
170 * | |
171 * Sets the event length mode as fixed size. | |
172 * | |
173 * \sa snd_seq_ev_set_variable(), snd_seq_ev_set_varusr() | |
174 */ | |
175 #define snd_seq_ev_set_fixed(ev) \ | |
176 ((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\ | |
177 (ev)->flags |= SND_SEQ_EVENT_LENGTH_FIXED) | |
178 | |
179 /** | |
180 * \brief set variable data | |
181 * \param ev event instance | |
182 * \param datalen length of the external data | |
183 * \param dataptr pointer of the external data | |
184 * | |
185 * Sets the event length mode as variable length and stores the data. | |
186 * | |
187 * \sa snd_seq_ev_set_fixed(), snd_seq_ev_set_varusr() | |
188 */ | |
189 #define snd_seq_ev_set_variable(ev, datalen, dataptr) \ | |
190 ((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\ | |
191 (ev)->flags |= SND_SEQ_EVENT_LENGTH_VARIABLE,\ | |
192 (ev)->data.ext.len = (datalen),\ | |
193 (ev)->data.ext.ptr = (dataptr)) | |
194 | |
195 /** | |
196 * \brief set varusr data | |
197 * \param ev event instance | |
198 * \param datalen length of the external data | |
199 * \param dataptr pointer of the external data | |
200 * | |
201 * Sets the event length mode as variable user-space data and stores the data. | |
202 * | |
203 * \sa snd_seq_ev_set_fixed(), snd_seq_ev_set_variable() | |
204 */ | |
205 #define snd_seq_ev_set_varusr(ev, datalen, dataptr) \ | |
206 ((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\ | |
207 (ev)->flags |= SND_SEQ_EVENT_LENGTH_VARUSR,\ | |
208 (ev)->data.ext.len = (datalen),\ | |
209 (ev)->data.ext.ptr = (dataptr)) | |
210 | |
211 /** | |
212 * \brief set queue controls | |
213 * \param ev event record | |
214 * \param typ event type | |
215 * \param q queue id | |
216 * \param val control value | |
217 */ | |
218 #define snd_seq_ev_set_queue_control(ev, typ, q, val) \ | |
219 ((ev)->type = (typ),\ | |
220 snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\ | |
221 (ev)->data.queue.queue = (q),\ | |
222 (ev)->data.queue.param.value = (val)) | |
223 | |
224 /** | |
225 * \brief set the start queue event | |
226 * \param ev event record | |
227 * \param q queue id to start | |
228 * | |
229 * \sa snd_seq_ev_set_queue_stop(), snd_seq_ev_set_queue_continue() | |
230 */ | |
231 #define snd_seq_ev_set_queue_start(ev, q) \ | |
232 snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_START, q, 0) | |
233 | |
234 /** | |
235 * \brief set the stop queue event | |
236 * \param ev event record | |
237 * \param q queue id to stop | |
238 * | |
239 * \sa snd_seq_ev_set_queue_start(), snd_seq_ev_set_queue_continue() | |
240 */ | |
241 #define snd_seq_ev_set_queue_stop(ev, q) \ | |
242 snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_STOP, q, 0) | |
243 | |
244 /** | |
245 * \brief set the stop queue event | |
246 * \param ev event record | |
247 * \param q queue id to continue | |
248 * | |
249 * \sa snd_seq_ev_set_queue_start(), snd_seq_ev_set_queue_stop() | |
250 */ | |
251 #define snd_seq_ev_set_queue_continue(ev, q) \ | |
252 snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_CONTINUE, q, 0) | |
253 | |
254 /** | |
255 * \brief set the stop queue event | |
256 * \param ev event record | |
257 * \param q queue id to change tempo | |
258 * \param val the new tempo value | |
259 */ | |
260 #define snd_seq_ev_set_queue_tempo(ev, q, val) \ | |
261 snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_TEMPO, q, val) | |
262 | |
263 /** | |
264 * \brief set the real-time position of a queue | |
265 * \param ev event record | |
266 * \param q queue id to change tempo | |
267 * \param rtime the new real-time pointer | |
268 */ | |
269 #define snd_seq_ev_set_queue_pos_real(ev, q, rtime) \ | |
270 ((ev)->type = SND_SEQ_EVENT_SETPOS_TIME,\ | |
271 snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\ | |
272 (ev)->data.queue.queue = (q),\ | |
273 (ev)->data.queue.param.time.time = *(rtime)) | |
274 | |
275 /** | |
276 * \brief set the tick-time position of a queue | |
277 * \param ev event record | |
278 * \param q queue id to change tempo | |
279 * \param ttime the new tick-time | |
280 */ | |
281 #define snd_seq_ev_set_queue_pos_tick(ev, q, ttime) \ | |
282 ((ev)->type = SND_SEQ_EVENT_SETPOS_TICK,\ | |
283 snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\ | |
284 (ev)->data.queue.queue = (q),\ | |
285 (ev)->data.queue.param.time.tick = (ttime)) | |
286 | |
287 /* set and send a queue control event */ | |
288 int snd_seq_control_queue(snd_seq_t *seq, int q, int type, int value, snd_seq_event_t *ev); | |
289 | |
290 /** | |
291 * \brief start the specified queue | |
292 * \param seq sequencer handle | |
293 * \param q queue id to start | |
294 * \param ev optional event record (see #snd_seq_control_queue) | |
295 */ | |
296 #define snd_seq_start_queue(seq, q, ev) \ | |
297 snd_seq_control_queue(seq, q, SND_SEQ_EVENT_START, 0, ev) | |
298 | |
299 /** | |
300 * \brief stop the specified queue | |
301 * \param seq sequencer handle | |
302 * \param q queue id to stop | |
303 * \param ev optional event record (see #snd_seq_control_queue) | |
304 */ | |
305 #define snd_seq_stop_queue(seq, q, ev) \ | |
306 snd_seq_control_queue(seq, q, SND_SEQ_EVENT_STOP, 0, ev) | |
307 | |
308 /** | |
309 * \brief continue the specified queue | |
310 * \param seq sequencer handle | |
311 * \param q queue id to continue | |
312 * \param ev optional event record (see #snd_seq_control_queue) | |
313 */ | |
314 #define snd_seq_continue_queue(seq, q, ev) \ | |
315 snd_seq_control_queue(seq, q, SND_SEQ_EVENT_CONTINUE, 0, ev) | |
316 | |
317 /** | |
318 * \brief change the tempo of the specified queue | |
319 * \param seq sequencer handle | |
320 * \param q queue id | |
321 * \param tempo the new tempo value | |
322 * \param ev optional event record (see #snd_seq_control_queue) | |
323 */ | |
324 #define snd_seq_change_queue_tempo(seq, q, tempo, ev) \ | |
325 snd_seq_control_queue(seq, q, SND_SEQ_EVENT_TEMPO, tempo, ev) | |
326 | |
327 /* create a port - simple version - return the port number */ | |
328 int snd_seq_create_simple_port(snd_seq_t *seq, const char *name, | |
329 unsigned int caps, unsigned int type); | |
330 /* delete the port */ | |
331 int snd_seq_delete_simple_port(snd_seq_t *seq, int port); | |
332 | |
333 /* simple subscription between this port and another port | |
334 (w/o exclusive & time conversion) | |
335 */ | |
336 int snd_seq_connect_from(snd_seq_t *seq, int my_port, int src_client, int src_port); | |
337 int snd_seq_connect_to(snd_seq_t *seq, int my_port, int dest_client, int dest_port); | |
338 int snd_seq_disconnect_from(snd_seq_t *seq, int my_port, int src_client, int src_port); | |
339 int snd_seq_disconnect_to(snd_seq_t *seq, int my_port, int dest_client, int dest_port); | |
340 | |
341 /* | |
342 * set client information | |
343 */ | |
344 int snd_seq_set_client_name(snd_seq_t *seq, const char *name); | |
345 int snd_seq_set_client_event_filter(snd_seq_t *seq, int event_type); | |
346 int snd_seq_set_client_pool_output(snd_seq_t *seq, size_t size); | |
347 int snd_seq_set_client_pool_output_room(snd_seq_t *seq, size_t size); | |
348 int snd_seq_set_client_pool_input(snd_seq_t *seq, size_t size); | |
349 /* sync output queue */ | |
350 int snd_seq_sync_output_queue(snd_seq_t *seq); | |
351 | |
352 /* | |
353 * parse the given string and get the sequencer address | |
354 */ | |
355 int snd_seq_parse_address(snd_seq_t *seq, snd_seq_addr_t *addr, const char *str); | |
356 | |
357 /* | |
358 * reset client input/output pool | |
359 */ | |
360 int snd_seq_reset_pool_output(snd_seq_t *seq); | |
361 int snd_seq_reset_pool_input(snd_seq_t *seq); | |
362 | |
363 /** | |
364 * \brief set note event | |
365 * \param ev event record | |
366 * \param ch channel number | |
367 * \param key note key | |
368 * \param vel velocity | |
369 * \param dur duration (in tick or msec) | |
370 */ | |
371 #define snd_seq_ev_set_note(ev, ch, key, vel, dur) \ | |
372 ((ev)->type = SND_SEQ_EVENT_NOTE,\ | |
373 snd_seq_ev_set_fixed(ev),\ | |
374 (ev)->data.note.channel = (ch),\ | |
375 (ev)->data.note.note = (key),\ | |
376 (ev)->data.note.velocity = (vel),\ | |
377 (ev)->data.note.duration = (dur)) | |
378 | |
379 /** | |
380 * \brief set note-on event | |
381 * \param ev event record | |
382 * \param ch channel number | |
383 * \param key note key | |
384 * \param vel velocity | |
385 */ | |
386 #define snd_seq_ev_set_noteon(ev, ch, key, vel) \ | |
387 ((ev)->type = SND_SEQ_EVENT_NOTEON,\ | |
388 snd_seq_ev_set_fixed(ev),\ | |
389 (ev)->data.note.channel = (ch),\ | |
390 (ev)->data.note.note = (key),\ | |
391 (ev)->data.note.velocity = (vel)) | |
392 | |
393 /** | |
394 * \brief set note-off event | |
395 * \param ev event record | |
396 * \param ch channel number | |
397 * \param key note key | |
398 * \param vel velocity | |
399 */ | |
400 #define snd_seq_ev_set_noteoff(ev, ch, key, vel) \ | |
401 ((ev)->type = SND_SEQ_EVENT_NOTEOFF,\ | |
402 snd_seq_ev_set_fixed(ev),\ | |
403 (ev)->data.note.channel = (ch),\ | |
404 (ev)->data.note.note = (key),\ | |
405 (ev)->data.note.velocity = (vel)) | |
406 | |
407 /** | |
408 * \brief set key-pressure event | |
409 * \param ev event record | |
410 * \param ch channel number | |
411 * \param key note key | |
412 * \param vel velocity | |
413 */ | |
414 #define snd_seq_ev_set_keypress(ev,ch,key,vel) \ | |
415 ((ev)->type = SND_SEQ_EVENT_KEYPRESS,\ | |
416 snd_seq_ev_set_fixed(ev),\ | |
417 (ev)->data.note.channel = (ch),\ | |
418 (ev)->data.note.note = (key),\ | |
419 (ev)->data.note.velocity = (vel)) | |
420 | |
421 /** | |
422 * \brief set MIDI controller event | |
423 * \param ev event record | |
424 * \param ch channel number | |
425 * \param cc controller number | |
426 * \param val control value | |
427 */ | |
428 #define snd_seq_ev_set_controller(ev,ch,cc,val) \ | |
429 ((ev)->type = SND_SEQ_EVENT_CONTROLLER,\ | |
430 snd_seq_ev_set_fixed(ev),\ | |
431 (ev)->data.control.channel = (ch),\ | |
432 (ev)->data.control.param = (cc),\ | |
433 (ev)->data.control.value = (val)) | |
434 | |
435 /** | |
436 * \brief set program change event | |
437 * \param ev event record | |
438 * \param ch channel number | |
439 * \param val program number | |
440 */ | |
441 #define snd_seq_ev_set_pgmchange(ev,ch,val) \ | |
442 ((ev)->type = SND_SEQ_EVENT_PGMCHANGE,\ | |
443 snd_seq_ev_set_fixed(ev),\ | |
444 (ev)->data.control.channel = (ch),\ | |
445 (ev)->data.control.value = (val)) | |
446 | |
447 /** | |
448 * \brief set pitch-bend event | |
449 * \param ev event record | |
450 * \param ch channel number | |
451 * \param val pitch bend; zero centered from -8192 to 8191 | |
452 */ | |
453 #define snd_seq_ev_set_pitchbend(ev,ch,val) \ | |
454 ((ev)->type = SND_SEQ_EVENT_PITCHBEND,\ | |
455 snd_seq_ev_set_fixed(ev),\ | |
456 (ev)->data.control.channel = (ch),\ | |
457 (ev)->data.control.value = (val)) | |
458 | |
459 /** | |
460 * \brief set channel pressure event | |
461 * \param ev event record | |
462 * \param ch channel number | |
463 * \param val channel pressure value | |
464 */ | |
465 #define snd_seq_ev_set_chanpress(ev,ch,val) \ | |
466 ((ev)->type = SND_SEQ_EVENT_CHANPRESS,\ | |
467 snd_seq_ev_set_fixed(ev),\ | |
468 (ev)->data.control.channel = (ch),\ | |
469 (ev)->data.control.value = (val)) | |
470 | |
471 /** | |
472 * \brief set sysex event | |
473 * \param ev event record | |
474 * \param datalen length of sysex data | |
475 * \param dataptr sysex data pointer | |
476 * | |
477 * the sysex data must contain the start byte 0xf0 and the end byte 0xf7. | |
478 */ | |
479 #define snd_seq_ev_set_sysex(ev,datalen,dataptr) \ | |
480 ((ev)->type = SND_SEQ_EVENT_SYSEX,\ | |
481 snd_seq_ev_set_variable(ev, datalen, dataptr)) | |
482 | |
483 /** \} */ | |
484 | |
485 #ifdef __cplusplus | |
486 } | |
487 #endif | |
488 | |
489 #endif /* __ALSA_SEQMID_H */ | |
490 |