PipeWire 0.3.81 (2023-10-06) This is the first 1.0 release candidate that is API and ABI compatible with previous 0.3.x releases.
Highlights
- jackdbus support is now enabled by default.
- IRQ based scheduling in ALSA was improved and enabled by default for Pro-Audio profile. It will also link the pcms together to get lower latency. This now matches what JACK does and results in equal latency for Pro-Audio profiles.
- Support both old and new versions of webrtc-audio-processing to make the transition easier.
- Forced quantum changes by nodes or metadata will now also force a suspend and resume of the graph, like the rate changes to make sure all nodes adapt to the new quantum. This is important for Pro-Audio nodes that need to reconfigure the hardware to a new period in IRQ based scheduling.
- Fix a regression in regex parsing.
- Many bugfixes and improvements.
PipeWire
- Jackdbus is by default enabled now. The idea is that when jackdbus is installed, the real libjack.so is in the path and we can become a real JACK client.
- Forces quantum changes by nodes or metadata will now also force a suspend and resume in the graph, like the rate changes to make sure all nodes adapt to the new quantum. This is important for Pro-Audio nodes that need to reconfigure the hardware to a new period.
- The stream now has an EARLY_PROCESS option that can be used to implement custom buffer fill levels. (#3480)
- Fix a regression in regex parsing. (#3528)
- Fix a bug in position reporting in the driver node. (#3189) (#3544)
- Destroying a link will now recalculate the graph correctly.
- Fix the rate comparison for finding the best rate in the graph.
- Use malloc_trim() when available to release memory. (#1840)
Tools
- pw-cat now supports DFF DSD files.
- pw-cli avoid some NULL derefs in some cases.
Modules
- The RAOP sink has seen some cleanups and improvements. It will now ask for feedback every 2 seconds to keep some devices alive.
- A bug in filter-chain was fixed where it would fail to apply the gain when mixing just one source.
- The filter-chain can now pass the stream volume to a control in the filter-chain graph. (#3434)
- Improve volume handling in RAOP sink.
Pulse-server
- Some cleanup in the pending_stream handling.
- Fix a regression in the event emission code where it failed to emit a changed event when a node was linked. (#3522)
- Lower the realtime priority of pulseaudio clients.
- Set pulse.module.id on the echo-cancel streams. (#3541)
SPA
- Support both old and new versions of webrtc-audio-processing to make the transition easier.
- The ALSA driver now does the sync of all followers directly from the wakeup event. This results in more stable rate matching.
- IRQ based scheduling in ALSA was improved and enabled by default for Pro-Audio profile. It will also link the pcms together to get lower latency. This now matches what JACK does and gives equal latency for Pro-Audio profiles.
- GNU/Hurd support was added.
- Some improvements to passthrough handling.
Bluetooth
- Improvements to the codec handling when PipeWire is used as Audio Gateway.
- Adapt to new Bluez API for BAP devices.
JACK
- When the jack library is set in the default library path, avoid using LD_LIBRARY_PATH because this can cause confusion.
- Handle clearing the latency on a port.
- jack_property now always manages to actually change the metadata because it waits for a roundtrip before exiting.
These guys do the real work rarely appreciated
True, what a blessing.
I’ve been using PipeWire for a couple years now and it’s honestly the most painless audio experience I’ve ever had on Linux. Looking forward to the 1.0 release!
Anyone know when it’ll become the default audio server in Ubuntu?
I’m not certain but I believe it has been the default in 22.10 and newer.
can confirm
Exciting. So I’ll see it in 24.04 LTS on my end.
I get the sense this is a tool used by developers, not end users. Is that right?
It’ll be used by a lot of Linux distributions.
It’s a drop-in replacement to the Pulseaudio and JACK audio systems, with the hopes of making audio handling decent within Linux with as low latency as they can.
Why is Pulse being replaced? I can’t think of anything it was missing
Pipewire fixed a lot of Bluetooth audio issues for me, and the ease with which I could enable things like SBC XQ was a lot more pleasant than the unoffiical Pulse integration that would do that same. It’s also interoperable with JACK (though it’s not as low-latency as Jack, but still beats Pulse of course) which is pretty cool, and it can do audio stream management that Pulse probably can but wasn’t built for.
It’s also the most common implementation of various Wayland screen recording features, though that doesn’t mean someone couldn’t reimplement the API with Pulse integration instead.
The most common way applications integrate with Pipewire seems to be through the Pulse compatibility layer, so if you don’t want to upgrade you can stick with Pulse for years to come. It’s not so much a full replacement (like how X.org is on maintenance only and Wayland intends to replace it for good) as it is a more modern alternative that has become the preference of many people (like how systemd has taken over the init space by being easier to work with, with alternatives still being developed and maintained to this day).
Pulseaudio has been replaced by PipeWire for quite some time in fedora. Since Fedora 34, released in April 2021, apparently.
According to the wiki page, PipeWire originally came about trying to improve video handling on Linux, the same way that pulseaudio improved audio handling.
They then wanted to try and handle audio streams, with the idea of converging use cases for both consumer and professional audio users. Namely, they wanted a single audio system that supported both pulseaudio and JACK, whilst remaining as low latency as possible.
On top of this, because it was a modern reimplementation of audio and video handling in Linux, they designed it to work with Flatpak, and to provide secure methods for screenshotting and screencasting in wayland via the compositors.
(All my info here I just took from the wiki)
It’s not so much anything missing, but more of a complete rewrite of the audio stack to create a more stable system with as low latency as possible. Both of which were needed.
It’s a replacement for pulseaudio.
it is the equivelant of the dude’s rug, it ties the room together. the end user doesn’t even recognize that change. it brings all programs that work with different sound servers (alsa, pulseaudio, jack) under the same umbrella.
It’s the audio framework behind most modern Linux systems nowadays. It performs much better than previous ones and provides greater consistency and expectations for end users. Basically… if you’ve ever been frustrated by audio configuration on Linux, this project is probably working on fixing it.
Been using it now since it hit Fedora Silverblue as an option. This is very “it works on my machine”, but I’ve rarely had any problems with it - like even in Jack2 bridge mode. Recently I’ve noticed nothing. It’s just there, working in the background, doing what it’s supposed to do.
To clarify, it was on my workstation laptop that I also use for leisure.
Because you don’t understand the changelog?
There are plenty of distros who will take care of you.