[LAD] [Jack-Devel] jack2's dbus name
Lennart Poettering
mzynq at 0pointer.de
Thu Jun 18 18:45:31 UTC 2009
On Thu, 18.06.09 13:51, Paul Davis (paul at linuxaudiosystems.com) wrote:
> On Thu, Jun 18, 2009 at 12:21 PM, Lennart Poettering <mzynq at 0pointer.de>wrote:
>
> >
> >
> > This is a bit more complex than you might think. Jack's thread
> > management is very unflexible and insists on controlling the entire
> > thread life cycle, only calling into client code in very few
> > occasions.
>
>
> You might want to check out the more recent API additions:
>
> jack_cycle_wait()
> jack_cycle_signal()
>
> which were created for precisely the sort of reasons you are describing.
That sounds like it was what I need.
So, how would I use this? I figure something like this:
<snip>
void* my_thread(void*arg) {
for (;;) {
n = jack_cycle_wait(client);
process_my_data(n);
jack_cycle_signal(client, 0);
do_my_other_work_if_there_is_any();
}
}
jack_set_process_thread(client, foo_func);
</snip>
Is that the rough idea? Hmm, with the other RT loops I have in PA I
usually just dispatch a single my own events and then immediately
check the IO device again, possibly dealing with the IO stuff first,
and only after finishing that I dispatch the next of my own events and
immediately check for IO again. That way I make sure that IO always
takes priority over dispatching those events. i.e. something along the
lines of:
<snip>
void *my_thread(void *arg) {
for (;;) {
n = how_much_shall_i_process();
if (n > 0) {
process_my_data(n);
continue;
}
n = how_many_events_to_dispatch();
if (n > 0) {
process_one_event();
continue;
}
wait_for_io();
}
</snip>
So, to map this to JACK, I would prefer if jack_cycle_wait() would
also exist in a non-blocking variant. i.e. something that can return 0
if there's nothing to process, but doesn't necessarily wait.
(we probably should stop the cross-posting, though)
Lennart
--
Lennart Poettering Red Hat, Inc.
lennart [at] poettering [dot] net
http://0pointer.net/lennart/ GnuPG 0x1A015CC4
More information about the Linux-audio-dev
mailing list