Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

POC: systemd-sysext use via addons #7450

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

antonlacon
Copy link
Contributor

@antonlacon antonlacon commented Feb 2, 2023

This is a proof of concept of using systemd-sysext and a kodi addon to modify the base image's contents. Systemd-sysxt, in short, is systemd's overlayfs manager that may alter the contents of /usr or /opt. It's intended for making changes to otherwise immutable filesystems. Systemd's intended use case for it is embedded or stateless machines. Read more here:
https://www.freedesktop.org/software/systemd/man/systemd-sysext.html
https://0pointer.net/blog/testing-my-system-code-in-usr-without-modifying-usr.html
https://blogs.igalia.com/berto/2022/09/13/adding-software-to-the-steam-deck-with-systemd-sysext/

The first commit is a systemd mount to back /var/lib/extensions with persistent storage (space in /storage/.config/extensions). I don't write systemd service scripts often, so this may be improved upon.

The demonstration addon is called core-scripts. Once installed, and run, it will put the update-system script into an overlay atop /usr/bin, so it's readily found in $PATH. Systemd-sysext does very minor version control, checking against /etc/os-release's ID and VERSION_ID values match what is in the addon. When the versions don't match, such as a say this addon being tagged for LE11 being present when updating to LE12, systemd-sysext will refuse to load the contents into the overlay. Systemd-sysext does not do finer detail, like 11.0.0 -> 11.0.1 being different. Mitigating this would be to ship the addon already in the image, instead of baking the script in separately (like via busybox's package.mk) and installing the addon later.

The goal would be able to replace certain parts of the image via the addon system instead of having to spin a new release image. Candidates could be the settings addon, or a script like is added here.

The addon is barebones, with no user feedback beside content in the log and very little thought given to what does it do when it updates. This will need to be expanded upon if this moves forward.

What would be nice, and I don't know if it's possible with Kodi addons, is to have the addon auto-execute on install or update. As written, the addon needs to be run to effect a change.

I don't know what would happen if two such addons provided update-system. My expectation is it would be down to a race of which sysext loads faster, or order they're processed (alphabetical?). My expectation is for this to be handled by controlling what addons are added to the tree, rather than trying to make an addon figure it out.

Content replaced in the base image via an extension would be writable by an enduser.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant