Re: [LAU] How to get started writing a JACK app? (also what distro for BeagleBone)

From: Paul Davis <paul@email-addr-hidden>
Date: Wed Jan 10 2018 - 23:01:55 EET

On Wed, Jan 10, 2018 at 3:48 PM, Andrew Voelkel <jandyman.voelkel@email-addr-hidden>
wrote:

> Glad to hear the discussion. From an outsider’s point of view, there are
> few things I don’t get.
>
>
>
> First, if each JACK app is a separate process, then theoretically you have
> to do a bunch of expensive process context switches for each audio buffer.
>

​In the scheme of things, a context switch is typically not very expensive
compared to a typical audio buffer size (say 16 samples and up).​ The only
way it gets unusually expensive is if a process touches a lot of memory
during its execution. This isn't impossible in an audio/DSP context, but it
isn't very likely either.

> And then there is interprocess communication. Uses shared memory buffers?
>

​it's all in shared memory. there's no communication overhead.​

As opposed to a typical plug-in architecture where everything runs under
> the host process. It is amazing to me that an interprocess scheme wouldn’t
> run into major problems under compute load when running with the small
> buffers needed for low latency.
>

​be amazed :)​

>
>
> What am I missing here?
>
>
>
> The other thing I’m used to seeing in a plug in API is setup for buffer
> sizes, sample rates, audio IO. The host centralizes this process.
>

​JACK does the same thing. Each client has no control over those things (at
least, not in the normal way).​ They can ask to change the buffer size, but
their request may be ignored, or it may be reset by something else. Just
like in a plugin architecture.

Then there is advertising your pins and capabilities. I was mystified when
> looking at the simple JACK examples that I didn’t see code for dealing with
> these issues (e.g. being sample rate aware).
>

​JACK clients have only one thing of interest to other clients: ports.
These are all clearly visible, and tagged appropriately (though for most
clients, there's almost no tagging to do)


_______________________________________________
Linux-audio-user mailing list
Linux-audio-user@email-addr-hidden
https://lists.linuxaudio.org/listinfo/linux-audio-user
Received on Thu Jan 11 00:15:03 2018

This archive was generated by hypermail 2.1.8 : Thu Jan 11 2018 - 00:15:03 EET