1 --- allegro/include/allegro/platform/alunix.h.orig Sun Dec 8 20:11:31 2002
2 +++ allegro/include/allegro/platform/alunix.h Sun Jan 26 13:29:31 2003
5 #endif /* ALLEGRO_WITH_ALSAMIDI */
7 +#ifdef ALLEGRO_WITH_ALSA9DIGI
9 +#define DIGI_ALSA9 AL_ID('A','L','S','9')
11 +#ifndef ALLEGRO_WITH_MODULES
13 +AL_VAR(DIGI_DRIVER, digi_alsa9);
15 +#define DIGI_DRIVER_ALSA9 \
16 + { DIGI_ALSA9, &digi_alsa9, TRUE },
20 +#endif /* ALLEGRO_WITH_ALSA9DIGI */
23 +#ifdef ALLEGRO_WITH_ALSA9MIDI
25 +#define MIDI_ALSA9 AL_ID('A','M','I','9')
27 +#ifndef ALLEGRO_WITH_MODULES
29 +AL_VAR(MIDI_DRIVER, midi_alsa9);
31 +#define MIDI_DRIVER_ALSA9 \
32 + { MIDI_ALSA9, &midi_alsa9, TRUE },
36 +#endif /* ALLEGRO_WITH_ALSA9MIDI */
40 /************************************/
41 diff -uNr allegro-4.1.6.old/acconfig.h allegro-4.1.6/acconfig.h
42 --- allegro-4.1.6.old/acconfig.h Sat Nov 30 12:13:21 2002
43 +++ allegro-4.1.6/acconfig.h Fri Dec 6 17:40:10 2002
45 /* Define if ALSA MIDI driver is supported. */
46 #undef ALLEGRO_WITH_ALSAMIDI
48 +/* Define if ALSA9 DIGI driver is supported. */
49 +#undef ALLEGRO_WITH_ALSA9DIGI
51 +/* Define if ALSA9 MIDI driver is supported. */
52 +#undef ALLEGRO_WITH_ALSA9MIDI
54 /* Define if ESD DIGI driver is supported. */
55 #undef ALLEGRO_WITH_ESDDIGI
57 diff -uNr allegro-4.1.6.old/aclocal.m4 allegro-4.1.6/aclocal.m4
58 --- allegro-4.1.6.old/aclocal.m4 Sat Nov 30 12:13:21 2002
59 +++ allegro-4.1.6/aclocal.m4 Fri Dec 6 17:40:10 2002
64 +dnl Test for ALSA9 DIGI driver.
67 +dnl allegro_enable_alsa9digi=(yes|)
68 +dnl allegro_cv_support_alsa9digi=(yes|)
70 +AC_DEFUN(ALLEGRO_ACTEST_ALSA9DIGI,
71 +[AC_ARG_ENABLE(alsa9digi,
72 +[ --enable-alsa9digi[=x] enable building ALSA9 DIGI driver [default=yes]],
73 +test "X$enableval" != "Xno" && allegro_enable_alsa9digi=yes,
74 +allegro_enable_alsa9digi=yes)
76 +if test -n "$allegro_enable_alsa9digi"; then
77 + AC_CACHE_CHECK(for supported ALSA9 version for digital sound,
78 + allegro_cv_support_alsa9digi,
79 + AC_TRY_RUN([#include <alsa/asoundlib.h>
80 + int main (void) { return SND_LIB_MAJOR != 0 || SND_LIB_MINOR != 9; }],
81 + allegro_cv_support_alsa9digi=yes,
82 + allegro_cv_support_alsa9digi=no,
83 + allegro_cv_support_alsa9digi=no))
84 + if test "X$allegro_cv_support_alsa9digi" = "Xyes" &&
85 + test -z "$allegro_support_modules"; then
86 + LIBS="-lasound $LIBS"
91 +dnl Test for ALSA9 MIDI driver.
94 +dnl allegro_enable_alsa9midi=(yes|)
95 +dnl allegro_support_alsa9midi=(yes|)
97 +AC_DEFUN(ALLEGRO_ACTEST_ALSA9MIDI,
98 +[AC_ARG_ENABLE(alsa9midi,
99 +[ --enable-alsa9midi[=x] enable building ALSA9 MIDI driver [default=yes]],
100 +test "X$enableval" != "Xno" && allegro_enable_alsa9midi=yes,
101 +allegro_enable_alsa9midi=yes)
103 +if test -n "$allegro_enable_alsa9midi"; then
104 + AC_CACHE_CHECK(for supported ALSA9 version for MIDI,
105 + allegro_cv_support_alsa9midi,
106 + AC_TRY_RUN([#include <alsa/asoundlib.h>
107 + int main (void) { return SND_LIB_MAJOR != 0 || SND_LIB_MINOR != 9; }],
108 + allegro_cv_support_alsa9midi=yes,
109 + allegro_cv_support_alsa9midi=no,
110 + allegro_cv_support_alsa9midi=no))
111 + if test "X$allegro_cv_support_alsa9midi" = "Xyes" &&
112 + test -z "$allegro_support_modules"; then
113 + LIBS="-lasound $LIBS"
118 dnl Test for ESD DIGI driver.
121 diff -uNr allegro-4.1.6.old/allegro.mft allegro-4.1.6/allegro.mft
122 --- allegro-4.1.6.old/allegro.mft Sat Nov 30 12:18:28 2002
123 +++ allegro-4.1.6/allegro.mft Fri Dec 6 17:40:10 2002
126 allegro/src/unix/alsa.c
127 allegro/src/unix/alsamidi.c
128 +allegro/src/unix/alsa9.c
129 +allegro/src/unix/alsa9midi.c
130 allegro/src/unix/arts.c
131 allegro/src/unix/sgial.c
132 allegro/src/unix/udjgpp.c
133 diff -uNr allegro-4.1.6.old/configure.in allegro-4.1.6/configure.in
134 --- allegro-4.1.6.old/configure.in Sat Nov 30 12:13:21 2002
135 +++ allegro-4.1.6/configure.in Fri Dec 6 17:40:10 2002
137 AC_DEFINE(ALLEGRO_WITH_ALSAMIDI)
140 +dnl Test for ALSA9 drivers.
141 +ALLEGRO_ACTEST_ALSA9DIGI
142 +if test "$allegro_cv_support_alsa9digi" = yes; then
143 + AC_DEFINE(ALLEGRO_WITH_ALSA9DIGI)
146 +ALLEGRO_ACTEST_ALSA9MIDI
147 +if test "$allegro_cv_support_alsa9midi" = yes; then
148 + AC_DEFINE(ALLEGRO_WITH_ALSA9MIDI)
151 dnl Test for ESD drivers.
152 ALLEGRO_ACTEST_ESDDIGI
153 if test -n "$allegro_support_esddigi"; then
155 ALLEGRO_MODULE_TARGETS="$ALLEGRO_MODULE_TARGETS lib/unix/alleg-alsamidi.so"
159 + if test "X$allegro_cv_support_alsa9digi" = "Xyes"; then
160 + ALLEGRO_MODULE_TARGETS="$ALLEGRO_MODULE_TARGETS lib/unix/alleg-alsa9digi.so"
164 + if test "X$allegro_cv_support_alsa9midi" = "Xyes"; then
165 + ALLEGRO_MODULE_TARGETS="$ALLEGRO_MODULE_TARGETS lib/unix/alleg-alsa9midi.so"
169 if test "X$allegro_support_esddigi" = "Xyes"; then
170 ALLEGRO_MODULE_TARGETS="$ALLEGRO_MODULE_TARGETS lib/unix/alleg-esddigi.so"
171 diff -uNr allegro-4.1.6.old/makefile.in allegro-4.1.6/makefile.in
172 --- allegro-4.1.6.old/makefile.in Fri Dec 6 17:39:38 2002
173 +++ allegro-4.1.6/makefile.in Fri Dec 6 17:40:10 2002
175 $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh dga2 -lXxf86dga $(ALLEGRO_MODULE_DGA2_FILES)' >> makefile.dep
176 $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh alsadigi -lasound $(ALLEGRO_MODULE_ALSADIGI_FILES)' >>makefile.dep
177 $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh alsamidi -lasound $(ALLEGRO_MODULE_ALSAMIDI_FILES)' >>makefile.dep
178 + $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh alsa9digi -lasound $(ALLEGRO_MODULE_ALSA9DIGI_FILES)' >>makefile.dep
179 + $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh alsa9midi -lasound $(ALLEGRO_MODULE_ALSA9MIDI_FILES)' >>makefile.dep
180 $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh esddigi "\`esd-config --libs\`" $(ALLEGRO_MODULE_ESD_FILES)' >>makefile.dep
181 $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh artsdigi "\`artsc-config --libs\`" $(ALLEGRO_MODULE_ARTS_FILES)' >>makefile.dep
182 $(SHELL) -c 'cd $(srcdir) && misc/depmod.sh sgialdigi -laudio $(ALLEGRO_MODULE_SGIAL_FILES)' >>makefile.dep
183 diff -uNr allegro-4.1.6.old/makefile.lst allegro-4.1.6/makefile.lst
184 --- allegro-4.1.6.old/makefile.lst Sat Nov 30 12:13:21 2002
185 +++ allegro-4.1.6/makefile.lst Fri Dec 6 17:40:10 2002
187 ALLEGRO_SRC_UNIX_FILES = \
189 src/unix/alsamidi.c \
191 + src/unix/alsa9midi.c \
196 ALLEGRO_MODULE_ALSAMIDI_FILES = \
199 +ALLEGRO_MODULE_ALSA9DIGI_FILES = \
202 +ALLEGRO_MODULE_ALSA9MIDI_FILES = \
203 + src/unix/alsa9midi.c
205 ALLEGRO_MODULE_ESD_FILES = \
208 diff -uNr allegro-4.1.6.old/modules.lst allegro-4.1.6/modules.lst
209 --- allegro-4.1.6.old/modules.lst Sat Nov 30 12:13:21 2002
210 +++ allegro-4.1.6/modules.lst Fri Dec 6 17:40:10 2002
217 diff -uNr allegro-4.1.6.old/setup/setup.c allegro-4.1.6/setup/setup.c
218 --- allegro-4.1.6.old/setup/setup.c Sat Nov 30 12:13:22 2002
219 +++ allegro-4.1.6/setup/setup.c Fri Dec 6 17:42:22 2002
221 { "alsa_rawmidi_card", param_int, "", "", NULL, "Card:", NULL, NULL, "ALSA RawMIDI card number" },
222 { "alsa_rawmidi_device",param_int, "", "", NULL, "Dev:", NULL, NULL, "ALSA RawMIDI device number" },
226 + { "alsa_card", param_int, "", "", NULL, "Card:", NULL, NULL, "ALSA card number" },
227 + { "alsa_pcmdevice", param_int, "", "", NULL, "Dev:", NULL, NULL, "ALSA PCM device number" },
228 + { "alsa_numfrags", param_int, "", "", NULL, "NumFr:", NULL, NULL, "Number of fragments (use 2, other values make little difference)" },
232 + { "alsa_rawmidi_card", param_int, "", "", NULL, "Card:", NULL, NULL, "ALSA RawMIDI card number" },
233 + { "alsa_rawmidi_device",param_int, "", "", NULL, "Dev:", NULL, NULL, "ALSA RawMIDI device number" },
237 { "be_midi_quality", param_int, "", "1", NULL, "Qual:", NULL, NULL, "BeOS MIDI synthetizer instruments quality (0 = low, 1 = high)" },
245 + static char *param[] = {"flip_pan", "sound_bits", "sound_stereo", "alsa_numfrags", "alsa_card", "alsa_pcmdevice", "sound_freq", "digi_volume", NULL};
246 + digi_cards[c].param = uconvert_static_string_array(param);
247 + digi_cards[c].desc = uconvert_static_string("ALSA Sound System");
257 static char *param[] = {"22", "alsa_rawmidi_card", "alsa_rawmidi_device", "", "midi_volume", NULL};
258 midi_cards[c].param = uconvert_static_string_array(param);
259 + midi_cards[c].desc = uconvert_static_string("ALSA RawMIDI");
267 + static char *param[] = {"22", "alsa_rawmidi_card", "alsa_rawmidi_device", "", "midi_volume", NULL};
268 + midi_cards[c].param = uconvert_static_string_array(param);
269 midi_cards[c].desc = uconvert_static_string("ALSA RawMIDI");
272 diff -uNr allegro-4.1.6.old/src/unix/alsa9.c allegro-4.1.6/src/unix/alsa9.c
273 --- allegro-4.1.6.old/src/unix/alsa9.c Thu Jan 1 01:00:00 1970
274 +++ allegro-4.1.6/src/unix/alsa9.c Mon Oct 28 21:20:48 2002
277 + * /\ _ \ /\_ \ /\_ \
278 + * \ \ \L\ \\//\ \ \//\ \ __ __ _ __ ___
279 + * \ \ __ \ \ \ \ \ \ \ /'__`\ /'_ `\/\`'__\/ __`\
280 + * \ \ \/\ \ \_\ \_ \_\ \_/\ __//\ \L\ \ \ \//\ \L\ \
281 + * \ \_\ \_\/\____\/\____\ \____\ \____ \ \_\\ \____/
282 + * \/_/\/_/\/____/\/____/\/____/\/___L\ \/_/ \/___/
286 + * ALSA 0.9 sound driver.
288 + * By Grzegorz Godlewski based on Alsa 0.5, OSS and MPlayer 0.9
290 + * See readme.txt for copyright information.
294 +#include "allegro.h"
296 +#if (defined DIGI_ALSA9) && ((!defined ALLEGRO_WITH_MODULES) || (defined ALLEGRO_MODULE))
298 +#include "allegro/internal/aintern.h"
300 +#include "allegro/platform/aintqnx.h"
302 +#include "allegro/platform/aintunix.h"
306 + #include <string.h>
307 + #include <alsa/asoundlib.h>
310 +#ifndef SND_PCM_FORMAT_S16_NE
311 + #ifdef ALLEGRO_BIG_ENDIAN
312 + #define SND_PCM_FORMAT_S16_NE SND_PCM_FORMAT_S16_BE
314 + #define SND_PCM_FORMAT_S16_NE SND_PCM_FORMAT_S16_LE
317 +#ifndef SND_PCM_FORMAT_U16_NE
318 + #ifdef ALLEGRO_BIG_ENDIAN
319 + #define SND_PCM_FORMAT_U16_NE SND_PCM_FORMAT_U16_BE
321 + #define SND_PCM_FORMAT_U16_NE SND_PCM_FORMAT_U16_LE
326 +#define ALSA9_DEFAULT_NUMFRAGS 2
327 +#define ALSA9_DEFAULT_FRAGSIZE 8192
329 +static snd_pcm_t *pcm_handle=NULL;
330 +static int alsa9_bufsize;
331 +static unsigned char *alsa9_bufdata;
332 +static int alsa9_bits, alsa9_signed, alsa9_rate, alsa9_stereo;
333 +static int periods,periodsize;
335 +static char alsa9_desc[256] = EMPTY_STRING;
339 +static int alsa9_detect(int input);
340 +static int alsa9_init(int input, int voices);
341 +static void alsa9_exit(int input);
342 +static int alsa9_mixer_volume(int volume);
343 +static int alsa9_buffer_size(void);
347 +DIGI_DRIVER digi_alsa9 =
361 + alsa9_mixer_volume,
367 + _mixer_release_voice,
368 + _mixer_start_voice,
372 + _mixer_get_position,
373 + _mixer_set_position,
377 + _mixer_ramp_volume,
378 + _mixer_stop_volume_ramp,
380 + _mixer_get_frequency,
381 + _mixer_set_frequency,
382 + _mixer_sweep_frequency,
383 + _mixer_stop_frequency_sweep,
388 + _mixer_stop_pan_sweep,
391 + _mixer_set_tremolo,
392 + _mixer_set_vibrato,
404 +/* alsa9_buffer_size:
405 + * Returns the current DMA buffer size, for use by the audiostream code.
407 +static int alsa9_buffer_size()
409 + return alsa9_bufsize;
415 +static void alsa9_update(int threaded)
420 + printf("alsa-play: device configuration error");
424 + frames = periodsize >> ((alsa9_stereo)?3:2);
425 + while (snd_pcm_writei(pcm_handle, alsa9_bufdata, frames) <0)
427 + snd_pcm_prepare(pcm_handle);
429 + _mix_some_samples((unsigned long) alsa9_bufdata, 0, alsa9_signed);
435 + * Detect driver presence.
437 +static int alsa9_detect(int input)
441 + char tmp1[128], tmp2[128];
443 + snd_pcm_hw_params_t *hwparams;
444 + char pcm_name[128];
446 + card = get_config_int(uconvert_ascii("sound", tmp1),
447 + uconvert_ascii("alsa_card", tmp2),
450 + device = get_config_int(uconvert_ascii("sound", tmp1),
451 + uconvert_ascii("alsa_pcmdevice", tmp2),
455 + sprintf(pcm_name,"plughw:%d,%d",card,device);
456 + snd_pcm_hw_params_alloca(&hwparams);
458 + if (!(snd_pcm_open(&handle, pcm_name, SND_PCM_STREAM_PLAYBACK , 0) < 0)) {
459 + if (!(snd_pcm_hw_params_any(handle, hwparams) < 0)) {
462 + snd_pcm_close(handle);
471 + * ALSA9 init routine.
473 +static int alsa9_init(int input, int voices)
476 + int format, bps; //, fragsize, numfrags;
477 + char tmp1[128], tmp2[128];
481 + snd_pcm_hw_params_t *hwparams;
482 + char pcm_name[128];
485 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Input is not supported"));
490 + card = get_config_int(uconvert_ascii("sound", tmp1),
491 + uconvert_ascii("alsadigi_card", tmp2),
492 + 0); //snd_defaults_card());
494 + device = get_config_int(uconvert_ascii("sound", tmp1),
495 + uconvert_ascii("alsadigi_pcmdevice", tmp2),
496 + 0); //snd_defaults_pcm_device());
498 + periodsize = get_config_int(uconvert_ascii("sound", tmp1),
499 + uconvert_ascii("alsa_fragsize", tmp2),
500 + ALSA9_DEFAULT_FRAGSIZE);
502 + periods = get_config_int(uconvert_ascii("sound", tmp1),
503 + uconvert_ascii("alsa_numfrags", tmp2),
504 + ALSA9_DEFAULT_NUMFRAGS);
506 + sprintf(pcm_name,"plughw:%d,%d",card,device);
507 + snd_pcm_hw_params_alloca(&hwparams);
509 + /* Open PCM device. */
510 + if (snd_pcm_open(&pcm_handle, pcm_name, (SND_PCM_STREAM_PLAYBACK), 0) < 0) {
511 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Can not open card/pcm device"));
515 + /* Init hwparams with full configuration space */
516 + if (snd_pcm_hw_params_any(pcm_handle, hwparams) < 0) {
517 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Can not configure this PCM device"));
521 + if (snd_pcm_hw_params_set_access(pcm_handle, hwparams, SND_PCM_ACCESS_RW_INTERLEAVED) < 0) {
522 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Error setting access"));
526 + /* Set format variables. */
527 + alsa9_bits = (_sound_bits == 8) ? 8 : 16;
528 + alsa9_stereo = (_sound_stereo) ? 1 : 0;
529 + alsa9_rate = (_sound_freq > 0) ? _sound_freq : 44100;
531 + format = ((alsa9_bits == 16) ? SND_PCM_FORMAT_S16_NE : SND_PCM_FORMAT_S8);
534 + bps = alsa9_rate * (alsa9_stereo ? 2 : 1);
536 + case SND_PCM_FORMAT_S8:
538 + case SND_PCM_FORMAT_U8:
541 + case SND_PCM_FORMAT_S16_NE:
543 + case SND_PCM_FORMAT_U16_NE:
546 + if (sizeof(short) != 2) {
547 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Unsupported sample format"));
552 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Unsupported sample format"));
556 + /* Set sample format */
557 + if (snd_pcm_hw_params_set_format(pcm_handle, hwparams, format) < 0) {
558 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Error setting format"));
563 + /* Set sample rate. If the exact rate is not supported */
564 + /* by the hardware, use nearest possible rate. */
565 + exact_rate=snd_pcm_hw_params_set_rate_near(pcm_handle, hwparams, alsa9_rate, &dir);
568 + //fprintf(stderr, "The rate %d Hz is not supported by your hardware.\n
569 + // ==> Using %d Hz instead.\n", rate, exact_rate);
570 +// ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("The rate is not supported by your hardware"));
574 + /* Set number of channels */
575 + if (snd_pcm_hw_params_set_channels(pcm_handle, hwparams, (alsa9_stereo) ? 2:1) < 0) {
576 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Error setting channels"));
580 + /* Set number of numfrags. numfrags used to be called fragments. */
581 + if (snd_pcm_hw_params_set_periods(pcm_handle, hwparams, periods, 0) < 0) {
582 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Error setting numfrags"));
586 + alsa9_bufsize=(periodsize * periods)>>2;
587 + /* Set buffer size (in frames). The resulting latency is given by */
588 + /* latency = fragsize * numfrags / (rate * bytes_per_frame) */
589 + if (snd_pcm_hw_params_set_buffer_size(pcm_handle, hwparams, alsa9_bufsize) < 0) {
590 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Error setting buffersize"));
594 + /* Apply HW parameter settings to */
595 + /* PCM device and prepare device */
596 + if (snd_pcm_hw_params(pcm_handle, hwparams) < 0) {
597 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Error setting HW params"));
601 + alsa9_bufdata = malloc(alsa9_bufsize);
603 + if (!alsa9_bufdata) {
604 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Can not allocate audio buffer"));
608 + /* Initialise mixer. */
609 + digi_alsa9.voices = voices;
611 + if (_mixer_init(alsa9_bufsize / (alsa9_bits / 8), alsa9_rate,
612 + alsa9_stereo, ((alsa9_bits == 16) ? 1 : 0),
613 + &digi_alsa9.voices) != 0) {
614 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text("Can not init software mixer"));
618 + _mix_some_samples((unsigned long) alsa9_bufdata, 0, alsa9_signed);
620 + /* Add audio interrupt. */
621 + _unix_bg_man->register_func(alsa9_update);
623 + uszprintf(alsa9_desc, sizeof(alsa9_desc),
624 + get_config_text("Card #%d, device #%d: %d bits, %s, %d bps, %s"),
625 + card, device, alsa9_bits,
626 + uconvert_ascii((alsa9_signed ? "signed" : "unsigned"), tmp1),
628 + uconvert_ascii((alsa9_stereo ? "stereo" : "mono"), tmp2));
630 + digi_driver->desc = alsa9_desc;
636 + snd_pcm_close(pcm_handle);
646 + * Shutdown ALSA9 driver.
648 +static void alsa9_exit(int input)
654 + _unix_bg_man->unregister_func(alsa9_update);
656 + free(alsa9_bufdata);
657 + alsa9_bufdata = NULL;
661 + snd_pcm_close(pcm_handle);
666 +/* alsa9_mixer_volume:
667 + * Set mixer volume (0-255)
669 +static int alsa9_mixer_volume(int volume)
673 + snd_mixer_t *handle;
676 + if (snd_mixer_open(&handle, card, device) == 0) {
677 + /* do something special */
678 + snd_mixer_close(handle);
690 +#ifdef ALLEGRO_MODULE
693 + * Called when loaded as a dynamically linked module.
695 +void _module_init(int system_driver)
697 + _unix_register_digi_driver(DIGI_ALSA9, &digi_alsa9, TRUE, TRUE);
704 diff -uNr allegro-4.1.6.old/src/unix/alsa9midi.c allegro-4.1.6/src/unix/alsa9midi.c
705 --- allegro-4.1.6.old/src/unix/alsa9midi.c Thu Jan 1 01:00:00 1970
706 +++ allegro-4.1.6/src/unix/alsa9midi.c Mon Oct 28 20:51:06 2002
709 + * /\ _ \ /\_ \ /\_ \
710 + * \ \ \L\ \\//\ \ \//\ \ __ __ _ __ ___
711 + * \ \ __ \ \ \ \ \ \ \ /'__`\ /'_ `\/\`'__\/ __`\
712 + * \ \ \/\ \ \_\ \_ \_\ \_/\ __//\ \L\ \ \ \//\ \L\ \
713 + * \ \_\ \_\/\____\/\____\ \____\ \____ \ \_\\ \____/
714 + * \/_/\/_/\/____/\/____/\/____/\/___L\ \/_/ \/___/
718 + * ALSA 0.9 RawMIDI Sound driver.
720 + * By Grzegorz Godlewski based on 0.5 version
722 + * See readme.txt for copyright information.
725 +#include "allegro.h"
727 +#if (defined MIDI_ALSA9) && ((!defined ALLEGRO_WITH_MODULES) || (defined ALLEGRO_MODULE))
729 +#include "allegro/internal/aintern.h"
731 +#include "allegro/platform/aintqnx.h"
733 +#include "allegro/platform/aintunix.h"
737 + #include <stdlib.h>
739 + #include <string.h>
741 + #include <sys/asoundlib.h>
744 +/* external interface to the ALSA9 rawmidi driver */
745 +static int alsa9_rawmidi_detect(int input);
746 +static int alsa9_rawmidi_init(int input, int voices);
747 +static void alsa9_rawmidi_exit(int input);
748 +static void alsa9_rawmidi_output(int data);
750 +static char alsa9_rawmidi_desc[256];
752 +static snd_rawmidi_t *rawmidi_handle = NULL;
754 +MIDI_DRIVER midi_alsa9 =
756 + MIDI_ALSA9, /* id */
757 + empty_string, /* name */
758 + empty_string, /* desc */
759 + "ALSA9 RawMIDI", /* ASCII name */
760 + 0, 0, 0xFFFF, 0, -1, -1, /* voices, basevoice, max_voices, def_voices, xmin, xmax */
761 + alsa9_rawmidi_detect, /* detect */
762 + alsa9_rawmidi_init, /* init */
763 + alsa9_rawmidi_exit, /* exit */
764 + NULL, /* mixer_volume */
765 + alsa9_rawmidi_output, /* raw_midi */
766 + _dummy_load_patches, /* load_patches */
767 + _dummy_adjust_patches, /* adjust_patches */
768 + _dummy_key_on, /* key_on */
769 + _dummy_noop1, /* key_off */
770 + _dummy_noop2, /* set_volume */
771 + _dummy_noop3, /* set_pitch */
772 + _dummy_noop2, /* set_pan */
773 + _dummy_noop2 /* set_vibrato */
776 +/* alsa9_rawmidi_detect:
777 + * ALSA9 RawMIDI detection.
779 +static int alsa9_rawmidi_detect(int input)
783 + int ret = FALSE, err;
784 + char tmp1[128], tmp2[128], temp[256];
785 + snd_rawmidi_t *handle = NULL;
786 + char pcm_name[128];
789 + /* Input not supported.
790 + card = get_config_int(uconvert_ascii("sound", tmp1),
791 + uconvert_ascii("alsa_rawmidi_input_card", tmp2),
792 + 0); // snd_defaults_rawmidi_card());
794 + device = get_config_int(uconvert_ascii("sound", tmp1),
795 + uconvert_ascii("alsa_rawmidi_input_device", tmp2),
796 + 0); // snd_defaults_rawmidi_device());
798 + sprintf(pcm_name,"plughw:%d,%d",card,device);
799 + if ((err = snd_rawmidi_open(&handle, NULL,pcm_name, SND_RAWMIDI_OPEN_INPUT)) < 0) {
800 + snprintf(temp, sizeof(temp), "Could not open card/rawmidi device: %s", snd_strerror(err));
801 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text(temp));
805 + snd_rawmidi_close(handle);
812 + card = get_config_int(uconvert_ascii("sound", tmp1),
813 + uconvert_ascii("alsa_rawmidi_card", tmp2),
814 + 0); // snd_defaults_rawmidi_card());
816 + device = get_config_int(uconvert_ascii("sound", tmp1),
817 + uconvert_ascii("alsa_rawmidi_device", tmp2),
818 + 0); // snd_defaults_rawmidi_device());
820 + sprintf(pcm_name,"plughw:%d,%d",card,device);
821 +// if ((err = snd_rawmidi_open(NULL,&handle, pcm_name, SND_RAWMIDI_APPEND)) < 0) {
822 + if ((err = snd_rawmidi_open(NULL,&handle, "default", SND_RAWMIDI_APPEND)) < 0) {
823 + snprintf(temp, sizeof(temp), "Could not open card/rawmidi device: %s", snd_strerror(err));
824 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text(temp));
828 + snd_rawmidi_close(handle);
836 +/* alsa9_rawmidi_init:
837 + * Setup the ALSA RawMIDI interface.
839 +static int alsa9_rawmidi_init(int input, int voices)
844 + char tmp1[128], tmp2[128], temp[256];
845 +// snd_rawmidi_info_t info;
846 + char pcm_name[128];
849 + /* Input not supported
850 + card = get_config_int(uconvert_ascii("sound", tmp1),
851 + uconvert_ascii("alsa_rawmidi_input_card", tmp2),
852 + 0); // snd_defaults_rawmidi_card());
854 + device = get_config_int(uconvert_ascii("sound", tmp1),
855 + uconvert_ascii("alsa_rawmidi_input_device", tmp2),
856 + 0); // snd_defaults_rawmidi_device());
858 + sprintf(pcm_name,"plughw:%d,%d",card,device);
859 + if ((err = snd_rawmidi_open(&rawmidi_handle, NULL,pcm_name, SND_RAWMIDI_OPEN_INPUT)) < 0) {
860 + snprintf(temp, sizeof(temp), "Could not open card/rawmidi device: %s", snd_strerror(err));
861 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text(temp));
870 + card = get_config_int(uconvert_ascii("sound", tmp1),
871 + uconvert_ascii("alsa_rawmidi_card", tmp2),
872 + 0); // snd_defaults_rawmidi_card());
874 + device = get_config_int(uconvert_ascii("sound", tmp1),
875 + uconvert_ascii("alsa_rawmidi_device", tmp2),
876 + 0); // snd_defaults_rawmidi_device());
878 + sprintf(pcm_name,"plughw:%d,%d",card,device);
880 +// if ((err = snd_rawmidi_open(NULL,&rawmidi_handle, pcm_name, SND_RAWMIDI_APPEND)) < 0) {
881 + if ((err = snd_rawmidi_open(NULL,&rawmidi_handle, "default", SND_RAWMIDI_APPEND)) < 0) {
882 + snprintf(temp, sizeof(temp), "Could not open card/rawmidi device: %s", snd_strerror(err));
883 + ustrzcpy(allegro_error, ALLEGRO_ERROR_SIZE, get_config_text(temp));
890 + if(rawmidi_handle) {
891 + snd_rawmidi_block_mode(rawmidi_handle, 1);
892 +// snd_rawmidi_info(rawmidi_handle, &info);
894 +// strcpy(alsa9_rawmidi_desc, info.name);
895 +// midi_alsa9.desc = alsa9_rawmidi_desc;
897 + LOCK_VARIABLE(alsa9_rawmidi_desc);
898 + LOCK_VARIABLE(rawmidi_handle);
899 + LOCK_VARIABLE(midi_alsa9);
900 + LOCK_FUNCTION(alsa9_rawmidi_output);
906 +/* alsa9_rawmidi_exit:
909 +static void alsa9_rawmidi_exit(int input)
911 + if(rawmidi_handle) {
912 + snd_rawmidi_output_drain(rawmidi_handle);
913 + snd_rawmidi_close(rawmidi_handle);
916 + rawmidi_handle = NULL;
919 +/* alsa9_rawmidi_output:
920 + * Outputs MIDI data.
922 +static void alsa9_rawmidi_output(int data)
926 + err = snd_rawmidi_write(rawmidi_handle, &data, sizeof(char));
929 +END_OF_STATIC_FUNCTION(alsa9_rawmidi_output);
931 +/* alsa9_rawmidi_input:
934 +static INLINE int alsa9_rawmidi_input(void)
938 + if(snd_rawmidi_read(rawmidi_handle, &data, sizeof(char)) > 0)
945 +#ifdef ALLEGRO_MODULE
948 + * Called when loaded as a dynamically linked module.
950 +void _module_init(int system_driver)
952 + _unix_register_midi_driver(MIDI_ALSA9, &midi_alsa9, TRUE, TRUE);
955 +#endif /* ALLEGRO_MODULE */
957 +#endif /* MIDI_ALSA9 */