Stable release
This stable release is the culmination of the 2.3.X sequence of development releases.
Change Summary
Changes from the previous stable version -- 2.2.5 -- are summarised here:
- Settings are now read from a configuration file. Command-line settings are supported but discouraged.
- Metadata is now supported -- it can be delivered to a unix pipe for processing by a helper application. See https://github.com/mikebrady/shairport-sync-metadata-reader for a sample metadata reader.
- Raw PCM audio can be delivered to standard output ("stdout") or to a unix pipe. The internal architecture has changed considerably to support this.
- Support for compilation on OpenWrt back to Attitude Adjustment.
- Can play unencrypted audio streams -- complatible with, e.g. Whaale.
- Uses the libconfig library.
- Runs on a wider range of platforms, including Arch Linux and Fedora.
- Bug fixes.
Please note that building instructions have changed slightly from the previous version.
Also, the -t hardware/software
option has been deprecated in the alsa back end.
Note
- We're getting ready to release the development branch as the new, stable, master branch at 2.4. If you're packaging Shairport Sync, you might prefer to wait a short while as we add a little polish before the release.
Changes
- Harmonise version numbers on the release and on the
shairport.spec
file used in Fedora.
Note
- We're getting ready to release the development branch as the new, stable, master branch at 2.4. If you're packaging Shairport Sync, you might prefer to wait a short while as we add a little polish before the release.
Changes
update-rc.d
has been removed from the installation script for System V because it causes problems for package makers. It's now noted in the user installation instructions.- The
alsa
groupmixer_type
setting is deprecated and you should stop using it. Its functionality has been subsumed intomixer_name
– when you specify amixer_name
it automatically chooses thehardware
mixer type.
Enhancements
- Larger range of interpolation. Shairport Sync has previously constrained not to make interpolations ("corrections") of more than about 1 per 1000 real frames. This contraint has been relaxed, and it is now able to make corrections of up to 1 in 352 real frames. This might result in a faster and undesirably sudden correction early during a play session, so a number of further changes have been made. The full set of these changes is as follows:
- No corrections happen for the first five seconds.
- Corrections of up to about 1 in 1000 for the next 25 seconds.
- Corrections of up to 1 in 352 thereafter.
Documentation Update
- Nearly there with updates concerning the configuration file.
Documentation Update
- Beginning to update the
man
document to include information about the configuration file. It's pretty sparse, but it's a start.
Bug fix
- The "pipe" backend used output code that would block if the pipe didn't have a reader. This has been replaced by non-blocking code. Here are some implications:
- When the pipe is created, Shairport Sync will not block if a reader isn't present.
- If the pipe doesn't have a reader when Shairport Sync wants to output to it, the output will be discarded.
- If a reader disappears while writing is occuring, the write will time out after five seconds.
- Shairport Sync will only close the pipe on termination.
- Bug fix
- Specifying the configuration file using a relative file path now works properly.
- The debug verbosity requested with
-v
,-vv
, etc. is now honoured before the configuration file is read. It is read and honoured from when the command line arguments are scanned the first time to get a possible configuration file path.
-
Annoying changes you must make
-
You probably need to change your
./configure
arguments. The flagwith-initscript
has changed towith-systemv
. It was previously enabled by default; now you must enable it explicitly. -
Changes
-
Added limited support for installing into
systemd
and Fedora systems. Forsystemd
support, use the configuration flag--with-systemd
in place of--with-systemv
. The installation does not do everything needed, such as defining special users and groups. -
Renamed
with-initscript
configuration flag towith-systemv
to describe its role more accurately. -
A System V startup script is no longer installed by default; if you want it, ask for it with the
--with-systemv
configuration flag. -
Added limited support for FreeBSD. You must specify
LDFLAGS='-I/usr/local/lib'
andCPPFLAGS='-L/usr/local/include'
before running./configure --with-foo etc.
-
Removed the
-configfile
annotation from the version string because it's no longer optional; it's always there. -
Removed the
dummy
,pipe
andstdout
backends from the standard build – they are now optional and are no longer automatically included in the build. -
Bug fixes
-
Allow more stack space to prevent a segfault in certain configurations (thanks to https://github.com/joerg-krause).
-
Add missing header files(thanks to https://github.com/joerg-krause).
-
Removed some (hopefully) mostly silent bugs from the configure.ac file.
- Changes
- Removed the two different buffer lengths for the alsa back end that made a brief appearance in 2.3.5.
- Enhancements
- Command line arguments are now given precedence over config file settings. This conforms to standard unix practice.
- A
–without-pkg-config
configuration argument now allows for build systems, e.g. for older OpenWrt builds, that haven't fully implemented it. There is still some unhappiness in arch linux builds. - More
- Quite a bit of extra diagnostic code was written to investigate clock drift, DAC timings and so on. It was useful but has been commented out. If might be useful in the future.
- Changes
- The metadata item 'sndr' is no longer sent in metadata. It's been replaced by 'snam' and 'snua' -- see below.
- Enhancements
- When a play session is initiated by a source, it attempts to reserve the player by sending an "ANNOUNCE" packet. Typically, a source device name and/or a source "user agent" is sent as part of the packet. The "user agent" is usually the name of the sending application along with some more information. If metadata is enabled, the source name, if provided, is emitted as a metadata item with the type
ssnc
and codesnam
and similarly the user agent, if provided, is sent with the typessnc
and codesnua
. - Two default buffer lengths for ALSA -- default 6615 frames if a software volume control is used, to minimise the response time to pause and volume control changes; default 22050 frames if a hardware volume control is used, to give more resilience to timing problems, sudden processor loading, etc. This is especially useful if you are processing metadata and artwork on the same machine.
- Extra metadata: when a play session starts, the "Active-Remote" and "DACP-ID" fields -- information that can be used to identify the source -- are provided as metadata, with the type
ssnc
and the codesacre
anddaid
respectively. The IDs are provided as strings. - Unencrypted audio data. The iOS player "Whaale" attempts to send unencrypted audio, presumably to save processing effort; if unsuccessful, it will send encrypted audio as normal. Shairport Sync now recognises and handles unencrypted audio data. (Apparently it always advertised that it could process unencrypted audio!)
- Handle retransmitted audio in the control channel. When a packet of audio is missed, Shairport Sync will ask for it to be retransmitted. Normally the retransmitted audio comes back the audio channel, but "Whaale" sends it back in the control channel. (I think this is a bug in "Whaale".) Shairport Sync will now correctly handle retransmitted audio packets coming back in the control channel.
- Bugfixes
- Generate properly-formed
<item>..</item>
items of information.
- Enhancement
- When a play session starts, Shairport Sync opens three UDP ports to communicate with the source. Until now, those ports could be any high numbered port. Now, they are located within a range of 100 port locations starting at port 6001. The starting port and the port range are settable by two new general settings in
/etc/shairport-sync.conf
--udp_port_base
(default 6001) andudp_port_range
(default 100). To retain the previous behaviour, set theudp_port_base
to0
. - Bugfixes
- Fix an out-of-stack-space error that can occur in certain cases (thanks to https://github.com/joerg-krause).
- Fix a couple of compiler warnings (thanks to https://github.com/joerg-krause).
- Tidy up a couple of debug messages that were emitting misleading information.
- Bugfix -- fixed an error in the sample configuration file.
- Enhancement
- Metadata format has changed slightly -- the format of each item is now
<item><type>..</type><code>..</code><length>..</length><data..>..</data></item>
, where the<data..>..</data>
part is present if the length is non-zero. The change is that everything is now enclosed in an<item>..</item>
pair.
These releases were faulty and have been deleted.
Some big changes "under the hood" have been made, leading to limited support for unsynchronised output to stdout
or to a named pipe and continuation of defacto support for unsynchronised PulseAudio. Also, support for a configuration file in preference to command line options, an option to ignore volume control and other improvements are provided.
In this release, Shairport Sync gains the ability to read settings from /etc/shairport-sync.conf
.
This gives more flexibility in adding features gives better compatability across different versions of Linux.
Existing command-line options continue to work, but some will be deprecated and may disappear in a future version of Shairport Sync. New settings will only be available via the configuration file.
Note that, for the present, settings in the configuration will have priority over command line options for Shairport Sync itself, in contravention of the normal unix convention. Audio back end command line options, i.e. those after the --
, have priority over configuration file settings for the audio backends.
In moving to the the use of a configuration file, some "housekeeping" is being done -- some logical corrections and other small changes are being made to option names and modes of operations, so the settings in the configuration file do not exactly match command line options.
When make install
is executed, a sample configuration is installed or updated at /etc/shairport-sync.conf.sample
. The same file is also installed as /etc/shairport-sync.conf
if that file doesn't already exist. To prevent the configuration files being installed, use the configuration option --without-configfiles
.
- Pesky Change You Must Do Something About
If you are using metadata, please note that the option has changed somewhat. The option -M
has a new long name equivalent: --metadata-pipename
and the argument you provide must now be the full name of the metadata pipe, e.g. -M /tmp/shairport-sync-metadata
.
- Enhancements
- Shairport Sync now reads settings from the configuration file
/etc/shairport-sync.conf
. This has settings for most command-line options and it's where any new settings will go. A default configuration file will be installed if one doesn't exist, and a sample file configuration file is always installed or updated. Details of settings are provided in the sample file. Shairport Sync relies on thelibconfig
library to read configuration files. For the present, you can disable the new feature (and save the space taken up bylibconfig
) by using the configure option--without-configfile-support
. - New command-line option
-c <file>
or--configfile=<file>
allows you to specify a configuration file other than/etc/shairport-sync.conf
. - Session Timeout and Allow Session Interruption can now be set independently. This is really some "housekeeping" as referred to above -- it's a kind of a bug fix, where the bug in question is an inappropriate connection of the setting of two parameters. To explain: (1) By default, when a source such as iTunes starts playing to the Shairport Sync device, any other source attempting to start a play session receives a "busy" signal. If a source disappears without warning, Shairport Sync will wait for 120 seconds before dropping the session and allowing another source to start a play session. (2) The command-line option
-t
or--timeout
allows you to set the wait time before dropping the session. If you set this parameter to0
, Shairport Sync will not send a "busy" signal, thus allowing another source to interrupt an existing one. (3) The problem is that if you set the parameter to0
, a session will never be dropped if the source disappears without warning. The (obvious) fix for this is to separate the setting of the two parameters, and this is now done in the configuration file/etc/shairport-sync.conf
-- please see the settingsallow_session_interruption
andsession_timeout
. The behaviour of the-t
and--timeout
command-line options is unchanged but deprecated. - New Option -- "Ignore Volume Control" ('ignore_volume_control'). If you set this to "yes", the output from Shairport Sync is always set at 100%. This is useful when you want to set the volume locally. Available via the settings file only.
- Statistics option correctly reports when no frames are received in a sampling interval and when output is not being synchronised.
- A new, supported audio back end called
stdout
provides raw 16-bit 44.1kHz stereo PCM output. To activate, setoutput_backend = "stdout"
in the general section of the configuration file. Output is provided synchronously with the source feed. No stuffing or stripping is done. If you are feeding it to an output device that runs slower or faster, you'll eventually get buffer overflow or underflow in that device. To include support for this back end, use the configuration option--with-stdout
. - Support for the
pipe
back end has been enhanced to provide raw 16-bit 44.1kHz stereo PCM output to a named pipe. To activate, setoutput_backend = "pipe"
in the general section of the configuration and give the fully-specified pathname to the pipe in the pipe section of the configuration file -- seeetc/shairport-sync.conf.sample
for an example. No stuffing or stripping is done. If you are feeding it to an output device that runs slower or faster, you'll eventually get buffer overflow or underflow in that device. To include support for this back end, use the configuration option--with-pipe
. - Support for the
dummy
audio backend device continues. To activate, setoutput_backend = "dummy"
in in the general section of the configuration. To include support for this back end, use the configuration option--with-dummy
. - Limited support for the PulseAudio audio backend continues. To activate, set
output_backend = "pulse"
in in the general section of the configuration. You must still enter its settings via the command line, after the--
as before. Note that no stuffing or stripping is done: if the PulseAudio sink runs slower or faster, you'll eventually get buffer overflow or underflow. - New backend-specific settings are provided for setting the size of the backend's buffer and for adding or removing a fixed offset to the overall latency. The
audio_backend_buffer_desired_length
default is 6615 frames, or 0.15 seconds. On some slower machines, particularly with metadata processing going on, the DAC buffer can underflow on this setting, so it might be worth making the buffer larger. A problem on software mixers only is that changes to volume control settings have to propagate through the buffer to be heard, so the larger the buffer, the longer the response time. If you're using an alsa back end and are using a hardware mixers, this isn't a problem. Theaudio_backend_latency_offset
allows you emit frames to the audio back end some time before or after the synchronised time. This would be useful, for example, if you are outputting to a device that takes 20 ms to process audio; yoou would specify aaudio_backend_latency_offset = -882
, where 882 is the number of frames in 20 ms, to compensate for the device delay.
-
Enhancements
-
Adding the System V startup script (the "initscript") is now a configuration option. The default is to include it, so if you want to omit the installation of the initscript, add the configuration option
--without-initscript
. -
Metadata support is now a compile-time option:
--with-metadata
. -
A metadata feed has been added. Use the option
-M <pipe-directory>
, e.g.-M /tmp
. Shairport Sync will provide metadata in a pipe called<pipe-directory>/shairport-sync-metadata
. (This is changed in 2.3.1.) There's a sample metadata reader at https://github.com/mikebrady/shairport-sync-metadata-reader. The format of the metadata is a mixture of XML-style tags, 4-character codes and base64 data. Please look atrtsp.c
andplayer.c
for examples. Please note that the format of the metadata may change. Beware: there appears to be a serious bug in iTunes before 12.1.2, such that it may stall for a long period when sending large (more than a few hundred kilobytes) coverart images. -
Bugfix
-
Fix a bug when compiling for Arch Linux on Raspberry Pi 2 (thanks to https://github.com/joaodriessen).
-
Fix a bug whereby if the ANNOUNCE and/or SETUP method fails, the play_lock mutex is never unlocked, thus blocking other clients from connecting. This can affect all types of users, but particularly Pulseaudio users. (Thanks to https://github.com/jclehner.)
-
Modify the init script to start after all services are ready. Add in a commented-out sleep command if users find it necessary (thanks to https://github.com/BNoiZe).
-
Two memory leaks fixed (thanks to https://github.com/pdgendt).
-
An error handling time specifications for flushes was causing an audible glitch when pausing and resuming some tracks. This has been fixed (thanks to https://github.com/Hamster128).
- Bugfixes
- Fix a segfault error that can occur in certain cases (thanks again to https://github.com/joerg-krause).
- Include header files in common.c (thanks again to https://github.com/joerg-krause).
- Bugfixes
- Fix an out-of-stack-space error that can occur in certain cases (thanks to https://github.com/joerg-krause).
- Fix a couple of compiler warnings (thanks to https://github.com/joerg-krause).
- NOTE: all the metadata stuff has been moved to the "development" branch. This will become the stable branch henceforward, with just bug fixes or minor enhancements. Apologies for the inconvenience.
- Bugfixes
- Fix a bug when compiling for Arch Linux on Raspberry Pi 2 (thanks to https://github.com/joaodriessen).
- Fix a compiler warning (thanks to https://github.com/sdigit).
- Enhancement
- An extra latency setting for forked-daapd sources -- 99,400 frames, settable via a new option
--forkedDaapdLatency
.
- Bugfixes:
- If certain kinds of malformed RTSP packets were received, Shairport Sync would stop streaming. Now, it generally ignores faulty RTSP packets.
- The
with-pulseaudio
compile option wasn't including a required library. This is fixed. Note that the PulseAudio back end doesn't work properly and is just included in the application because it was there in the original shairport. Play with it for experimentation only. - Fix typo in init.d script: "Headphones" -> "Headphone".
- Extra documentation
- A brief note on how to compile
libsoxr
from source is included for the Raspberry Pi.
- Enhancements:
- New password option:
--password=SECRET
- New tolerance option:
--tolerance=FRAMES
. Use this option to specify the largest synchronisation error to allow before making corrections. The default is 88 frames, i.e. 2 milliseconds. The default tolerance is fine for streaming over wired ethernet; however, if some of the stream's path is via WiFi, or if the source is a third-party product, it may lead to much overcorrection -- i.e. the difference between "corrections" and "net correction" in the--statistics
option. Increasing the tolerence may reduce the amount of overcorrection.
- Changes to latency calculations:
- The default latency is now 88,200 frames, exactly 2 seconds. It was 99,400 frames. As before, the
-L
option allows you to set the default latency. - The
-L
option is no longer deprecated. - The
-L
option no longer overrides the-A
or-i
options. - The default latency for iTunes is now 99,400 frames for iTunes 10 or later and 88,200 for earlier versions.
- The
-i
or--iTunesLatency
option only applies to iTunes 10 or later sources.
- Documentation update: add information about the
-m
audio backend option. The-m
audio backend option allows you to specify the hardware mixer you are using. Not previously documented. Functionality of shairport-sync is unchanged.
- Compilation change: Begin to use PKG_CHECK_MODULES (in configure.ac) to statically link some of the libraries used by shairport-sync. It is intended to make it easier to build in the buildroot system. While sufficient for that purpose, note that PKG_CHECK_MODULES is not used for checking all the libraries yet. Functionality of shairport-sync is unchanged.
- Enhancement:
--statistics
Statistics are periodically written to the console (or the logfile) if this command-line option is included. They are no longer produced in verbose (-v
) mode. - Bugfixes for
tinysvcmdns
- A bug that prevented the device's IP number(s) and port numbers being advertised when using
tinysvcmdns
has been fixed. (Cause: name needed to have a.local
suffix.) - Bugs causing the shairport service to semi-randomly disappear and reappear seem to be fixed. (Possible cause: incorrect timing settings when using
tinysvcmdns
.)
- A bug that prevented the device's IP number(s) and port numbers being advertised when using
- Enhancement
- A man page is now installed -- do
man shairport-sync
or see it here: http://htmlpreview.github.io/?https://github.com/mikebrady/shairport-sync/blob/2.1/man/shairport-sync.html.
- A man page is now installed -- do
- Bugfix
- A bug that caused the
-t
timeout value to be incorrectly assigned has been fixed. (Cause:config.timeout
defined asint64_t
instead onint
.)
- A bug that caused the
- Bugfixes
- A bug that sometimes caused the initial volume setting to be ignored has been fixed. (Cause: setting volume before opening device.)
- a bug that caused shairport-sync to become unresponsive or unavailable has been fixed. (Cause: draining rather than flushing the alsa device before stopping.)
-
Enhancements
- (This feature is intended to be useful to integrators.) Shairport Sync now the ability to immediately disconnect and reconnect to the sound output device while continuing to stream audio data from its client.
Send a
SIGUSR2
to the shairport-sync process to disconnect or send it aSIGHUP
to reconnect. If shairport-sync has been started as a daemon usingshairport-sync -d
, then executingshairport-sync -D
or--disconnectFromOutput
will request the daemon to disconnect, and executingshairport-sync -R
or--reconnectToOutput
will request it to reconnect. With this feature, you can allow Shairport Sync always to advertise and provide the streaming service, but still be able to disconnect it locally to enable other audio services to access the output device.
- (This feature is intended to be useful to integrators.) Shairport Sync now the ability to immediately disconnect and reconnect to the sound output device while continuing to stream audio data from its client.
Send a
-
Annoying things you should know about if you're updating from a previous version:
- Options
--with-openssl
,--with-polarssl
have been replaced with a new option--with-ssl=<option>
where<option>
is eitheropenssl
orpolarssl
. - Option
--with-localstatedir
has been replaced with--with-piddir
. This compilation option allows you to specify the directory in which the PID file will be written. The directory must exist and be writable. Supercedes the--with-localstatedir
and describes the intended functionality a little more accurately.
- Options
-
Bugfixes
- A small (?) bug in the flush logic has been corrected. Not causing any known problem.
- Enhancements
- Adds a
--with-localstatedir
configuration option. When Shairport Sync is running as a daemon, it writes its Process ID (PID) to a file. The file must be stored in part of the file system that is writable. Most build systems choose an appropriate 'local state directory' for this automatically, but some -- notablybuildroot
-- don't always get it right for an embedded system. This compilation option allows you to specify the local state directory. Supersedes 2.1.4, which tried to do the same thing.
- Adds a
- Faulty -- withdrawn. 2.1.5 does it properly.
- Stability Improvements
- Fixed a bug which prevented Shairport Sync starting on an IPv4-only system.
- Stability Improvements
- Improved buffering and flushing control, especially important on poor networks.
-
Enhancements
- Add new -t or --timeout option. Normally, when playing audio from a source, the Shairport Sync device is unavailable to other devices requesting to play through it -- it returns a "busy" signal to those devices. If the audio source disappears without warning, the play session automatically terminates after a timeout period (default 120 seconds) and the device goes from being "busy" to being available for new play requests again. This option allows you to set that timeout period in seconds. In addition, setting the timeout period to 0 means that play requests -- say from other devices on the network -- can interrupt and terminate the current session at any time. In other words, the "busy" feature of the device -- refusing connections from other players while playing from an existing source -- is turned off.
- Allow -B and -E commands to have arguments, e.g. -B '/usr/bin/logger "Starting to play"' is now legitimate.
-
Annoying things you should know about if you're updating from 2.1:
- Build now depends on the library libpopt -- see "Building and Installing" below.
-
Stability Improvements
- Fixed a bug which would silence output after a few hours.
- Tightened up management of packet buffers.
- Improved estimate of lead-in silence to achieve initial synchronisation.
-
New features:
- Support for libsoxr, the SoX Resampler library -- see http://sourceforge.net/projects/soxr/. Briefly, Shairport Sync keeps in step with the audio source by deleting or inserting frames of audio into the stream as needed. This "interpolation" is normally inaudible, but it can be heard in some circumstances. Libsoxr allows this interpolation to be done much more smoothly and subtly. You can optionally include libsoxr support when building Shairport Sync. The big problem with libsoxr is that it is very compute intensive -- specifically floating point compute intensive -- and many embedded devices aren't powerful enough. Another issue is libsoxr is not yet in all linux distributions, so you might have to build it yourself. Available via the -S option.
- Support for running (and optionally waiting for the completion of) programs before and after playing. See the -B, -E and -w options.
- A new option to vary or turn off the resync threshold. See the -r option.
- Version and build options. See the -V option.
- Renamed program and init script. This is not exactly a big deal, but the name of the application itself and the default init script file have been renamed from "shairport" to "shairport-sync" to avoid confusion with other versions of shairport.
- PolarSSL can be used in place of OpenSSL and friends.
-
Other stuff
- Tinysvcmdns works as an alternative to, say, Avahi, but is now [really] dropped if you don't select it. Saves about 100k.
- Lots of bug fixes.
-
Annoying things you should know about if you're updating from 2.0:
- Compile options have changed -- see the Building and Installing section below.
- The name of the program itself has changed from shairport to shairport-sync. You should remove the old version -- you can use
$which shairport
to locate it. - The name of the init script file has changed from shairport to shairport-sync. You should remove the old one.
- New features:
- Audio synchronisation that works. The audio played by a Shairport Sync-powered device will stay in sync with the source. This allows you to synchronise Shairport Sync devices reliably with other devices playing the same source. For example, synchronised multi-room audio is possible without difficulty.
- True mute and instant response to mute and volume control changes -- this requires hardware mixer support, available on most audio devices. Without hardware mixer support, response is also faster than before -- around 0.15 seconds.
- Smoother volume control at the top and bottom of the range.
- Another source can not interrupt an existing source playing via Shairport Sync. it will be given a 'busy' signal.