]> git.ipfire.org Git - thirdparty/systemd.git/log
thirdparty/systemd.git
3 months agoupdate TODO 37855/head
Lennart Poettering [Mon, 16 Jun 2025 10:11:31 +0000 (12:11 +0200)] 
update TODO

3 months agotest: add testcase for unpriv machined nspawns reg + killing
Lennart Poettering [Mon, 30 Jun 2025 21:13:26 +0000 (23:13 +0200)] 
test: add testcase for unpriv machined nspawns reg + killing

Let's add a superficial test for the code we just added: spawn a
container unpriv, make sure registration fully worked, then kill it via
machinectl, to ensure it all works properly.

Not too thorough but a good start.

3 months agounits: systems might take a while to boot
Lennart Poettering [Fri, 13 Jun 2025 16:21:11 +0000 (18:21 +0200)] 
units: systems might take a while to boot

vmspawn systems might take quite a while to boot in particular if they
go through uefi and wait for a network lease. Hence let's increase the
start timeout to 2min (from 45s). We'll do that for both nspawn and
vmspawn, even though the UEFI thing certainly doesn't apply there (but
the DHCP thing still does).

3 months agounits: add units for vmspawn/nspawn in --user mode too
Lennart Poettering [Fri, 23 May 2025 13:41:58 +0000 (15:41 +0200)] 
units: add units for vmspawn/nspawn in --user mode too

3 months agovmspawn: do not set vt220
Lennart Poettering [Fri, 11 Jul 2025 07:05:29 +0000 (09:05 +0200)] 
vmspawn: do not set vt220

We do not let qemu do terminal stuff, hence no point in setting any
TERM.

3 months agovmspawn: introduce --notify-ready= switch
Lennart Poettering [Mon, 16 Jun 2025 08:49:25 +0000 (10:49 +0200)] 
vmspawn: introduce --notify-ready= switch

This mimics the switch of the same name from nspawn: it controls whether
we expect a READY=1 message from the payload or not. Previously we'd
always expect that. This makes it configurable, just like it is in
nspawn.

There's one fundamental difference in behaviour though: in nspawn it
defaults to off, in vmspawn it defaults to on. (for historical reasons,
ideally we'd default to on in both cases, but changing is quite a compat
break both directly and indirectly: since timeouts might get triggered).

3 months agovmspawn: substantially beef up cgroup logic, to match more closely what nspawn does
Lennart Poettering [Fri, 13 Jun 2025 08:29:01 +0000 (10:29 +0200)] 
vmspawn: substantially beef up cgroup logic, to match more closely what nspawn does

This beefs up the cgroup logic, adding --slice=, --property= to vmspawn
the same way it already exists in nspawn.

There are a bunch of differences though: we don't delegate the cgroup
access in the allocated unit (since qemu wouldn't need that), and we do
registration via varlink not dbus. Hence, while this follows a similar
logic now, it differs in a lot of details.

This makes in particular one change: when invoked on the command line
we'll only add the qemu instance to the allocated scope, not the vmspawn
process itself (this follows more closely how nspawn does this where
only the container payload has its scope, not nspawn itself). This is
quite tricky to implement: unlike in nspawn we have auxiliary services
to start, with depencies to the scope. This means we need to start the
scope early, so that we know the scope's name. But the command line to
invoke is only assembled from the data we learn about the auxiliary
services, hence much later. To addres we'll now fork off the child that
eventually will become early, then move it to a scope, prepare the
cmdline and then very late send the cmdline (and the fds we want to
pass) to the prepared child, which then execs it.

3 months agovmspawn: spawn polkit during registration phase
Lennart Poettering [Thu, 12 Jun 2025 09:48:37 +0000 (11:48 +0200)] 
vmspawn: spawn polkit during registration phase

Just like in nspawn, there's a chance we need to PK authenticate the
registration, hence let's spawn off the agent for that during that
phase, and terminate it once we don't need it anymore.

3 months agovmspawn: use VM leader PID not vmspawn PID to register machine
Lennart Poettering [Thu, 15 May 2025 09:00:17 +0000 (11:00 +0200)] 
vmspawn: use VM leader PID not vmspawn PID to register machine

Let's make vmspawn machine registration more like nspawn machine
registration, and register the payload, not vmspawn/nspawn itself.

3 months agonspawn: properly order include of constants.h
Lennart Poettering [Fri, 11 Jul 2025 12:25:40 +0000 (14:25 +0200)] 
nspawn: properly order include of constants.h

3 months agonspawn: tweak logging/notifications when processing exit requests
Lennart Poettering [Wed, 9 Jul 2025 07:36:25 +0000 (09:36 +0200)] 
nspawn: tweak logging/notifications when processing exit requests

3 months agonspawn: slightly beef up READY= logic in nspawn
Lennart Poettering [Mon, 16 Jun 2025 08:46:37 +0000 (10:46 +0200)] 
nspawn: slightly beef up READY= logic in nspawn

Let's also send out a STATUS= message when we get READY=1 if it didn't
come with a STATUS= message itself.

Also, let's initially say the container is "started", and only once the
READY=1 is seen claim it was "running".

3 months agonspawn: reorganize scope allocation/registration logic
Lennart Poettering [Fri, 23 May 2025 20:04:56 +0000 (22:04 +0200)] 
nspawn: reorganize scope allocation/registration logic

This cleans up allocation of a scope unit for the container: when
invoked in user context we'll now allocate a scope through the per-user
service manager instead of the per-system manager. This makes a ton more
sense, since it's the user that invokes things after all. And given that
machined now can register containers in the user manager there's nothing
stopping us to clean this up.

Note that this means we'll connect to two busses if run unpriv: once to
the per-user bus to allocate the scope unit, and once to the per-system
bus to register it with machined.

3 months agomachinectl: output supervisor info in status output
Lennart Poettering [Wed, 2 Jul 2025 11:12:06 +0000 (13:12 +0200)] 
machinectl: output supervisor info in status output

3 months agomachined: add a bit more debug logging
Lennart Poettering [Wed, 9 Jul 2025 07:35:25 +0000 (09:35 +0200)] 
machined: add a bit more debug logging

3 months agomachined: explicitly watch machine cgroup for getting empty
Lennart Poettering [Wed, 9 Jul 2025 07:35:12 +0000 (09:35 +0200)] 
machined: explicitly watch machine cgroup for getting empty

3 months agomachined: also track 'supervisor' process of a machine
Lennart Poettering [Wed, 2 Jul 2025 09:20:23 +0000 (11:20 +0200)] 
machined: also track 'supervisor' process of a machine

So far, machined strictly tracked the "leader" process of a machine,
i.e. the topmost process that is actually the payload of the machine.
Its runtime also defines the runtime of the machine, and we can directly
interact with it if we need to, for example for containers to join the
namespaces, or kill it.

Let's optionally also track the "supervisor" process of a machine, i.e.
the host process that manages the payload if there is one. This is
generally useful info, but in particular is useful because we might need
to communicate with it to shutdown a machine without cooperation of the
payload. Traditionally we did this by simply stopping the unit of the
machine, but this is not doable now that the host machined can be used
to track per-user machines.

In the long run we probably want a more bespoke protocol between
machined and supervisors (so that we can execute other commands too,
such as request cooperative reboots/shutdowns), but that's for later.

Some environments call the concept "monitor" rather than "supervisor" or
use some other term. I stuck to "supervisor" because nspawn uses this,
and ultimately one name is as good as another.

And of course, in other implementations of VM managers of containers
there might not be a single process tracking each VM/container. Because
of this, the concept of a supervisor is optional.

3 months agomachined: use different polkit actions for registering and creating a machine
Lennart Poettering [Fri, 23 May 2025 20:10:36 +0000 (22:10 +0200)] 
machined: use different polkit actions for registering and creating a machine

The difference between these two operations are large: one is relatively
superficial: for "registration" all resources remain associated with the
invoking user, only the cgroup is reported to machined which then keeps
track of the machine, too. OTOH "creation" a scope is allocated in
system context, hence the invoked code will be owned by the system, and
its resource usage charged against the system.

Hence, use two distinct polkit actions for this, so that we can relax
access to registration, but keep access to creation tough.

3 months agomachined: track UID owner of machines
Lennart Poettering [Fri, 23 May 2025 13:30:22 +0000 (15:30 +0200)] 
machined: track UID owner of machines

Now that unpriv clients can register machines, let's register their UID
too. This allows us to do two things:

1. make sure the scope delegation is assigned to the right UID (so that
   the unpriv user can actually create cgroups below the delegated
   scope)

2. permit certain types of access (i.e. killing, or pty access) to the
   client without auth if it owns the machine.

3 months agomachined: optionally track machines in cgroup subgroups
Lennart Poettering [Wed, 21 May 2025 15:23:47 +0000 (17:23 +0200)] 
machined: optionally track machines in cgroup subgroups

3 months agocgroup-util: add cg_path_get_unit_full() helper and related calls
Lennart Poettering [Wed, 21 May 2025 15:21:36 +0000 (17:21 +0200)] 
cgroup-util: add cg_path_get_unit_full() helper and related calls

This helper returns not only the unit a cgroup belongs to, but also the
cgroup sub-path beyond it.

3 months agopidref: add pidref_set_pid_and_pidfd_id()
Lennart Poettering [Wed, 2 Jul 2025 09:12:23 +0000 (11:12 +0200)] 
pidref: add pidref_set_pid_and_pidfd_id()

This new helper takes both a PID and and a pidfd ID, and initializes a
PidRef from it. It ensures they actually belong together and returns an
error if not.

3 months agoSeveral follow-ups for recent SELinux changes (#38161)
Daan De Meyer [Fri, 11 Jul 2025 07:01:00 +0000 (09:01 +0200)] 
Several follow-ups for recent SELinux changes (#38161)

3 months agonetwork/bridge-vlan: allow to configure bridge vlan on stacked bridge master interface
Yu Watanabe [Fri, 11 Jul 2025 03:58:33 +0000 (12:58 +0900)] 
network/bridge-vlan: allow to configure bridge vlan on stacked bridge master interface

Fixes #38157.

3 months agoCleanups for missing_xyz.h headers (#37904)
Yu Watanabe [Fri, 11 Jul 2025 06:20:10 +0000 (15:20 +0900)] 
Cleanups for missing_xyz.h headers (#37904)

Continuation of #37960.

The same concern as expalined in #37960 exists also in
missing_syscall.h. If we use enough new glibc, a function we want to use
may be already provided by glibc, but our baseline glibc may not. And it
is hard to detect in our daily development.

This moves all prototypes of syscalls to relevant headers, and missing
syscall functions are defined in relevant .c files of libc wrapper. This
way, we can use usual header as is, e.g. when we want to write code with
`move_mount()`, we can simply use sys/mount.h without checking if it is
supported by our baseline glibc.

3 months agojournal: fix typo
Yu Watanabe [Fri, 11 Jul 2025 05:12:16 +0000 (14:12 +0900)] 
journal: fix typo

Follow-up for df5b3426f60bb626f46f93fbdacecae274c1645b.

3 months agoman: fix typo
Yu Watanabe [Fri, 11 Jul 2025 05:11:01 +0000 (14:11 +0900)] 
man: fix typo

Follow-up for 7aefb194e754cae9c166539a103e9fd6b7e59798.

3 months agoconf-files: make conf-file enumerators provide more detailed information of enumerate...
Yu Watanabe [Fri, 11 Jul 2025 04:50:47 +0000 (13:50 +0900)] 
conf-files: make conf-file enumerators provide more detailed information of enumerated files (#38006)

This introduces `struct ConfFile` that stores detailed information of an
enumerated file, and introduces `conf_files_list_full()` and friends
that provide results in `ConfFile`.
Then make udev, hwdb, catalog, and cat-files use the new function and
struct to make them not read files outside of specified root directory.

3 months agoraw-clone: move definition to .c file 37904/head
Yu Watanabe [Thu, 19 Jun 2025 19:31:08 +0000 (04:31 +0900)] 
raw-clone: move definition to .c file

Then, we can decrease the number of headers to be indirectly included
by including raw-clone.h. No functional change.

3 months agoreboot-util: merge with raw-reboot.h
Yu Watanabe [Thu, 19 Jun 2025 19:18:00 +0000 (04:18 +0900)] 
reboot-util: merge with raw-reboot.h

The header raw-reboot.h is only used with reboot-util. Let's merge them.

3 months agodocs: mention src/include/ directories
Yu Watanabe [Tue, 8 Jul 2025 04:52:03 +0000 (13:52 +0900)] 
docs: mention src/include/ directories

3 months agoinclude: use unit8_t for uuid
Yu Watanabe [Tue, 8 Jul 2025 05:30:07 +0000 (14:30 +0900)] 
include: use unit8_t for uuid

To emphasize it is an array of bytes.
This also align variables.
No functional changes. Just refactoring.

3 months agoinclude: move trivial kernel header wrappers to src/include/override/
Yu Watanabe [Sun, 6 Jul 2025 05:52:23 +0000 (14:52 +0900)] 
include: move trivial kernel header wrappers to src/include/override/

3 months agolibc-wrapper: introduce a tiny libc wrapper
Yu Watanabe [Sat, 21 Jun 2025 11:29:51 +0000 (20:29 +0900)] 
libc-wrapper: introduce a tiny libc wrapper

Then, move syscall definitions to the wrapper, and prototypes are moved
to relevant headers.

This also adds checks for add_key() and request_key(), as one day
glibc may be going to add some of them separatedly.

The check for fspick in meson.build is dropped, as it is currently
unused in our code.

This also moves
- basic/missing_bpf.h -> include/override/linux/bpf.h,
- basic/missing_keyctl.h -> include/override/linux/keyctl.h.

3 months agobasic: move basic/missing_syscall_defs.h -> include/override/sys/syscall.h
Yu Watanabe [Wed, 18 Jun 2025 23:35:35 +0000 (08:35 +0900)] 
basic: move basic/missing_syscall_defs.h -> include/override/sys/syscall.h

This also moves syscall tables and generators to the same directory.

Note, inclusion of asm/sgidefs.h is dropped, as it is already included
by unistd.h and sys/syscall.h.

3 months agotree-wide: several cleanups for generating symbol lists and gperf files
Yu Watanabe [Tue, 8 Jul 2025 04:07:32 +0000 (13:07 +0900)] 
tree-wide: several cleanups for generating symbol lists and gperf files

- pass our system include directories to make generators use our libc
  wrappers and latest kernel headers,
- include relevant headers in generated gperf file,
- use files() rather than find_program(), as the result of
  find_program() cannot be passed to 'input' of custom_target(),
- move generate-bpf-delegate-configs.py to src/core/, as it is only used
  by libcore.

3 months agoinclude: move libc header wrappers to src/include/override/, and kernel headers to...
Yu Watanabe [Sun, 6 Jul 2025 03:19:26 +0000 (12:19 +0900)] 
include: move libc header wrappers to src/include/override/, and kernel headers to src/include/uapi/

Preparation for later changes.

3 months agomkosi: various improvements (#38156)
Yu Watanabe [Fri, 11 Jul 2025 03:40:22 +0000 (12:40 +0900)] 
mkosi: various improvements (#38156)

3 months agocore/selinux-access: insert an empty line after function arguments 38161/head
Yu Watanabe [Fri, 11 Jul 2025 02:51:54 +0000 (11:51 +0900)] 
core/selinux-access: insert an empty line after function arguments

Follow-ups for fe3f2ac0734e64dcd729b00992a6261cbf4cc846 and
e3fef210c8903a9a3871ea5ba9b558b6cdbabea3.

3 months agoselinux-util: downgrade log level to LOG_DEBUG when error code is zero
Yu Watanabe [Fri, 11 Jul 2025 02:46:08 +0000 (11:46 +0900)] 
selinux-util: downgrade log level to LOG_DEBUG when error code is zero

Previously, the logger is only used in error paths, but since
fe3f2ac0734e64dcd729b00992a6261cbf4cc846, the logger is also used in a
success path. Let's not log loudly on success.

This also drops unused log_selinux_enforcing().

3 months agocatalog: do not read catalog files outside of specified root directory 38006/head
Yu Watanabe [Tue, 1 Jul 2025 02:33:22 +0000 (11:33 +0900)] 
catalog: do not read catalog files outside of specified root directory

3 months agohwdb-util: do not read hwdb files outside of specified root directory
Yu Watanabe [Tue, 1 Jul 2025 02:21:09 +0000 (11:21 +0900)] 
hwdb-util: do not read hwdb files outside of specified root directory

3 months agohwdb-util: coding style update
Yu Watanabe [Tue, 1 Jul 2025 02:12:59 +0000 (11:12 +0900)] 
hwdb-util: coding style update

- use 'r' for storing results,
- use RET_GATHER().

3 months agoudev-rules: do not read udev rules files outside of specified root directory
Yu Watanabe [Tue, 1 Jul 2025 02:05:18 +0000 (11:05 +0900)] 
udev-rules: do not read udev rules files outside of specified root directory

3 months agoTEST-17-UDEV: conditionalize test cases for testuser
Yu Watanabe [Fri, 4 Jul 2025 07:54:49 +0000 (16:54 +0900)] 
TEST-17-UDEV: conditionalize test cases for testuser

Then, we can also run the test script in our local machine.

3 months agoudevadm: do not read udev rules files outside of the specified root directory
Yu Watanabe [Mon, 30 Jun 2025 19:46:41 +0000 (04:46 +0900)] 
udevadm: do not read udev rules files outside of the specified root directory

With this change, an invalid symlink and an empty file is silently
ignored. Hence, the test code is slightly updated.

3 months agopretty-print: make conf_files_cat() not show files outside of the specified root.
Yu Watanabe [Sun, 29 Jun 2025 20:22:53 +0000 (05:22 +0900)] 
pretty-print: make conf_files_cat() not show files outside of the specified root.

Then, make the function show the original and resolved path if they are
different.

With this change, procfs needs to be mounted on /proc/, hence the test
code is slightly updated.

3 months agopretty-print: several cleanups for cat_files()
Yu Watanabe [Sun, 29 Jun 2025 20:18:32 +0000 (05:18 +0900)] 
pretty-print: several cleanups for cat_files()

- drop redundant error messages in cat_files(), as cat_file() internally
  logs errors,
- show an empty line and filename before opening file, to make not mix
  any error messages with the previous file,
- drop unnecessary fflush(),
- use RET_GATHER() and continue to show files even if some files cannot
  be shown.

3 months agoconf-files: introduce conf_files_list_full() and friends that provides results in...
Yu Watanabe [Sun, 29 Jun 2025 02:01:52 +0000 (11:01 +0900)] 
conf-files: introduce conf_files_list_full() and friends that provides results in ConfFile

3 months agoconf-files: make conf_files_list() and friends internally use struct ConfFile
Yu Watanabe [Tue, 1 Jul 2025 01:33:54 +0000 (10:33 +0900)] 
conf-files: make conf_files_list() and friends internally use struct ConfFile

No functional change, just refactoring.

3 months agoconf-files: introduce struct ConfFile to store information of found conf file
Yu Watanabe [Sun, 29 Jun 2025 01:12:09 +0000 (10:12 +0900)] 
conf-files: introduce struct ConfFile to store information of found conf file

It is currently unused, will be used later. Preparation for later changes.

3 months agochase: allow to request O_PATH fd even with CHASE_NONEXISTENT
Yu Watanabe [Mon, 30 Jun 2025 06:18:47 +0000 (15:18 +0900)] 
chase: allow to request O_PATH fd even with CHASE_NONEXISTENT

3 months agotest-cgroup: Ignore ENOENT from cg_create(); test-cgroup-util: Ignore ENXIO in one...
Yu Watanabe [Fri, 11 Jul 2025 01:38:04 +0000 (10:38 +0900)] 
test-cgroup: Ignore ENOENT from cg_create(); test-cgroup-util: Ignore ENXIO in one more place (#38158)

This was the only test failure building systemd-252-51.el9 in a
container, also previously reported against 252-rc1 under Gentoo in
#25015

This is a forward-port of the patch we actually started using for CIQ's
builds of the EL9-derived package, which was:

```diff
--- systemd-252/src/test/test-cgroup.c 2022-10-31 18:59:18.000000000 +0000
+++ systemd-252-test/src/test/test-cgroup.c 2025-07-10 00:47:07.541000000 +0000
@@ -62,7 +62,7 @@
         log_info("Paths for test:\n%s\n%s", test_a, test_b);

         r = cg_create(SYSTEMD_CGROUP_CONTROLLER, test_a);
-        if (IN_SET(r, -EPERM, -EACCES, -EROFS)) {
+        if (IN_SET(r, -EPERM, -EACCES, -EROFS, -ENOENT)) {
                 log_info_errno(r, "Skipping %s: %m", __func__);
                 return;
         }
```

I confirmed that the `ERRNO_IS_NEG_FS_WRITE_REFUSED` macro is equivalent
to checking the first 3 error codes above, so the addition of the check
for `ENOENT` is still just as relevant as it was in 252, but adding it
into the macro would be inconsistent with its name, description, and
possible other uses. Hence, in this PR I'm adding the extra check into
the `if`.

3 months agojournalctl: do not fail on SIGTERM/SIGINT or STDOUT disconnect when running with...
Yu Watanabe [Fri, 11 Jul 2025 01:36:31 +0000 (10:36 +0900)] 
journalctl: do not fail on SIGTERM/SIGINT or STDOUT disconnect when running with --follow (#38116)

Closes #38114.

3 months agoio.systemd.Manager.Describe fix context/runtime split (#38135)
Yu Watanabe [Fri, 11 Jul 2025 01:26:57 +0000 (10:26 +0900)] 
io.systemd.Manager.Describe fix context/runtime split (#38135)

This PR rearranges fields in io.systemd.Manager.Describe according to
the guidance by Lennart:

> If a property can be set in a unit file, ever, then it belongs in context.
> Otherwise, it belongs to runtime.

Closes #38124.

3 months agoPlumbing to perform SELinux checks in varlink API (#38146)
Yu Watanabe [Fri, 11 Jul 2025 01:20:36 +0000 (10:20 +0900)] 
Plumbing to perform SELinux checks in varlink API (#38146)

This PR does minimal changes to introduce varlink support. Ideally, the
code should switch to using `mac_selinux_get_our_label()` and new
`mac_selinux_get_peer_label()`. But I leave it for now to minimize
breakage. `mac_selinux_get_peer_label()` remains unused.

This is a prep step to merge
https://github.com/systemd/systemd/pull/38032

3 months agotest-cgroup-util: Ignore ENXIO in one more place 38158/head
Solar Designer [Thu, 10 Jul 2025 23:46:38 +0000 (01:46 +0200)] 
test-cgroup-util: Ignore ENXIO in one more place

3 months agoNEWS: mention about the exit code change in journalctl --follow 38116/head
Yu Watanabe [Tue, 8 Jul 2025 09:42:02 +0000 (18:42 +0900)] 
NEWS: mention about the exit code change in journalctl --follow

3 months agotest: drop unnecessary disablement of pipefail
Yu Watanabe [Tue, 8 Jul 2025 09:36:09 +0000 (18:36 +0900)] 
test: drop unnecessary disablement of pipefail

3 months agomain-func: drop unused DEFINE_MAIN_FUNCTION_WITH_POSITIVE_SIGNAL()
Yu Watanabe [Tue, 8 Jul 2025 09:30:48 +0000 (18:30 +0900)] 
main-func: drop unused DEFINE_MAIN_FUNCTION_WITH_POSITIVE_SIGNAL()

3 months agojournalctl: do not fail on SIGTERM/SIGINT, or when STDOUT is disconnected
Yu Watanabe [Tue, 8 Jul 2025 09:19:05 +0000 (18:19 +0900)] 
journalctl: do not fail on SIGTERM/SIGINT, or when STDOUT is disconnected

The current behavior is not useful when e.g. pipefail is enabled.
Let's exit cleanly in such cases.

Closes #38114.

3 months agotest-cgroup: Ignore ENOENT from cg_create()
Solar Designer [Thu, 10 Jul 2025 22:28:14 +0000 (00:28 +0200)] 
test-cgroup: Ignore ENOENT from cg_create()

which was the only test failure building systemd-252-51.el9 in a
container, also previously reported against 252-rc1 under Gentoo
in #25015

3 months agoman/systemd.exec: explain how BPF token works
Matteo Croce [Thu, 10 Jul 2025 11:37:27 +0000 (13:37 +0200)] 
man/systemd.exec: explain how BPF token works

Add a small paragraph explaining how BPF token works, how it's being
created and its relationship between the BPF filesystem.
Move all the relevant documentation in the PrivateBPF= section and let
point all the BPFDelegate* options to that one.

3 months agojournald: support reloading configuration at runtime
Ubuntu [Wed, 11 Jun 2025 23:32:27 +0000 (23:32 +0000)] 
journald: support reloading configuration at runtime

3 months agoIntroduce ERRNO_IS_FS_WRITE_REFUSED(), and use it in binfmt_mounted() (#38117)
Lennart Poettering [Thu, 10 Jul 2025 19:38:13 +0000 (21:38 +0200)] 
Introduce ERRNO_IS_FS_WRITE_REFUSED(), and use it in binfmt_mounted() (#38117)

- This introduces ERRNO_IS_FS_WRITE_REFUSED(), and apply it where
usable.
- This makes unexpected errors in access_fd() called by binfmt_mounted()
propagated to the caller.
- Renames binfmt_mounted() to binfmt_mounted_and_writable(), as it also
checks the fs is writable.
- Voidifies one disable_binfmt() call in shutdown.c.

3 months agouserdb: Add userdb.transient credentials
DaanDeMeyer [Thu, 3 Jul 2025 19:22:41 +0000 (21:22 +0200)] 
userdb: Add userdb.transient credentials

To implement --bind-user in systemd-vmspawn, we need a transient
version of these credentials. These are useful when the home directory
of the user is mounted into the container/vm and every trace of the user
will be (mostly) gone again when the container/vm is shut down.

3 months agoselinux: mac_selinux_unit_access_check_varlink macros 38146/head
Ivan Kruglov [Thu, 10 Jul 2025 10:47:04 +0000 (03:47 -0700)] 
selinux: mac_selinux_unit_access_check_varlink macros

3 months agoselinux: mac_selinux_access_check_varlink_internal()
Ivan Kruglov [Thu, 10 Jul 2025 10:40:21 +0000 (03:40 -0700)] 
selinux: mac_selinux_access_check_varlink_internal()

3 months agoselinux: check_access()
Ivan Kruglov [Thu, 10 Jul 2025 13:55:18 +0000 (06:55 -0700)] 
selinux: check_access()

3 months agocore: leave a comment about context/runtime split 38135/head
Ivan Kruglov [Wed, 9 Jul 2025 13:15:04 +0000 (06:15 -0700)] 
core: leave a comment about context/runtime split

3 months agocore: move ControlGroup move runtime to context
Ivan Kruglov [Thu, 10 Jul 2025 14:36:13 +0000 (07:36 -0700)] 
core: move ControlGroup move runtime to context

3 months agocore: move ConfirmSpawn from runtime to context
Ivan Kruglov [Thu, 10 Jul 2025 14:33:20 +0000 (07:33 -0700)] 
core: move ConfirmSpawn from runtime to context

3 months agocore: move ShowStatus/Log* from runtime to context
Ivan Kruglov [Wed, 9 Jul 2025 13:00:04 +0000 (06:00 -0700)] 
core: move ShowStatus/Log* from runtime to context

3 months agocore: move WatchdogDevice from runtime to context
Ivan Kruglov [Wed, 9 Jul 2025 12:59:01 +0000 (05:59 -0700)] 
core: move WatchdogDevice from runtime to context

3 months agocore: move RuntimeWatchdog* + RebootWatchdog + KExecWatchdog from runtime to spec
Ivan Kruglov [Wed, 9 Jul 2025 12:57:55 +0000 (05:57 -0700)] 
core: move RuntimeWatchdog* + RebootWatchdog + KExecWatchdog from runtime to spec

3 months agocore: fix double Environment present in both context and runtime
Ivan Kruglov [Wed, 9 Jul 2025 12:54:07 +0000 (05:54 -0700)] 
core: fix double Environment present in both context and runtime

3 months agocore: move Version/Arch/Features/Taints/UnitPath from context to runtime
Ivan Kruglov [Wed, 9 Jul 2025 12:50:32 +0000 (05:50 -0700)] 
core: move Version/Arch/Features/Taints/UnitPath from context to runtime

3 months agoselinux: get_our_contexts()
Ivan Kruglov [Thu, 3 Jul 2025 13:40:14 +0000 (06:40 -0700)] 
selinux: get_our_contexts()

3 months agoselinux: rename mac_selinux_access_check_internal() -> mac_selinux_access_check_bus_i...
Ivan Kruglov [Thu, 3 Jul 2025 11:30:59 +0000 (04:30 -0700)] 
selinux: rename mac_selinux_access_check_internal() -> mac_selinux_access_check_bus_internal()

3 months agoselinux-utils: rename and expose log_selinux_enforcing_errno()
Ivan Kruglov [Thu, 10 Jul 2025 13:47:29 +0000 (06:47 -0700)] 
selinux-utils: rename and expose log_selinux_enforcing_errno()

3 months agoselinux-util: mac_selinux_get_peer_label()
Ivan Kruglov [Thu, 3 Jul 2025 11:53:23 +0000 (04:53 -0700)] 
selinux-util: mac_selinux_get_peer_label()

3 months agoruff: Default to python 3.7 version
DaanDeMeyer [Thu, 10 Jul 2025 12:47:03 +0000 (14:47 +0200)] 
ruff: Default to python 3.7 version

For some use cases we still want python 3.7 compat so let's default
to that and only target python 3.9 in a few specific cases.

3 months agoAdd --entry-type=type1|type2 option to kernel-install.
Li Tian [Tue, 8 Jul 2025 06:44:35 +0000 (14:44 +0800)] 
Add --entry-type=type1|type2 option to kernel-install.

Both kernel-core and kernel-uki-virt call kernel-install upon removal. Need an additional argument to avoid complete removal for both traditional kernel and UKI.

Signed-off-by: Li Tian <litian@redhat.com>
3 months agotree-wide: Use "mkosi box" instead of "mkosi sandbox" 38156/head
DaanDeMeyer [Thu, 10 Jul 2025 14:23:26 +0000 (16:23 +0200)] 
tree-wide: Use "mkosi box" instead of "mkosi sandbox"

The box verb was added as a synonym for sandbox. sandbox still works,
but let's switch to box as it's shorter.

3 months agomkosi: Drop unnecessary [Match] sections
DaanDeMeyer [Wed, 9 Jul 2025 08:31:39 +0000 (10:31 +0200)] 
mkosi: Drop unnecessary [Match] sections

These are already satisfied in every path that includes pkgenv.conf.

3 months agomkosi: Simplify centos/fedora configuration
DaanDeMeyer [Wed, 9 Jul 2025 08:22:47 +0000 (10:22 +0200)] 
mkosi: Simplify centos/fedora configuration

Both EPEL 9 and 10 now have the packages we need except for dhcp-server
so let's get rid of the EPEL conditionals and simply skip the tests that
require dhcp-server on CentOS.

While we're at it, make sure we use the new Architecture=uefi match in
mkosi to simplify the uefi checks.

3 months agomkosi: update mkosi commit reference to 184472f0f1f831ca29953546ec01fd941ff763a6
DaanDeMeyer [Thu, 10 Jul 2025 14:21:14 +0000 (16:21 +0200)] 
mkosi: update mkosi commit reference to 184472f0f1f831ca29953546ec01fd941ff763a6

184472f0f1 mkosi-tools: make sure p11-kit dir exists when configuring module
9fb807884e mkosi-tools: Explicitly install p11-kit
9131877d60 Support matching against architectures with uefi support
f1eab5a783 Rename sandbox verb to box
d609f55d98 Fix /var/tmp directory cleanup
4997b9495c build(deps): bump github/codeql-action from 3.28.18 to 3.29.2

3 months agosocket-activate: Always send NOTIFY=ready
DaanDeMeyer [Thu, 3 Jul 2025 08:41:50 +0000 (10:41 +0200)] 
socket-activate: Always send NOTIFY=ready

Even if we're not using --accept=, it's very useful to be able to
synchronize on systemd-socket-activate having binded to its listen
socket, so let's always send READY=1. This means the payload can't
send READY=1 anymore but it's doubtful whether that's useful in this
case in the first place.

3 months agoTwo trivial nspawn fixes (#38152)
Daan De Meyer [Thu, 10 Jul 2025 14:19:18 +0000 (16:19 +0200)] 
Two trivial nspawn fixes (#38152)

3 months agovmspawn: Use virtio-blk-pci for image instead of virtio-scsi-pci
DaanDeMeyer [Thu, 3 Jul 2025 12:50:05 +0000 (14:50 +0200)] 
vmspawn: Use virtio-blk-pci for image instead of virtio-scsi-pci

We don't need a full blown SCSI controller just to present the main
root drive device to the VM. Let's simplify the storage stack by using
virtio-blk-pci instead.

Additionally, virtio-blk-pci is a builtin module in Arch and Fedora
which means we can do qemu direct kernel boot without needing an initrd.

3 months agoescape: Make quote_command_line() argument const
DaanDeMeyer [Thu, 3 Jul 2025 08:47:15 +0000 (10:47 +0200)] 
escape: Make quote_command_line() argument const

3 months agovmspawn: Disable hpet for vmspawn x86 virtual machines
DaanDeMeyer [Thu, 3 Jul 2025 08:37:25 +0000 (10:37 +0200)] 
vmspawn: Disable hpet for vmspawn x86 virtual machines

hpet is an emulated clocksource that is generally discouraged in favor
of kvm-clock or tsc for virtual machines. While vmspawn's virtual machines
already use kvm-clock, leaving hpet enabled causes qemu on the host to
consume a non-trivial amount of cpu, so let's disable the hpet feature since
we're not making use of it anyway.

3 months agoRevert "resolve: query the parent zone for DS records"
Yu Watanabe [Wed, 16 Apr 2025 21:53:02 +0000 (06:53 +0900)] 
Revert "resolve: query the parent zone for DS records"

This reverts commit 49ff90c70debc59f5a52e5cec5a92507d9868b9d.

3 months agonspawn: Use in_child_chown() in one more place 38152/head
DaanDeMeyer [Fri, 4 Jul 2025 19:21:35 +0000 (21:21 +0200)] 
nspawn: Use in_child_chown() in one more place

3 months agonspawn: Improve log message
DaanDeMeyer [Fri, 4 Jul 2025 19:21:25 +0000 (21:21 +0200)] 
nspawn: Improve log message

3 months agozsh-completion: generate completion for systemd-run from systemd-analyze
Eisuke Kawashima [Wed, 28 May 2025 10:25:17 +0000 (19:25 +0900)] 
zsh-completion: generate completion for systemd-run from systemd-analyze

continuation of #37641

3 months agonews: fix typo
Jörg Behrmann [Thu, 10 Jul 2025 07:52:42 +0000 (09:52 +0200)] 
news: fix typo

3 months agoman: clean up list of literals
Christian Hesse [Wed, 9 Jul 2025 10:26:39 +0000 (12:26 +0200)] 
man: clean up list of literals

3 months agoci: also set TEST_RUNNER environment variable in coverage test
Yu Watanabe [Wed, 9 Jul 2025 06:36:05 +0000 (15:36 +0900)] 
ci: also set TEST_RUNNER environment variable in coverage test

Otherwise, integration-test-wrapper.py will fail.
```
Traceback (most recent call last):
  File "/home/runner/work/systemd/systemd/test/integration-tests/integration-test-wrapper.py", line 693, in <module>
    main()
    ~~~~^^
  File "/home/runner/work/systemd/systemd/test/integration-tests/integration-test-wrapper.py", line 677, in main
    runner = os.environ['TEST_RUNNER']
             ~~~~~~~~~~^^^^^^^^^^^^^^^
  File "<frozen os>", line 717, in __getitem__
KeyError: 'TEST_RUNNER'
```

Follow-up for c0a5801f7b034f3473c10f627d54671e1588963b.

3 months agoshutdown: voidify disable_binfmt() 38117/head
Yu Watanabe [Tue, 8 Jul 2025 09:58:14 +0000 (18:58 +0900)] 
shutdown: voidify disable_binfmt()