summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2024-01-31doc: Make version and date files phony targetsxengineering
This makes sure that the version / date file is always re-generated. Otherwise it is hard to make sure that e.g. the version is always aligned with the real state.
2024-01-30doc: Restrict lldpd to Unix OS not Linuxxengineering
The lldpd homepage [1] mentions Unix operating systems as host systems, not only Linux. Furthermore there is a possibly working homebrew package for MacOS. [1]: https://lldpd.github.io [2]: https://formulae.brew.sh/formula/lldpd#default
2024-01-30doc: Add section 'Getting soundbox'xengineering
2024-01-30doc: Add version information to PDF title pagexengineering
Since otherwise the Git describe output / version information is only embedded into the file name the risk is given that Git version information is lost by renaming the file.
2024-01-30doc: Reformulate variadic command definitionxengineering
The new format is closer to e.g. 'man 1 printf'.
2024-01-30doc: Move 'setup-alpine' to configuration sectionxengineering
This was never part of an installation but instead of a configuration step.
2024-01-30doc: Add section 'Bill of materials'xengineering
This is the central reference what is required to build soundbox devices.
2024-01-30doc: Rewrite introductionxengineering
The introduction was very limited so far but is important to manage expectations regarding the device.
2024-01-28doc: Add new chapter 'Developer documentation'xengineering
This new chapter should be the one with the highest level of details. The section about versioning is also moved there with this commit.
2024-01-27doc: Use Git-provided commit date for PDFxengineering
Using the date of the build makes it not-reproducible. This should be avoided. Furthermore the date on the front page should anyway reflect when the source of the document was created. Not when it was converted into a PDF.
2024-01-27doc: Switch protocol, format and codecxengineering
The following changes are included in this commit: - multicast to unicast - UDP to TCP - Matroska to ogg - MP3 to FLAC Switching to these protocols has several advantages. Avoiding multicast makes it unnecessary to care about the available multicast addresses in the local network. Unicast addresses are anyway assigned by DHCP. In a multi-room setup this has of course the disadvantage that the same data might be streamed via separate connections. The bandwidth requirement would be multiplied by the number of soundbox devices. But since a stream takes around 2 Mbit/s and we live in a world where 100 Mbit/s in a local network should not be a problem the inefficiency can be neglected. Switching from UDP to TCP has the advantage that the stream is transmitted reliably. Furthermore it avoids the situation that multiple clients stream to the same soundbox simultaneously since a single-connection TCP server is used. The switch from Matroska to ogg is done because the ogg format is recommended on the FLAC homepage. FLAC is used instead of MP3 because it is a lossless audio compression format. This is obviously superior compared to the lossy MP3 format regarding audio quality.
2024-01-27mech: Fix chinch hole positionxengineering
2024-01-26mech: Fix wrong case y dimension calculationxengineering
The y dimension of the shell connectors was assumed to be bolt_l. But this ignores that their thickness is bolt_l-t because the bolt has to go through the shell with thickness t before entering the shell connector.
2024-01-21doc: Rework user guide for streamingxengineering
The default streaming guide is now far away from the original taken from the FFmpeg streaming guide. Since the command can handle a lot of inputs its also not useful to send sine waves to soundbox devices.
2024-01-20doc: Add user guide for device discoveryxengineering
2024-01-20doc: Add OpenRC service configurationxengineering
This makes sure the audio-receiving software `ffplay` runs all the time.
2024-01-20doc: Split configuration section into subsectionsxengineering
2024-01-20doc: Add lldpd configurationxengineering
This makes a soundbox device discoverable via the Link Layer Discovery Protocol (LLDP). That way a client application can lookup the available soundbox devices inside the network to display playback options.
2024-01-14doc: Always use MP3 as audio codecxengineering
While transcoding to a lossy formate like MP3 is not recommended [1] forquality reasons it has the advantage that alway UPD / Matroska / MP3 is used for soundbox. That way the stream can be stopped and started at any time without re-launching ffplay on the soundbox device. This could make the SSH connection to the soundbox not longer needed. [1]: https://trac.ffmpeg.org/wiki/Encode/HighQualityAudio#WhenshouldItranscodeaudio
2024-01-14doc: Simplify streaming commandsxengineering
2024-01-14doc: Switch from RTP to Matroska and UDPxengineering
The Matroska format has to advantage that a stream can be stopped and the restarted at any time without executing new commands on the soundbox device. Since Matroska and RTP have similar / redundant features [1] the transport protocol is switched to plain UDP. [1]: https://en.wikipedia.org/wiki/Comparison_of_video_container_formats#cite_note-22
2024-01-14Add versioned documentation file in artifacts dirxengineering
The full soundbox-<version>- prefix was only used for the artifact tar archive name so far. This has the advantage that the file names inside that archive are shorter like 'documentation.pdf'. But sometimes it is useful to pass only the documentation around as a PDF file because it is easier for people to open it compared to a tar file. For this purpose a second artifact installation for the documentation PDF is added including the soundbox-<version>- prefix.
2024-01-14doc: Fix duplicated periodxengineering
2024-01-14doc: Switch to multicast for streamingxengineering
This allows to stream to multiple devices at the same time. Nevertheless it still works for a point to point stream.
2024-01-14doc: Explain how to enable default RPi audioxengineering
The soundbox software should be portable to other Raspberry Pis without the HiFiBerry DAC too.
2024-01-14doc: Unify replacable parts of streaming commandxengineering
2024-01-14doc: Use native audio codec for streamingxengineering
The music streaming documentation used to enforce re-encoding via ffmpeg to save bandwidth. This led to pretty poor audio quality. This is not the purpose of soundbox. It is assumed that the user wants the highest possible audio quality as default.
2024-01-14doc: Add Alpine Linux config guidexengineering
Configuring the Alpine Linux operating system correctly for soundbox is not trivial. Since it is very important it has to be documented in detail.
2024-01-14doc: Switch to tar-based installationxengineering
The tar-based installation is more difficult to explain but has the advantage that the partition size is maximized from the beginning. This is way easier than resizing the partition after the installation.
2024-01-12doc: Add Alpine Linux installation instructionsxengineering
This is currently the recommended OS installation for soundbox.
2024-01-10mech: Rework front panelxengineering
The positions of the connectors had to be adapted to the new PCB case dimensions. Furthermore the micro USB port which is built in to supply the device with power is now the only visible micro USB port from the outside. The other one is unused and could lead to confusion. User might plug in the power cable into the wrong port. Hiding this misleading USB port is an elegant way to avoid this problem. Developers can still open the device to make use of that port if required.
2024-01-09mech: Adapt thickness and spacingxengineering
The front panel has to be very close and thin so that USB and HDMI cables can still be connected when only the ports are cut out of the panel.
2024-01-09mech: pcb_case: Add spacersxengineering
Since a proper norm-based distance bolt was not found printing spacers is the easiest way to make the case producable independent of part availability.
2024-01-09mech: pcb_case: Align connector_z and bolt lengthxengineering
This makes sure that the bolts inside the connectors align with them. Thus the bolts do not stick inside the case which might lead to PCB collisions.
2024-01-09mech: pcb_case: Fix height calculationxengineering
The height should take into account that the shell is two instead of one times the thickness high. This is relevant for the vertical spacing.
2024-01-06doc: Change paragraph distancexengineering
There used to be no extra space between paragraphs which in combination with no indentation was not useful.
2024-01-05doc: Fix missing `-re` flag for ffmpeg streamingxengineering
This flag makes sure the file is streamed in native frame rate and not e.g. way faster. This is the expected behaviour.
2024-01-05doc: Switch from UDP port 1234 to UDP port 5316xengineering
This port should be used in the future as soundbox standard port.
2024-01-05doc: Add example for FFMpeg MP3 streamingxengineering
This allows more testing than only streaming sine waves.
2024-01-05doc: Add section 'Playing audio'xengineering
This documents a basic FFmpeg streaming example so that soundbox devices can be tested.
2024-01-05doc: Write section 'Versioning'xengineering
This section is important to communicate how to interpret version numbers in the context of this device repository.
2024-01-05doc: Build twice with LaTeXxengineering
This is required to build the table of contents and similar parts of the document correctly.
2024-01-05doc: Remove 'soundbox-' prefix from doc PDFxengineering
Inside the artifacts folder aswell as inside the source folder adding a 'soundbox-' prefix to files is uncommon. In both cases only the root level folder should contain the name 'soundbox' to remove redundancies.
2024-01-05Introduce 'debug' targetxengineering
This target will skip generating the artifacts directory. This avoids a bloated build directory while the default target 'all' still generates the artifacts.
2024-01-04Provide artifacts folder including build archivesxengineering
All build files relevant for users (artifacts) should be provided in build/artifacts. This folder has subdirectories for every revision and a corresponding Zstandard-compressed Tar archive. This archive contains the full result of the build of the current source directory and can easily be shared.
2024-01-03mech: Add assembly to mech build targetxengineering
The CAD model of the full assembly might be useful to be included in other projects or CAD files.
2024-01-03mech: Leave STL files inside build folderxengineering
Most users will not own the default printer and thus cannot work with the built gcode files with the default slicer configuration. It might be easier for those users to manually slice the STL instead of modifying the soundbox source code.
2024-01-03doc: Add brief description for first chapterxengineering
2024-01-03Write 'Build instructions' for the READMExengineering
2024-01-03Write 'Repository overview' for READMExengineering
Providing a structural overview inside the README should help developers new to the repository to get familiar with it.