summaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
Diffstat (limited to 'doc')
-rw-r--r--doc/documentation.tex56
1 files changed, 47 insertions, 9 deletions
diff --git a/doc/documentation.tex b/doc/documentation.tex
index fe58ba6..a6ba82b 100644
--- a/doc/documentation.tex
+++ b/doc/documentation.tex
@@ -72,11 +72,15 @@ seconds a new discovery packet is emitted by soundbox. Thus it can take up to
\section{Playing audio} \label{playing-audio}
Audio can be streamed to \texttt{soundbox} devices with the \texttt{ffmpeg}
-command. Audio files or internet stream addresses can be passed as input.
+command. Audio files or internet stream addresses can be passed as input. Since
+\texttt{ffmpeg} supports multiple outputs, multiple \texttt{soundbox} devices
+can be targeted with their IP addresses.
\begin{verbatim}
-ffmpeg -re -i <input> -acodec libmp3lame -f matroska \
- udp://224.0.0.99:5316
+ffmpeg -re -i <input> \
+ -acodec flac -f ogg tcp://<ip-1>:5316 \
+ -acodec flac -f ogg tcp://<ip-2>:5316 \
+ ...
\end{verbatim}
More details about FFmpeg streaming can be read from the FFmpeg streaming
@@ -261,26 +265,60 @@ option has to be inserted instead:
echo 'dtparam=audio=on' >> /media/mmcblk0p1/config.txt
\end{verbatim}
+\subsection{soundbox script}
+
+soundbox uses the command \texttt{ffplay} for playback. A script has to be
+added to call the command over and over again to allow new connections. The
+script can be added with \texttt{echo} and is made executable with
+\texttt{chmod}. \texttt{lbu add} will make sure that the script will be made
+persistent by calling \texttt{lbu commit} later (see
+section~\ref{lbu-persistence}).
+
+\begin{verbatim}
+echo '#!/bin/ash
+
+set -e
+
+while true
+do
+ ffplay -autoexit tcp://0.0.0.0:5316?listen
+done' > /usr/local/bin/soundbox
+
+chmod 755 /usr/local/bin/soundbox
+
+lbu add /usr/local/bin/soundbox
+\end{verbatim}
+
+This makes the command \texttt{soundbox} available on the system.
+
\subsection{Service configuration}
To receive audio streams via the network it is required to run the
-\texttt{ffplay} command continuously. This is possible by creating a service
-file for the OpenRC init system with \texttt{echo} and enabling the service
-with \texttt{rc-update}.
+\texttt{soundbox} command continuously. This is possible by creating a service
+file for the OpenRC init system with \texttt{echo}, making that executable with
+\texttt{chmod} and enabling the service with \texttt{rc-update}. Also here
+\texttt{lbu add} makes sure that the service file will be made persistent later
+(see section~\ref{lbu-persistence} for details).
\begin{verbatim}
echo '#!/sbin/openrc-run
name="soundbox"
-command="/usr/bin/ffplay"
-command_args="udp://224.0.0.99:5316"
+command="/usr/local/bin/soundbox"
+command_args=""
pidfile="/run/soundbox.pid"
command_background=true' > /etc/init.d/soundbox
+chmod 755 /etc/init.d/soundbox
+
rc-update add soundbox default
+
+lbu add /etc/init.d/soundbox
\end{verbatim}
-\subsection{Persistence of changes and reboot}
+This will make sure the soundbox script is run on every boot.
+
+\subsection{Persistence of changes and reboot}\label{lbu-persistence}
Since a diskless Alpine Linux installation is preferred for soundbox the
changes have to be made persistent with \texttt{lbu}. Rebooting after it makes