[Pkg-utopia-maintainers] Bug#1054019: broken sample rate passthrough
Nicholas D Steeves
sten at debian.org
Sun Oct 15 22:25:25 BST 2023
Package: pipewire
Version: 0.3.65-3
Severity: normal
Hi,
Unfortunately using mpv's Pipewire driver results in audio being
resampled, which introduces resampling artifacts. While I discovered
this bug in bookworm's mpv_0.31.1-4, I've confirmed that it is still
present in 0.36.0-1. That said, as a result of the investigation when
filing this bug, I found what seems to be evidence that points to
Pipewire as the true cause of the bug. Any software that uses Pipewire directly, or pipewire-jack appears to be affected.
Steps to reproduce:
1. Uninstall and disable pulseaudio (if it's installed).
2. Install pipewire-pulse.
3. Cp /usr/share/pipewire/pipewire.conf /etc/pipewire/pipewire.conf
4. Set "default.clock.allowed-rates = [ 44100 48000 88200 96000 ]"
5. Restart pipewire's --user session.
6. mpv --ao=pipewire 01.ripped.from-CD.flac
7. cat /proc/asound/card0/pcm0p/sub0/hw_params | grep rate
rate: 48000 (48000/1)
When playing music with mpd (with Pulse audio backed) or with "mpv
--ao=pulse", the sample rate is correctly passed through to Pipewire, and thus to the hardware:
rate: 44100 (44100/1)
Yes, I tested to see if the creation of a pipewire.conf with
"default.clock.allowed-rates", and it appears to be for bookworm's
Pipewire 0.3.65-3.
The people who would probably be bothered the most by this bug are
those who purchased "High-resolution audio" files (sample rates up to
192kHz, and usually 24bit), because playback will be limited to 48kHz
due to this bug, as well as people who can hear 44.1khz to 48khz
resampling artifacts.
With the hypothesis that it was a Pipewire bug, I tried running
Audacious with pipewire-jack (with JACK output configured), and a popup dialogue showed "Error"
The JACK server requires a sample rate of 48000 Hz, but
Audacious is playing at 44100 Hz. Please use the Sample rate
Converter effect to correct the mismatch.
And testing with "pw-jack mpv --ao=jack 01.ripped.from-CD.flac" shows
AO: [jack] 48000Hz stereo 2ch floatp
and of course cat /proc/asound/card0/pcm0p/sub0/hw_params | grep rate shows
rate: 48000 (48000/1)
So yeah, it looks like Pipewire's default sample rate is always
applied when using pipewire or JACK sinks, despite
"default.clock.allowed-rates" being set, except with using pulseaudio.
I'm not sure why this is the case, but it seems wrong that everything
is buggy except Pipewire and Pulseaudio...and that's why I'm reporting
this bug against pipewire. Please feel free to reassign if this is a
naive assessment.
I hope this is enough to identify which package[s] is[are] affected as
well as to forward the bug upstream. Please let me know if any more
info is required.
Thanks,
Nicholas
-- System Information:
Debian Release: 12.2
APT prefers stable-security
APT policy: (500, 'stable-security'), (500, 'stable-debug'), (500, 'proposed-updates-debug'), (500, 'stable')
Architecture: amd64 (x86_64)
Foreign Architectures: i386
Kernel: Linux 6.1.0-13-rt-amd64 (SMP w/4 CPU threads; PREEMPT)
Locale: LANG=en_CA.UTF-8, LC_CTYPE=en_CA.UTF-8 (charmap=UTF-8), LANGUAGE=en_CA:en
Shell: /bin/sh linked to /usr/bin/dash
Init: systemd (via /run/systemd/system)
LSM: AppArmor: enabled
Versions of packages mpv depends on:
ii libarchive13 3.6.2-1
ii libasound2 1.2.8-1+b1
ii libass9 1:0.17.1-1
ii libavcodec-extra59 [libavcodec59] 7:5.1.3-1
ii libavdevice59 7:5.1.3-1
ii libavfilter8 7:5.1.3-1
ii libavformat59 7:5.1.3-1
ii libavutil57 7:5.1.3-1
ii libbluray2 1:1.3.4-1
ii libc6 2.36-9+deb12u3
ii libcaca0 0.99.beta20-3
ii libcdio-cdda2 10.2+2.0.1-1
ii libcdio-paranoia2 10.2+2.0.1-1
ii libcdio19 2.1.0-4
ii libdrm2 2.4.114-1+b1
ii libdvdnav4 6.1.1-1
ii libegl1 1.6.0-1
ii libgbm1 22.3.6-1+deb12u1
ii libjack-jackd2-0 [libjack-0.125] 1.9.21~dfsg-3
ii libjpeg62-turbo 1:2.1.5-2
ii liblcms2-2 2.14-2
ii liblua5.2-0 5.2.4-3
ii libmujs2 1.3.2-1
ii libpipewire-0.3-0 0.3.65-3
ii libplacebo208 4.208.0-3
ii libpulse0 16.1+dfsg1-2+b1
ii librubberband2 3.1.2+dfsg0-1
ii libsdl2-2.0-0 2.26.5+dfsg-1
ii libsixel1 1.10.3-3
ii libswresample4 7:5.1.3-1
ii libswscale6 7:5.1.3-1
ii libuchardet0 0.0.7-1
ii libva-drm2 2.17.0-1
ii libva-wayland2 2.17.0-1
ii libva-x11-2 2.17.0-1
ii libva2 2.17.0-1
ii libvdpau1 1.5-2
ii libvulkan1 1.3.239.0-1
ii libwayland-client0 1.21.0-1
ii libwayland-cursor0 1.21.0-1
ii libwayland-egl1 1.21.0-1
ii libx11-6 2:1.8.4-2+deb12u2
ii libxext6 2:1.3.4-1+b1
ii libxinerama1 2:1.1.4-3
ii libxkbcommon0 1.5.0-1
ii libxpresent1 1.0.0-2+b10
ii libxrandr2 2:1.5.2-2+b1
ii libxss1 1:1.2.3-1
ii libxv1 2:1.0.11-1.1
ii libzimg2 3.0.4+ds1-1
ii zlib1g 1:1.2.13.dfsg-1
Versions of packages mpv recommends:
ii xdg-utils 1.1.3-4.1
ii yt-dlp 2023.09.24-2~bpo12+1
Versions of packages mpv suggests:
pn libcuda1 <none>
-- no debconf information
More information about the Pkg-utopia-maintainers
mailing list