I am new to snaps but this solution seems to has several major drawbacks. I do not want to maintain a separate version of ALSA. This means any bug fixes or security patches will require a new snap to be released, correct?
Let me know if there is a better way than having to maintain my own version.
@ogra I have made the changes outlined in the document you provided and that solved the issue with the missing file.
My next question is about the /etc/asound.conf file. This is needed to configure which device to stream the audio to/from. It seems it’s not able to read this file. I cannot package this with the snap since this is something the user can change.
I’m getting the error: Invalid CTL default and Invalid PCM default
i think “needed” is a broad statement, i guess it is rather rare nowadays that people touch it (vs simply using something like pavuctrl (given that the majority of desktops nowadays integrates with pulse and you can tweak everything there))
i dont think ubuntu at least has shipped /etc/asound.conf in the last decade …
nontheless you are indeed correct that people can configure alsa through it and i guess it would make sense to add read access to that file directly in
@jdstrand was there any particular security concern why read access to /etc/asound.conf was not added to the alsa interface ?
@ogra@jdstrand This may be because I am targeting Raspian OS. At the top of the /usr/share/alsa/alsa.conf, it is preloading the following config files:
I tried packaging the raspian /usr/share/alsa directory which is the @datadir listed in this config file but still get the errors Invalid CTL default and Invalid PCM default
In Raspian, if you have multiple sound devices, you can change the device in the UI and it will update the ~/.asoundrc with the appropriate device id.
Since I am running this as a snap daemon, the next best configuration file for the sound card is the /etc/asound.conf so that is why I was asking for system-files permission to this.
At this point, I am stuck and have no work-around. Any help is very much appreciated!
Use of the alsa interface requires special configuration. Keep in mind, granting access via system-files to /usr/share/alsa would not help because /usr comes from the base snap, not the host’s filesystem. You should adjust your snap to configure alsa accordingly. I believe @lucyllewy and/or the @advocacy team have additional information that might assist you in getting the alsa interface to work.
I have tried the solution provided but it is only for Ubuntu using pulseaudio. I’m trying to deploy my app to Raspian. I have a C++ app that includes a WebRTC library that require libsdl2-2.0 that requires alsa. Requiring a special configuration and recompiled alsa library is quite a lot to ask.
Any other documentation, tutorials or examples that will help solve this is appreciated.
@jdstrand@ogra We still haven’t been able to resolve this issue.
Question: Do you know of any consultants that have expertise in this area who would be interested in helping us get past this hurdle? We want to leverage the snapcraft packaging but this ALSA issue is blocking us.