jack2 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
falkTX ffde5f7863 CI: use full list of bad packages, for posterity 2 years ago
.github CI: use full list of bad packages, for posterity 2 years ago
android Fix misc. typos 3 years ago
autooptions FIx doxygen and user facing and non-facing typos 5 years ago
common It compiles 2 years ago
compat Make sure we use python3 (another patch from Fedora) 4 years ago
dbus Move jack_control to dbus (#831) 2 years ago
example-clients Add FreeBSD support 2 years ago
freebsd FreeBSD: Big driver overhaul for FreeBSD OSS. 2 years ago
linux ALSA: convert properly S24_LE 2 years ago
macosx macOS: Pass JackMachSemaphore send right via mach_msg IPC (#788) 2 years ago
man Allow optional build of jack-example-tools 2 years ago
posix POSIX: Remove unnecessary feature test macro. 2 years ago
solaris FIx doxygen and user facing and non-facing typos 5 years ago
systemd Make sure we use python3 (another patch from Fedora) 4 years ago
tests Add FreeBSD support 2 years ago
tools Move jack_control to dbus (#831) 2 years ago
waflib Fix misc. typos 3 years ago
windows CI: Generate windows installers 2 years ago
.gitignore CI: Generate windows installers 2 years ago
.wafupdaterc Update to waf 2.0.11 6 years ago
AUTHORS.rst macOS: Pass JackMachSemaphore send right via mach_msg IPC (#788) 2 years ago
COPYING Add a local GPLv2 license file as COPYING 4 years ago
ChangeLog.rst Add changelog entry for optional example tools 2 years ago
README.rst README: Add repology repository badge 3 years ago
README_NETJACK2 FIx doxygen and user facing and non-facing typos 5 years ago
doxyfile.in Fix compilation of documentation 3 years ago
jack.pc.in Add custom variable to jack pkgconfig to distinguish implementations 2 years ago
waf Make sure we use python3 (another patch from Fedora) 4 years ago
wscript Fix build of jack-example-tools with waf autooptions 2 years ago

README.rst

`JACK2 <https://jackaudio.org/>`_
################################

.. image:: https://travis-ci.org/jackaudio/jack2.svg?branch=master
:target: https://travis-ci.org/jackaudio/jack2
.. image:: https://repology.org/badge/tiny-repos/jack-audio-connection-kit.svg
:target: https://repology.org/metapackage/jack-audio-connection-kit/versions

JACK2 aka jackdmp is a C++ version of the JACK low-latency audio server for
multi-processor machines. It is a new implementation of the JACK server core
features that aims at removing some limitations of the JACK1 design. The
activation system has been changed for a data flow model and lock-free
programming techniques for graph access have been used to have a more dynamic
and robust system.

- uses a new client activation model, that allows simultaneous client
execution (on a SMP machine) when parallel clients exist in the graph (client
that have the same inputs). This activation model allows to better use
available CPU on a smp machine, but also works on mono-processor machine.

- uses a lock-free way to access (read/write) the client graph, thus
allowing connections/disconnection to be done without interrupting the audio
stream. The result is that connections/disconnections are glitch-free.

- can work in two different modes at the server level:

- *synchronous activation*: in a given cycle, the server waits for all
clients to be finished (similar to normal jackd)

- *asynchronous activation*: in a given cycle, the server does not wait for
all clients to be finished and use output buffer computed the previous
cycle.
The audible result of this mode is that if a client is not activated
during one cycle, other clients may still run and the resulting audio
stream will still be produced (even if its partial in some way). This
mode usually result in fewer (less audible) audio glitches in a loaded
system.

For further information, see the JACK `homepage <https://jackaudio.org/>`_ and `wiki <https://github.com/jackaudio/jackaudio.github.com/wiki>`_. There are also the #jack and #lad chat channels on `freenode IRC <https://freenode.net>`_.