wiki:pipewire

Pipewire

Handy link (thanks archetech on #lfs-support): https://wiki.gentoo.org/wiki/PipeWire
It has some indications for SysV (OpenRC startup).

Replace Pulseaudio

With Wireplumber, Pipewire can function as a drop-in replacement of Pulseaudio:

  • On systemd:
    sudo systemctl --global enable pipewire-pulse.socket
    sudo systemctl --global disable pulseaudio
    

(For some reason enabling the .socket unit works fine for me, but enabling the .service unit causes the camera not found. Maybe a race condition.)

  • On Sysv: add to /usr/bin/pipewire-launcher.sh (after pipewire and before wireplumber):
    exec /usr/bin/pipewire -c pipewire-pulse.conf &
    sleep 1
    
    then move away the file /etc/xdg/autostart/puleaudio.desktop, and change autospawn to "no" in /etc/pulse/client.conf (uncomment it, of course).
  • On both systemd and sysv: disable the XDG autostart of traditional PulseAudio daemon
sudo sed '2i exit # nouse' -i /etc/xdg/Xwayland-session.d/00-pulseaudio-x11
sudo sed '$a Hidden=true'  -i /etc/xdg/autostart/pulseaudio.desktop

If PulseAudio is upgraded, do this again.

(Without this my system was running no-sound for 30 seconds after login.)

  • Then logout and login again.

Use Pipewire for ALSA-based applications

If Pipewire is running, it will occupy the sound card device and an ALSA-based application cannot use the card at the same time. To work around the issue, tell alsa-lib to use a virtual device provided by Pipewire:

sudo install -vdm755 /etc/alsa/conf.d
sudo ln -sfvr /usr/share/alsa/alsa.conf.d/99-pipewire-default.conf /etc/alsa/conf.d

Bluetooth LDAC support

Install ldacBT before building Pipewire. The link to ldacBT is available on the book page. Installation process of ldacBT:

mkdir build; cd build
cmake .. -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr
make
# no test suite available
sudo make install

Libcamera support

GNOME/Snapshot (a replacement for Cheese) needs a functional pipewire daemon (i. e. requiring wireplumber) built with libcamera.

We can use v4l-utils instead of libcamera. This section only remains here for reference.

libcamera dependencies are listed at https://libcamera.org/getting-started.html. Everything required or recommended is in BLFS, except a Python module named ply.

Install ply (https://files.pythonhosted.org/packages/source/p/ply/ply-3.11.tar.gz):

pip3 wheel -w dist --no-build-isolation --no-deps --no-cache-dir $PWD
sudo pip3 install --no-index --find-links=dist --no-cache-dir --no-user ply

There is no website for libcamera release tarballs. Clone the git repository and checkout the latest release tag:

git clone https://git.libcamera.org/libcamera/libcamera.git
git checkout v0.1.0

Now install it:

mkdir build
cd build
meson setup --prefix=/usr --buildtype=release --wrap-mode=nodownload -Dwerror=false
ninja
sudo ninja install

Then (re)build pipewire and libcamera should be automatically detected and enabled.

Last modified 8 months ago Last modified on 01/27/2024 07:59:14 PM
Note: See TracWiki for help on using the wiki.