[LAD] Problem with small ALSA rawmidi app

Frank Neumann beachnase at web.de
Thu Oct 22 22:17:12 UTC 2009


Hi,
On Thu, 22 Oct 2009 13:46:51 -0400
Paul Davis <paul at linuxaudiosystems.com> wrote:

[..]

> > What I basically do is (code excerpt / pseudo code):
> >
> > snd_rawmidi_t *handle_in = 0, *handle_out = 0;
> > unsigned char ibuf[256];
> > unsigned char obuf[] = { 0xf0, .., 0xf7 }; /* 6 bytes sysex */
> >
> > snd_rawmidi_open(&handle_in, NULL, "hw:2,0,0", SND_RAWMIDI_NONBLOCK);
> >
> > snd_rawmidi_open(NULL, &handle_out, "hw:2,0,0", SND_RAWMIDI_NONBLOCK);
> >
> > snd_rawmidi_write(handle_out, &obuf, 6);
> > snd_rawmidi_drain(handle_out);
> >
> > // wait a little for the answer
> > // I know I should not do it this way, but for testing purposes..
> > usleep(1000000);
> >
> > num = snd_rawmidi_read(handle_in, ibuf, sizeof(ibuf));
> >
> > I know that the data is sent out, but reading back the answer always gives
> > me -1 for num.
> 
> you opened both ports in NON_BLOCKing mode.
> 
> this means that a read or write will ALWAYS return immediately, no
> matter whether there is data/space for the write/read or not.

That's right, but my thinking was that "after sending out the SysEx request,
draining the outbound connection and waiting for 1 second, some data should
be available in the incoming ringbuffer". I see from amidi experiments that
the device answers pretty promptly.

But I think I just found the solution myself, though I am not sure about the
reason - from alsa-utils/amidi/amidi.c, I took over this line of code, before
sending out my data:

 snd_rawmidi_read(handle_in, NULL, 0); /* trigger reading */

So, a dummy read on the inbound connection gets it going.
Now it works as expected. Any idea why this is necessary? "buffer pre-warm"?

Greetings,
Frank







More information about the Linux-audio-dev mailing list