fluid-dev
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [fluid-dev] JACK kick-out on startup


From: David Henningsson
Subject: Re: [fluid-dev] JACK kick-out on startup
Date: Sun, 06 Feb 2011 21:06:34 +0100
User-agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.2.13) Gecko/20101208 Thunderbird/3.1.7

On 2011-02-06 12:32, Krzysztof Foltman wrote:
Hi all,

While trying to use Fluidsynth 1.1.3 with JACK in realtime mode, I've
noticed that Fluidsynth tends to get removed from the graph on first
processed block, due to excessive time spent in the process function.
This makes it practically impossible to use Fluidsynth in that context.

I've looked at the code, and isolated the problem to the
new_fluid_chorus function called from event handling code, as the first
event to be handled. This function not only calls malloc (non RT-safe),
but also calculates a 1280-item sinc table and zeroes a delay line -
which might take plenty of time that might not be available in realtime
callback.

I think there are some improvements that might make Fluidsynth
compatible with realtime mode:

1. Pre-allocating the chorus object. Changing the sample rate doesn't
require full removal and re-creation of the chorus object, it's probably
enough to just update the sinc values and some other things.

2. Not changing lookup table size depending on sample rate - a fixed
size table plus interpolation might be good enough for chorus.

3. Not using fluid_rvoice_mixer_set_samplerate event when not required,
and certainly not at startup. It's probably sufficient to query sample
rate on startup and set it in non-realtime context. This won't help when
sample rate is changed "on the fly", but it's a very uncommon scenario,
and not currently possible with JACK.

Or maybe the first batch of events could be dispatched before sound
processing is started - in case of JACK, that would be before a call to
jack_activate, from a non-realtime thread. This way, all the "startup"
events would be processed with no realtime requirement, which would
sidestep the problem with new_fluid_chorus.

Thanks for the report and the analysis!

The last paragraph outlines the correct solution IMO. Would it be possible for you to test the attached patch and see if it solves the problem for you?

// David


Attachment: jack_flush_queue.patch
Description: Text Data


reply via email to

[Prev in Thread] Current Thread [Next in Thread]