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

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

 



As Benoit suggested, there are plugin APIs on Linux too (both LV2 and LinuxVST). If you would write an AU for MacOS, you could write a plugin on Linux too. There are plentiful hosts, some of them extremely lightweight (i.e. they don't really do anything themselves).

Normal JACK clients introduce a tiny amount of overhead and add no latency whatsoever. It is quite common (unfortunately in my view these days) to implement things as JACK clients (i.e. standalone programs) on Linux, rather than as plugins (though this changing).


On Tue, Jan 9, 2018 at 11:07 PM, Andrew Voelkel <jandyman.voelkel@xxxxxxxxx> wrote:

Hi,

 

Maybe I need to ask a different question. My goal is to stick my real time processing algorithm in between x number of audio inputs coming from a USB audio interface, and then send the outputs to y number of audio outputs on the same USB audio interface. Low latency is important. Being able to add in other processing from third parties would be nice, but it isn’t essential.

 

Is writing a JACK client the right way to do this? If so, what is the right approach? If not, what is the right way to do this? 

 

On the Apple platform, I do this by writing an Audio Unit, and either leverage a DAW host application like Logic or the Apple AVAudioEngine to serve as a host for my processing algorithm. The host gets the inputs from the audio interface, I process the audio in my Audio Unit in a callback routine, and the host sends the outputs to the audio interface. In Windows a similar thing happens, but with VST plugins and an ASIO host, which is either a DAW or a custom ASIO host. I’ve done both.

 

So what is the best “linux way” to do this? Out-of-process seems high overhead and not suited for low latency, so I figure I must be misunderstanding something quite fundamental.

 

Thanks so much for the help, I really do appreciate it.

 

  • Andy

 

From: Paul Davis <paul@xxxxxxxxxxxxxxxxxxxxx>
Date: Tuesday, January 9, 2018 at 8:22 PM
To: Andrew Voelkel <jandyman.voelkel@xxxxxxxxx>
Cc: Benoît Rouits <brouits@xxxxxxx>, linux-audio-user <linux-audio-user@lists.linuxaudio.org>
Subject: Re: How to get started writing a JACK app? (also what distro for BeagleBone)

 

In-process JACK clients are a very special case and almost nobody implements or uses them. They are like plugins for the JACK server, and that's not really the point of JACK (which was designed to connect distinct processes).

Look at the out-of-process ("normal") example(s) instead.

 

On Tue, Jan 9, 2018 at 9:39 PM, Andrew Voelkel <jandyman.voelkel@xxxxxxxxx> wrote:

Hi and thanks.

 

So looking at the in-process example, I’m guessing it compiles to a dynamic library which the server loads? If so, how does the server know the capabilities of the in-process client.

 

I’m coming from writing VST plug-ins on Windows or Audio Units on Apple platforms, in case I sound confused.

 

I’m also having trouble getting used to the idea of the client being the plug in, normally I would think the client would be what is called the “host” on Windows or Apple, and the plug-in would closer to a “server”. But here the terminology is reversed. Am I understanding correctly? The “client” in JACK is the plug-in (for in-process use), correct?

 

Finally, I’d like to get started seeing whether the eco-system works for low latency with existing apps and components for diving in. Is AVLinux the way to go, and is there any reason it will not work on BeagleBone?

 

I’m not a Linux expert in case you can’t already tell! It’s not that I have zero experience, but sometimes it’s close, depending on context.

 

But I do know audio, and operating system design, and threading, and SIMD, and etc.

 

  • Andy

 

From: Linux-audio-user <linux-audio-user-bounces@lists.linuxaudio.org> on behalf of Paul Davis <paul@xxxxxxxxxxxxxxxxxxxxx>
Date: Tuesday, January 9, 2018 at 4:41 PM
To: Benoît Rouits <brouits@xxxxxxx>
Cc: linux-audio-user <linux-audio-user@lists.linuxaudio.org>
Subject: Re: How to get started writing a JACK app?

 

please. not sourceforge.

JACK code lives on github ...  https://github.com/jackaudio/example-clients

 

On Tue, Jan 9, 2018 at 6:21 PM, Benoît Rouits <brouits@xxxxxxx> wrote:

Hello  Andy

as a starting point, you could look at:

http://jackit.sourceforge.net/cgi-bin/lxr/http/source/example-clients/

This is C client code samples for jack.

HTH,
 Benoît

Le 09/01/2018 à 16:19, Andrew Voelkel a écrit :
>
>     Hi,____
>
>     __ __
>
>     I’m new to this list. I’m thinking of giving low latency real time
>     audio in Linux another try after my last unsuccessful attempt a few
>     years ago. My goal is to put some of my own DSP code into a hardware
>     appliance and use it to process audio signals during music
>     rehearsals and performances.____
>
>     __ __
>
>     I think this boils down to getting an appropriate distro, getting
>     JACK working in a low latency configuration with a multichannel USB
>     interface. And then …____
>
>     __ __
>
>     Writing a JACK app to process the audio. ____
>
>     __ __
>
>     I’ve done some googling and found a lot about _/using/_ JACK, but
>     not much about writing a JACK app. ____
>
>     __ __
>
>     Are there any examples or tutorials out there?____
>
>     __ __
>
>     I’m already up to speed on doing C++ cross development with Eclipse.____
>
>     __ __
>
>     I’ve got a BeagleBone black sitting around here I could use to
>     experiment.____
>
>     __ __
>
>       * Andy____

>
>
>
>
> _______________________________________________
> Linux-audio-user mailing list
> Linux-audio-user@lists.linuxaudio.org
> https://lists.linuxaudio.org/listinfo/linux-audio-user
>
_______________________________________________
Linux-audio-user mailing list
Linux-audio-user@lists.linuxaudio.org
https://lists.linuxaudio.org/listinfo/linux-audio-user

 

_______________________________________________ Linux-audio-user mailing list Linux-audio-user@lists.linuxaudio.org https://lists.linuxaudio.org/listinfo/linux-audio-user

 


_______________________________________________
Linux-audio-user mailing list
Linux-audio-user@xxxxxxxxxxxxxxxxxxxx
https://lists.linuxaudio.org/listinfo/linux-audio-user

[Index of Archives]     [Linux Sound]     [ALSA Users]     [Pulse Audio]     [ALSA Devel]     [Sox Users]     [Linux Media]     [Kernel]     [Photo Sharing]     [Gimp]     [Yosemite News]     [Linux Media]

  Powered by Linux