[LAD] making sense of Jack MIDI; or, is this an appropriate use for Jack?
malnourite at gmail.com
Fri Feb 15 18:19:57 UTC 2013
On Fri, Feb 15, 2013 at 10:33 AM, M Donalies <ingeniousnebbish at cox.net>wrote:
> On Friday 15 February 2013 11:12:04 Paul Davis wrote:
> > JACK does not provide sequencing facilities. It simply transports MIDI
> > between ports.
> > > If I wanted to do the sequencing myself, what would be involved?
> > a lot.
> Does that mean:
> Don't even think about it unless you're a systems programmer because
> 1000 low-level subtleties involved.
> Or is it just the tedium of turning all the midi events into binary and
> sure all the events are in order to be processed by the target (fluidsynth
> soundcard or whatever)?
> I can handle the latter, but certainly not the former. My idiot-level
> algorithm is kind of like writing realtime midi to a port and looks
> 1) My app has a buffer of the binary midi data. Jack is running and I've
> created a midi out port.
> 2) Jack let's me know what time it is through a callback.
> 3) To play, I record the current time as my starting time. Then write some
> events to the port.
> 4) Wait for another callback and write more data.
> Ok, you can stop banging your head on or desk, exclaiming "How does this
> even know how to post a message to the list!" I have the feeling this is
> equivalent of the car question, "Now tell me again, why do I have to use
> icky motor oil stuff? Pouring water in the reservoir fills it just the
> same and
> it's far less messy."
It means that you have to do that tricky 'sequencing' part, which consists
of scheduling (MIDI) events and only placing them onto the JACK buffer at
the appropriate instant. ALSA MIDI does this for you, as well as providing
a nice API for generating the MIDI events. That's not the trickiest part
though, the real mess begins when you want to deal with the JACK
Transport/Timebase API to follow or generate tempo changes.
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the Linux-audio-dev