Multimedia processing graphs
Find a file
Gleb Popov fd937fa378 On FreeBSD, add dependency on epoll-shim library.
FreeBSD doesn't provide timerfd and eventfd functions. These are implemented in
3rd party library called epoll-shim. Link targets requiring these functions to
this library.
2019-11-19 13:41:40 +01:00
doc doc: add session-manager <-> pulseaudio mapping 2019-11-08 15:53:14 +01:00
man
pipewire-alsa system: use spa_system functions for fds 2019-11-19 13:41:40 +01:00
pipewire-jack
pipewire-pulseaudio
po
spa On FreeBSD, add dependency on epoll-shim library. 2019-11-19 13:41:40 +01:00
src On FreeBSD, add dependency on epoll-shim library. 2019-11-19 13:41:40 +01:00
.editorconfig
.gitignore
.gitlab-ci.yml
_config.yml
autogen.sh
check_missing_headers.sh
CODE_OF_CONDUCT.md
config.h.meson
COPYING
Dockerfile
LICENSE
Makefile.in
meson.build On FreeBSD, add dependency on epoll-shim library. 2019-11-19 13:41:40 +01:00
meson_options.txt meson: remove spa option 2019-11-12 08:14:13 +00:00
NEWS
PROTOCOL
pw-uninstalled.sh
README.md

PipeWire

PipeWire is a server and user space API to deal with multimedia pipelines. This includes:

  • Making available sources of video (such as from a capture devices or application provided streams) and multiplexing this with clients.
  • Accessing sources of video for consumption.
  • Generating graphs for audio and video processing.

Nodes in the graph can be implemented as separate processes, communicating with sockets and exchanging multimedia content using fd passing.

Building

Pipewire uses the Meson and Ninja build system to compile. You can run it with:

$ meson build
$ cd build
$ ninja

You can see the available meson options in meson_options.txt file.

If you're not familiar with these tools, the included autogen.sh script will automatically run the correct meson/ninja commands, and output a Makefile. It follows that there are two methods to build Pipewire, however both rely on Meson and Ninja to actually perform the compilation:

$ ./autogen.sh
$ make

Running

If you want to run PipeWire without installing it on your system, there is a script that you can run. This puts you in an environment in which PipeWire can be run from the build directory, and ALSA, PulseAudio and JACK applications will use the PipeWire emulation libraries automatically in this environment. You can get into this environment with:

$ ./pw-uninstalled.sh