seq.h 32 KB

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