Shairport Sync Version 5 is a major release and represents a significant advancement in Shairport Sync's capabilities, introducing multi-channel audio support, high-resolution playback, automatic transcoding and comprehensive performance improvements.
Important Breaking Changes Notice: Version 5.0 includes many breaking changes from previous versions of Shairport Sync. Please review the documentation carefully before upgrading. A useful guide to Version 5 Configuration File Changes in Version 5 is available here.
New Features
-
Multi-Channel and High-Resolution Audio Support
- 48,000 frames per second ("48k") operation.
- 48k lossless stereo support.
- 5.1 and 7.1 surround sound support.
- Multi-channel and multi-rate operation on
ALSA, PipeWire, PulseAudio, FreeBSD,stdoutand Unixpipeoutput backends.
-
Automatic Audio Format Selection
- Flexible and controllable output format selection.
- Automatic rate, sample format, and channel count selection.
-
Full FFmpeg Integration
- Support for transcoding.
- Advanced resampling capabilities.
- New audio format support.
-
Enhanced Resampling
- New
vernierresampling and interpolation method optimized for low-power CPUs. - Better performance on resource-constrained devices.
- New
-
Convolution and Loudness Enhancements
- Convolution system is now multithreaded and works on stereo and multichannel audio at 48k and 44.1k.
- Multiple impulse response (IR) files can now be provided via
convolution_ir_filessetting. - New
convolution_thread_pool_sizesetting for multithreaded processing (defaults to 1). - Loudness processing now works with stereo and multichannel audio at 48k and 44.1k.
- Updated to the most recent HiFi-LoFi FFT convolver.
-
MQTT Enhancements
- Added new
publish_retainboolean option. When enabled, published MQTT messages have theretainflag set, so the MQTT broker stores the last message per topic and new subscribers receive the most recent value immediately. Thanks to lululombard for PR #2142.
- Added new
-
D-Bus Enhancements
- Added new
dbus_default_message_buscommand-line argument (can besystemorsession) to set the default message bus for both D-Bus native service and MPRIS service.
- Added new
Performance Improvements
- Improved compatibility with AirPlay 2 AutoMix and smart playlists.
- Better operation on low-power devices down to Raspberry Pi B.
- Improved efficiency on embedded systems.
- Enhanced timestamp handling for better synchronization.
- Improved sync error calculation.
- Rebuilt buffered audio processor for cleaner handling of immediate and deferred flush requests.
Docker Enhancements
- Reduced Docker image sizes with slimmed-down
FFmpeglibrary. - Removed
dhclientfrom Docker images for smaller footprint.
Bug Fixes
- Fixed MQTT warning on service startup:
Could not establish a mqtt connection. The startup script now correctly states that themosquittoservice is required. Thanks to Hugo Villeneuve for PR #2137. - Fixed compatibility with
mbedtlslibrary version 3.4+ (present on recent Linux versions). Thanks to Christian Beier for finding and fixing the bug. - Fixed PulseAudio backend so that
PA_ERR_NODATAreturns "No latency data yet". Thanks to Vladimir Shakov for the report and fix. - Ensured old flush requests are deleted when a new play session starts. Thanks to saujanyashah for the report.
- Fixed format warnings on 64-bit and 32-bit systems
- Removed compilation warnings on 32-bit builds
- Improved argument checking for
debug(),inform(),warn()anddie()functions - Fixed "daemon" typos throughout codebase. Thanks to Chris Boot for PR #1981.
- Added warning if a convolution impulse response file cannot be read due to bad path or permissions
Build System Improvements
- Unified service file with variable substitution for Avahi support, making it easier to add future service dependencies. Thanks to Hugo Villeneuve.
- Network interface selection now only considers interfaces that are up, running and not loopback interfaces. Thanks to Carl Johnson for the suggestion.
Configuration File Changes and Deprecations
- New settings:
convolution_ir_files(replacesconvolution_ir_file),convolution_enabled(replacesconvolution),convolution_max_length_in_seconds(replacesconvolution_max_length),loudness_enabled(replacesloudness). - New
convolution_thread_pool_sizesetting (defaults to 1). - Deprecated settings:
convolution_ir_file,convolution,convolution_max_length,loudness. - Corresponding D-Bus methods and properties have been updated.
Deprecation Notice
- The Jack Audio and
soundiobackends are deprecated and will be removed in a future release. Consider using the updated PipeWire backend instead.
Documentation Updates
- Updated BUILD.md with latest build instructions.
- Updated AIRPLAY2.md with feature information.
- Enhanced convolution and loudness documentation.
Maintenance
- Fixed FFmpeg deprecation warnings.
- Bumped
actions/checkoutfrom 6.0.1 to 6.0.2. - Bumped
docker/login-actionfrom 3.6.0 to 3.7.0. - Bumped
docker/build-push-actionfrom 6.13.0 to 6.15.0. - Bumped
docker/setup-qemu-actionfrom 3.4.0 to 3.6.0. - Bumped
docker/setup-buildx-actionfrom 3.9.0 to 3.10.0.