]> git.ipfire.org Git - thirdparty/systemd.git/log
thirdparty/systemd.git
2 days agosd-bus/bus-message: more prudently verify it's SCM_RIGHTS that got truncated 40488/head
Mike Yuan [Tue, 27 Jan 2026 18:10:41 +0000 (19:10 +0100)] 
sd-bus/bus-message: more prudently verify it's SCM_RIGHTS that got truncated

Follow-up for 6c8de404c98fb9b965cba68360c2db1e3f55b776

As discussed in
https://github.com/systemd/systemd/pull/40089#issuecomment-3672063388,
if any other control msg got truncated it's a genuine error, and
we should reject the message as a whole.

2 days agosd-bus/bus-socket: reinstate MSG_TRUNC handling in bus_socket_read_message()
Mike Yuan [Wed, 28 Jan 2026 02:01:06 +0000 (03:01 +0100)] 
sd-bus/bus-socket: reinstate MSG_TRUNC handling in bus_socket_read_message()

We switched away from recvmsg_safe() in order to gracefully
handle MSG_CTRUNC. But MSG_TRUNC really shouldn't happen.

While at it, do not use RET_NERRNO with ssize_t.

2 days agosd-bus/bus-socket: restore recvmsg_safe() during auth
Mike Yuan [Tue, 27 Jan 2026 18:01:18 +0000 (19:01 +0100)] 
sd-bus/bus-socket: restore recvmsg_safe() during auth

At auth stage we reject any fds, hence either way the connection
would fail. Let's play it safe and check for MSG_(C)TRUNC still.

2 days agoBump required minimum version of glibc to 2.34
Yu Watanabe [Fri, 2 Jan 2026 23:23:16 +0000 (08:23 +0900)] 
Bump required minimum version of glibc to 2.34

Major distributions already have glibc >= 2.34.
Let's bump the required minimum version.

Note, glibc-2.34 was released on 2021-08-01.

2 days agostoragetm: ensure device lock fd is opened for writing
Mike Yuan [Sun, 25 Jan 2026 15:50:34 +0000 (16:50 +0100)] 
storagetm: ensure device lock fd is opened for writing

Follow-up for e582484789a6d889d11b97d9c2afa74c3c985130

_cleanup_close_ is dropped, as the fd would be immediately
consumed by the nvme_subsystem_add() call below anyways.

2 days agoreread-partition-table: fix typo
Mike Yuan [Sun, 25 Jan 2026 15:50:00 +0000 (16:50 +0100)] 
reread-partition-table: fix typo

2 days agokernel-install: handle removal unsuccessful UKIs and loader entries separately
Jörg Behrmann [Fri, 23 Jan 2026 12:55:51 +0000 (13:55 +0100)] 
kernel-install: handle removal unsuccessful UKIs and loader entries separately

When a tries file exists, 90-uki-copy.install removes a previous UKI of the
same kernel version and all it's unbooted variants. This removal is guarded
behind a check for the existence of the already booted UKI, i.e. if uki.efi
already exists, uki.efi and uki+*.efi will be removed.

This leaves the edge case that if uki.efi does not exist, but only an unbooted,
e.g. uki+3.efi, it will not be removed. This is not a problem, if the number of
tries is constant between both builds, since a new uki+3.efi would overwrite
the existing one, but if the number of tries is changed to, e.g. uki+5.efi, we
are left with both uki+3.efi and uki+5.efi.

The same is done for loader entries.

2 days agopreparations for installer PR (#40446)
Zbigniew Jędrzejewski-Szmek [Tue, 27 Jan 2026 14:04:47 +0000 (15:04 +0100)] 
preparations for installer PR (#40446)

As suggested by @keszybz the generic preparatory work split out of
#38764

2 days agoman/custom-html: support dark mode
Daniel Foster [Sun, 25 Jan 2026 05:14:11 +0000 (15:14 +1000)] 
man/custom-html: support dark mode

Use the browser's default style and opt in for dark mode.

Has the bonus of removing some
[deprecated attributes](https://developer.mozilla.org/docs/Web/HTML/Reference/Elements/body#deprecated_attributes).

2 days agoNEWS: Remember to mention new option SYSTEMD_COLORS=auto-24bit
Peter Oliver [Sat, 24 Jan 2026 11:56:44 +0000 (11:56 +0000)] 
NEWS: Remember to mention new option SYSTEMD_COLORS=auto-24bit

2 days agosd-bus: allow receiving messages with MSG_CTRUNC set (#40089)
Zbigniew Jędrzejewski-Szmek [Tue, 27 Jan 2026 11:07:33 +0000 (12:07 +0100)] 
sd-bus: allow receiving messages with MSG_CTRUNC set (#40089)

In the event that we can't receive all of the fds from the message
(which can happen for a number of reasons including LSM denials or
hitting the fd limit of the process) the kernel will set the MSG_CTRUNC
flag.  Through our use of recvmsg_safe() we've been treating this as a
fatal error, which will result in dropping the connection.

Let's dial that back a bit: we can receive the message, but when the
user attempts to access the missing fds via sd_bus_message_read_basic()
we can return the (existing) error code of -EBADMSG to indicate that the
fd is missing.

We can do this by using recvmsg() directly, and relaxing some of the
checks on message creation: when (and only when) we have received
MSG_CTRUNC we allow a smaller than expected (per the header) number of
fds to be present.  The error check in sd_bus_message_read_basic() was
already there so we don't need to do anything about that.

This puts the receiver of the message into a difficult situation: you
can call sd_bus_message_read_basic() as often as you want but as long as
it keeps returning -EBADMSG it won't progress through the message and
you won't be able to close whatever container you're in.  That means
that the user will probably need to abandon processing the message
anyway.  So why not just drop the message up front?  This approach is
more likely to yield a useful error message, which will be invaluable
for people trying to track down problems caused by LSM denials.

Fixes #34688

2 days agovmspawn: keep stderr fd connected when running ssh-keygen
Michael Vogt [Mon, 26 Jan 2026 18:25:50 +0000 (19:25 +0100)] 
vmspawn: keep stderr fd connected when running ssh-keygen

When vmspawn executes ssh-keygen it currently hides all std{out,err}.
This is not ideal when errors happen, so this commit tweaks the
code to include stderr in the output.

My use case is that I recently ran into the issue that inside a
`mkosi box` my systemd-homed user was not available so ssh-keygen
errored with `No user exists for uid 1000` [0] but that error was
not visible, only the generic:
`'/usr/bin/ssh-keygen' failed with exit status 255.`
was displayed.

This also adds FORK_REOPEN_LOG to the pidref_safe_fork flags,
thanks to Mike Yuan for the suggestion.

[0] Arguably this is also an issue in ssh-keygen because it does
not need to do the user lookup when `-f /path/` is passed.

3 days agohwdb: Add extended SteelSeries Arctis headset device support (#40479)
Sriman Achanta [Tue, 27 Jan 2026 06:11:35 +0000 (01:11 -0500)] 
hwdb: Add extended SteelSeries Arctis headset device support (#40479)

Add USB device IDs for additional SteelSeries Arctis headset models to
the sound card hardware database. This extends support for the complete
Arctis lineup including newer models.

Newly added device IDs:
- Arctis 7 P (0x12d5)
- Arctis Pro (0x1290)
- Arctis Nova 3 (0x12ec)
- Arctis Nova 3 P (0x2269)
- Arctis Nova 3 X (0x226d)
- Arctis Nova 5 (0x2232)
- Arctis Nova 5 X (0x2253)
- Arctis Nova 7 Rev2 (0x2258)
- Arctis Nova 7 Diablo (0x223a)
- Arctis Nova 7 WoW (0x227a)
- Arctis Nova 7 2 (0x22a1)
- Arctis Nova 7 Gen2 (0x227e)
- Arctis Nova 7 X Gen2 (0x229e)
- Arctis Nova Pro (0x12e0)
- Arctis Nova Pro X (0x12e5)

Also reordered existing entries for better organization.

Note, steelseries [firmware release
103.0.0](https://techblog.steelseries.com/2026/01/21/GG-notes-103.0.0.html)
was a major update for all Nova 7 (Gen 1) Family headsets with new PIDs
being issued for the devices. I only own the Nova 7 which is the only
(previously unknown) PID being added. Additional PIDs will need to be
added for those new identifiers (if any), but this should be basically
every Steelseries Headset which the kernel supports/will eventually
support.

3 days agosd-bus: add test cases for truncated fds 40089/head
Allison Karlitskaya [Mon, 15 Dec 2025 09:35:56 +0000 (10:35 +0100)] 
sd-bus: add test cases for truncated fds

We add some test cases for the previous commits: first (with Claude's
help) we exercise the message creation API internally by passing it
various combinations of incorrect fds with the might_be_truncated flag
set to true or false.

Then we try more of a "real world" test by lowering our fd limit and
sending ourselves a message via the bus and making sure that we
successfully receive a message that has had at least some of its fds
truncated.

3 days agosd-bus: allow receiving messages with MSG_CTRUNC set
Allison Karlitskaya [Mon, 15 Dec 2025 09:27:04 +0000 (10:27 +0100)] 
sd-bus: allow receiving messages with MSG_CTRUNC set

In the event that we can't receive all of the fds from the message
(which can happen for a number of reasons including LSM denials or
hitting the fd limit of the process) the kernel will set the MSG_CTRUNC
flag.  Through our use of recvmsg_safe() we've been treating this as a
fatal error, which will result in dropping the connection.

Let's dial that back a bit: we can receive the message, but when the
user attempts to access the missing fds via sd_bus_message_read_basic()
we can return the (existing) error code of -EBADMSG to indicate that the
fd is missing.

We can do this by using recvmsg() directly, and relaxing some of the
checks on message creation: when (and only when) we have received
MSG_CTRUNC we allow a smaller than expected (per the header) number of
fds to be present.  The error check in sd_bus_message_read_basic() was
already there so we don't need to do anything about that.

This puts the receiver of the message into a difficult situation: you
can call sd_bus_message_read_basic() as often as you want but as long as
it keeps returning -EBADMSG it won't progress through the message and
you won't be able to close whatever container you're in.  That means
that the user will probably need to abandon processing the message
anyway.  So why not just drop the message up front?  This approach is
more likely to yield a useful error message, which will be invaluable
for people trying to track down problems caused by LSM denials.

Fixes #34688

3 days agotest: perform /usr/share/ sysext unmount lazily
Lennart Poettering [Sun, 25 Jan 2026 19:49:14 +0000 (20:49 +0100)] 
test: perform /usr/share/ sysext unmount lazily

/usr/share/ is a directory commonly accessed by various tools, hence we
really should make sure we umount it lazily (MNT_DETACH), since
otherwise there's a good chance that the umount might simply fail.

I noticed this there:

https://github.com/systemd/systemd/actions/runs/21321690161/job/61372465563?pr=40446

4 days agoexec-invoke: minor tweaks (#40450)
Mike Yuan [Sun, 25 Jan 2026 21:11:32 +0000 (22:11 +0100)] 
exec-invoke: minor tweaks (#40450)

4 days agoconf-files: add flag so that we don't always prefix returned paths with the root... 40446/head
Lennart Poettering [Mon, 15 Sep 2025 13:12:40 +0000 (15:12 +0200)] 
conf-files: add flag so that we don't always prefix returned paths with the root dir path used

This is useful in tools such as system-repart where we show the
definition file paths a lot in our output, but if prefixed with the root
path we'd show a temporary mount dir when operating on a image file.
Hence, let's drop the prefix here, and show only the path within the
image.

4 days agoconf-files: rename .name field to .filename to make clearer what precisely it is...
Lennart Poettering [Mon, 15 Sep 2025 12:45:08 +0000 (14:45 +0200)] 
conf-files: rename .name field to .filename to make clearer what precisely it is the name of

4 days agoboot-entry: plug through XAT_FDROOT
Lennart Poettering [Wed, 3 Sep 2025 08:39:49 +0000 (10:39 +0200)] 
boot-entry: plug through XAT_FDROOT

4 days agoos-util: support XAT_FDROOT everywhere
Lennart Poettering [Fri, 23 Jan 2026 10:24:07 +0000 (11:24 +0100)] 
os-util: support XAT_FDROOT everywhere

4 days agoconf-files: add support for root_fd based operation
Lennart Poettering [Fri, 5 Sep 2025 12:21:53 +0000 (14:21 +0200)] 
conf-files: add support for root_fd based operation

Let's make sure we can safely load configuration files based on a root
fd, including XAT_FDROOT.

(While we are at it, always pass path to root fs before fd to root fs,
following our recently updated CODING_STYLE)

4 days agosd-id128-util: allow XAT_FDROOT pass through in id128_get_machine_at()
Lennart Poettering [Tue, 20 Jan 2026 21:34:07 +0000 (22:34 +0100)] 
sd-id128-util: allow XAT_FDROOT pass through in id128_get_machine_at()

4 days agoexec-invoke: remove one level of indentation 40450/head
Lennart Poettering [Thu, 27 Nov 2025 08:43:10 +0000 (09:43 +0100)] 
exec-invoke: remove one level of indentation

4 days agoexec-invoke: handle PRIVATE_USERS_SELF cases together
Lennart Poettering [Thu, 27 Nov 2025 07:59:17 +0000 (08:59 +0100)] 
exec-invoke: handle PRIVATE_USERS_SELF cases together

And moving things to a switch/case sttement.

5 days agosd-event: unpoison memory returned by epoll_pwait2() (#40464)
Mike Yuan [Sat, 24 Jan 2026 23:50:18 +0000 (00:50 +0100)] 
sd-event: unpoison memory returned by epoll_pwait2() (#40464)

Fixes #40455

Alternative to #40463
Closes #40463

5 days agoCODING_STYLE: suggest a clear order for func params that combine fd and path
Lennart Poettering [Tue, 20 Jan 2026 15:56:20 +0000 (16:56 +0100)] 
CODING_STYLE: suggest a clear order for func params that combine fd and path

5 days agoloop-util: when open_flags is unspecified derive it from passed in fd
Lennart Poettering [Wed, 21 Jan 2026 21:29:22 +0000 (22:29 +0100)] 
loop-util: when open_flags is unspecified derive it from passed in fd

5 days agosd-event: use FOREACH_ARRAY 40464/head
Mike Yuan [Sat, 24 Jan 2026 17:51:21 +0000 (18:51 +0100)] 
sd-event: use FOREACH_ARRAY

5 days agosd-event: unpoison memory returned by epoll_pwait2()
Mike Yuan [Sat, 24 Jan 2026 17:33:05 +0000 (18:33 +0100)] 
sd-event: unpoison memory returned by epoll_pwait2()

Our fuzzer CI recently got bumped to Ubuntu 24.04 with
glibc >= 2.35. Apparently msan is not happy with the new
epoll_pwait2(), hence explicitly mark the memory region
as initialized.

Fixes #40455
Alternative to #40463

5 days agoREADME: add epoll_pwait2() to the list of kernel APIs
Mike Yuan [Sat, 24 Jan 2026 17:28:24 +0000 (18:28 +0100)] 
README: add epoll_pwait2() to the list of kernel APIs

5 days agounits/meson.build: rebreak lines
Mike Yuan [Sat, 24 Jan 2026 17:07:15 +0000 (18:07 +0100)] 
units/meson.build: rebreak lines

5 days agomkosi: fix debian/ubuntu/suse builds
Luca Boccassi [Sat, 24 Jan 2026 15:12:09 +0000 (16:12 +0100)] 
mkosi: fix debian/ubuntu/suse builds

Follow-up for 072e72424b2e6da1c96489ef6996f49fabd46474

5 days agomkosi: workaround autovt removal in SUSE spec 40460/head
Luca Boccassi [Sat, 24 Jan 2026 13:24:53 +0000 (13:24 +0000)] 
mkosi: workaround autovt removal in SUSE spec

Follow-up for 072e72424b2e6da1c96489ef6996f49fabd46474

5 days agomkosi: update debian commit reference to 6f4d90be5cb4075954f0a36653105e586a9a1fa9
Luca Boccassi [Sat, 24 Jan 2026 13:19:28 +0000 (13:19 +0000)] 
mkosi: update debian commit reference to 6f4d90be5cb4075954f0a36653105e586a9a1fa9

6f4d90be5c Do not install autovt@ for upstream builds
8cc28a6b82 Install new files for upstream build
0d15255073 Use deb-systemd-invoke to reexec instead of manual calls
db04e5fa0b Use dh_installsystemd to handle journald and networkd
d8756a4c82 Use dh_installsystemd more to manage units
40b23b0d5d d/tests: drop tests-in-lxd
5821c5a350 d/control: have systemd-boot depend on efibootmgr for amd64 and arm64 only

Follow-up for 072e72424b2e6da1c96489ef6996f49fabd46474

5 days agounits/getty@.service: use [Install]Alias= instead of static alias
Zbigniew Jędrzejewski-Szmek [Fri, 23 Jan 2026 13:18:14 +0000 (14:18 +0100)] 
units/getty@.service: use [Install]Alias= instead of static alias

In Fedora, kmsconvt@.service is starting to be used instead of getty@.service
to have nicer font handling. This means that we need the autovt@.service alias
point to the new unit. So far the alias was done through a static symlink
because there was little reason to change it. Let's use [Install] instead so
the decision which implementation to use can be made after installation.

https://bugzilla.redhat.com/show_bug.cgi?id=2429626
https://fedoraproject.org/wiki/Changes/UseKmsconVTConsole

5 days agotivial journal fixlets (#40448)
Lennart Poettering [Sat, 24 Jan 2026 12:18:31 +0000 (13:18 +0100)] 
tivial journal fixlets (#40448)

5 days agomountfsd: improve logging
Lennart Poettering [Fri, 28 Nov 2025 15:22:21 +0000 (16:22 +0100)] 
mountfsd: improve logging

5 days agorun: remove unused enum values for getopt_long()
Mike Yuan [Sat, 24 Jan 2026 00:11:16 +0000 (01:11 +0100)] 
run: remove unused enum values for getopt_long()

6 days agocore/exec-invoke: switch PRIVATE_USERS_FULL to direct "0 0 UINT32_MAX" mapping (...
Mike Yuan [Fri, 23 Jan 2026 23:04:30 +0000 (00:04 +0100)] 
core/exec-invoke: switch PRIVATE_USERS_FULL to direct "0 0 UINT32_MAX" mapping (#40445)

6 days agojournal: do not use typecasts for range checks 40448/head
Lennart Poettering [Wed, 21 Jan 2026 22:48:29 +0000 (23:48 +0100)] 
journal: do not use typecasts for range checks

6 days agojournal: some whitespace fixes
Lennart Poettering [Wed, 21 Jan 2026 22:48:14 +0000 (23:48 +0100)] 
journal: some whitespace fixes

6 days agoupdate TODO
Lennart Poettering [Fri, 23 Jan 2026 21:19:18 +0000 (22:19 +0100)] 
update TODO

6 days agocore/exec-invoke: switch PRIVATE_USERS_FULL to direct "0 0 UINT32_MAX" mapping 40445/head
Mike Yuan [Fri, 23 Jan 2026 17:51:28 +0000 (18:51 +0100)] 
core/exec-invoke: switch PRIVATE_USERS_FULL to direct "0 0 UINT32_MAX" mapping

This was intended for v259. Let's get it done now, in v260.

6 days agocore/exec-invoke: group setup_private_users*() together
Mike Yuan [Fri, 28 Nov 2025 18:44:17 +0000 (19:44 +0100)] 
core/exec-invoke: group setup_private_users*() together

6 days agopam_systemd: remove handling of obsolete "existing" attr from CreateSession() call...
Mike Yuan [Fri, 23 Jan 2026 16:50:44 +0000 (17:50 +0100)] 
pam_systemd: remove handling of obsolete "existing" attr from CreateSession() call (#40432)

6 days agohwdb: Update Lenovo Legion Go Models
Derek J. Clark [Thu, 22 Jan 2026 20:52:03 +0000 (12:52 -0800)] 
hwdb: Update Lenovo Legion Go Models
- Different BIOS versions of the Legion Go 2 can init the keyboard
  device as set 1 (appears as raw set 2) or as set 2 (appears as
  translated set 2). Add the Legion Go 2 to the Translated list.
- While at it, specify the models in a more verbose manner for
  posterity.

Signed-off-by: Derek J. Clark <derekjohn.clark@gmail.com>
6 days agoansi-color: new option SYSTEMD_COLORS=auto-16/auto-256/auto-24bit (#40303)
Peter Oliver [Fri, 23 Jan 2026 12:54:31 +0000 (12:54 +0000)] 
ansi-color: new option SYSTEMD_COLORS=auto-16/auto-256/auto-24bit (#40303)

Setting SYSTEMD_COLORS=auto-16 is like SYSTEMD_COLORS=16 if output is to
a non-dumb TTY, and like SYSTEMD_COLORS=no otherwise.

Relates to
https://github.com/systemd/systemd/issues/15498#issuecomment-1682025186

6 days agohostnamed: after unescaping fancy name, validate it's valid UTF-8
Lennart Poettering [Thu, 22 Jan 2026 21:50:43 +0000 (22:50 +0100)] 
hostnamed: after unescaping fancy name, validate it's valid UTF-8

The fancy name could contain arbitrary bytes, in escaped fashion. Before
using it, let's validate that this contains only valid UTF-8.

(Note that D-Bus might kick us off the bus if we don't ensure everything
we send around is UTF-8).

(While we are at it, do the same in PID 1, even though it's not that
important there)

Addresses this issue found by @YHNdnzj:

https://github.com/systemd/systemd/pull/40367#discussion_r2714614301

Follow-up for: #40367

6 days agoman/fstab-generator: correct root= options
Antonio Alvarez Feijoo [Fri, 23 Jan 2026 11:19:41 +0000 (12:19 +0100)] 
man/fstab-generator: correct root= options

Remove duplicate "fstab" option, and add missing "tmpfs" and "bind:" options.

7 days agopam_systemd: remove handling of obsolete "existing" attr from CreateSession() call 40432/head
Mike Yuan [Thu, 22 Jan 2026 19:41:24 +0000 (20:41 +0100)] 
pam_systemd: remove handling of obsolete "existing" attr from CreateSession() call

Follow-up for b80120c4cba7d134b5437a58437a23fdf7ab2084

After the mentioned commit, logind returns an error if the process
already lives in a session, and register_session() short-circuits
without setting systemd.existing flag. Hence systemd.existing
is either false or unset for pam_sm_close_session(), making
the whole logic effectively NOP. Kill it with fire.

7 days agohostnamed: use INDEXES_TO_MASK where appropriate
Mike Yuan [Thu, 22 Jan 2026 18:25:53 +0000 (19:25 +0100)] 
hostnamed: use INDEXES_TO_MASK where appropriate

Addresses https://github.com/systemd/systemd/pull/40367#discussion_r2714368627

7 days agopam_systemd: fix regression introduced in v258 by preserving the FIFO fd
Franck Bui [Mon, 19 Jan 2026 17:24:12 +0000 (18:24 +0100)] 
pam_systemd: fix regression introduced in v258 by preserving the FIFO fd

Upstream commit 3180c4d introduced a version incompatibility between
pam_systemd.so v258 and logind v257. This is problematic because such version
mismatches can occur in practice: logind still cannot be restarted during a
systemd package upgrade (it's a long-standing limitation, see
https://github.com/systemd/systemd/issues/17308).

When pam_systemd requests a new session, logind v257 returns a FIFO
fd. pam_systemd.so v258 ignores this fd and closes it. logind interprets the
closure as the session leader exiting and immediately terminates the session.

This patch partially reverts commit 3180c4d and restores the handling of the
FIFO fd in pam_systemd. The change is limited to the D-Bus APIs, since the
varlink API was only introduced in logind v258.

Follow-up for 3180c4d46151673a9c985e60f205d4c76a81573f.

8 days agomeson: Drop minimum meson version required for clang-tidy
Daan De Meyer [Wed, 21 Jan 2026 14:54:58 +0000 (15:54 +0100)] 
meson: Drop minimum meson version required for clang-tidy

8 days agoos-release: add a new FANCY_NAME= field to /etc/os-release, similar to PRETTY_NAME...
Lennart Poettering [Wed, 21 Jan 2026 22:57:39 +0000 (23:57 +0100)] 
os-release: add a new FANCY_NAME= field to /etc/os-release, similar to PRETTY_NAME, that may carry ansi sequences + more unicode chars (#40367)

It's sometimes useful include non-ascii unicode chars in an os name, and
give it some ansi coloring. Since we usualy don't want to show that,
introduce a new field for it, and show it at boot and in thostnamectl
only, with safe fallbacks if colors/emojis are not available.

8 days agounits/systemd-portabled: enable NoNewPrivileges=
Mike Yuan [Wed, 21 Jan 2026 19:26:31 +0000 (20:26 +0100)] 
units/systemd-portabled: enable NoNewPrivileges=

As with all other daemons we ship.

8 days agomountfsd: Make singleFileSystem non-nullable
Daan De Meyer [Wed, 21 Jan 2026 18:39:33 +0000 (19:39 +0100)] 
mountfsd: Make singleFileSystem non-nullable

It's always set, so no need to be nullable.

8 days agohostnamectl: show fancy name if available 40367/head
Lennart Poettering [Wed, 14 Jan 2026 17:23:03 +0000 (18:23 +0100)] 
hostnamectl: show fancy name if available

8 days agohostnamed: expose fancy OS name as a field
Lennart Poettering [Mon, 12 Jan 2026 12:46:47 +0000 (13:46 +0100)] 
hostnamed: expose fancy OS name as a field

8 days agopid1: show fancy name field at boot, if specified
Lennart Poettering [Mon, 12 Jan 2026 12:44:54 +0000 (13:44 +0100)] 
pid1: show fancy name field at boot, if specified

8 days agoman: introduce FANCY_NAME field
Lennart Poettering [Mon, 12 Jan 2026 12:40:27 +0000 (13:40 +0100)] 
man: introduce FANCY_NAME field

8 days agoformat-table: add new string cell type that accepts ANSI sequences
Lennart Poettering [Thu, 15 Jan 2026 07:51:05 +0000 (08:51 +0100)] 
format-table: add new string cell type that accepts ANSI sequences

For various usecases it's useful that we can embed ANSI sequences in
cells of tables. For example, I hope we can eventually switch "systemctl
status" output to use the table formatter, and multiple of its fields
contain ANSI sequences (since they pack multiple different pieces
information into the same field, and highlight parts of it to
communicate relevance of distinct parts).

Add a distinct cell type for this, which gets special processing when we
output to a terminal that doesn't support ANSI sequences, and to JSON:
we strip the sequences.

8 days agoTrivial follow-ups for recently merged PRs (#40417)
Mike Yuan [Wed, 21 Jan 2026 18:54:32 +0000 (19:54 +0100)] 
Trivial follow-ups for recently merged PRs (#40417)

8 days agoportable: Enable unpriv operation (#40091)
Daan De Meyer [Wed, 21 Jan 2026 15:46:53 +0000 (16:46 +0100)] 
portable: Enable unpriv operation (#40091)

This does not yet support directory images properly
as systemd itself does not support unpriv directory
images properly yet.

8 days agofdset: do not call fd_get_path() if debug logging is off 40417/head
Mike Yuan [Wed, 21 Jan 2026 14:39:22 +0000 (15:39 +0100)] 
fdset: do not call fd_get_path() if debug logging is off

Follow-up for 89065ada83af55ed9e2350c2df7e315e2e6ad043

8 days agonetwork/dhcp4: send release message before stopping the client
Yu Watanabe [Tue, 20 Jan 2026 09:04:33 +0000 (18:04 +0900)] 
network/dhcp4: send release message before stopping the client

Otherwise, the socket is already closed and sending release will be
anyway skipped.

With this patch, release message is sent before stopping the client.
```
Jan 20 18:29:41 systemd[1]: Stopping systemd-networkd.service - Network Management...
Jan 20 18:29:41 systemd-networkd[3821255]: wlp59s0: DHCPv4 client: RELEASE
Jan 20 18:29:41 systemd-networkd[3821255]: wlp59s0: DHCPv4 client: STOPPED
Jan 20 18:29:41 systemd-networkd[3821255]: wlp59s0: DHCP lease lost
```

Fixes #39299.

8 days agofdset: sort includes
Mike Yuan [Wed, 21 Jan 2026 14:49:47 +0000 (15:49 +0100)] 
fdset: sort includes

8 days agosysupdate-resource: on hash mismatch the best before marker is not ignored
Mike Yuan [Wed, 21 Jan 2026 14:35:39 +0000 (15:35 +0100)] 
sysupdate-resource: on hash mismatch the best before marker is not ignored

Hence use a less ambiguous wording.

Follow-up for d0badc0a619e15c67d38f65730ac210316ece84c
Addresses https://github.com/systemd/systemd/pull/40393#discussion_r2709953179

8 days agoportable: Enable unpriv operation 40091/head
Daan De Meyer [Tue, 2 Dec 2025 10:17:13 +0000 (11:17 +0100)] 
portable: Enable unpriv operation

This does not yet support directory images properly
as systemd itself does not support unpriv directory
images properly yet.

The user profiles are a copy of the system profiles but without
DynamicUser=yes (can't be used by user managers) and without
ProtectHome=yes (this masks /home which breaks StateDirectory= which
is lcoated inside /home)

8 days agopam_systemd_home: Use PAM_TEXT_INFO for token prompts
Vunny Sodhi [Wed, 21 Jan 2026 10:27:55 +0000 (12:27 +0200)] 
pam_systemd_home: Use PAM_TEXT_INFO for token prompts

The prompts asking the user to physically authenticate
or confirm presence on a security token are informational
requests for action, not error conditions.

This commit changes the message type to PAM_TEXT_INFO,
which is more appropriate for guiding the user through
the authentication process.

8 days agoshared/fdset: add detailed debug logging to fdset_new_fill()
AshishKumar Mishra [Wed, 21 Jan 2026 08:43:29 +0000 (14:13 +0530)] 
shared/fdset: add detailed debug logging to fdset_new_fill()

Currently, when fdset_new_fill() fails to open /proc/self/fd or
encounters an error while processing individual file descriptors
(such as fcntl or fstat failures), it returns a silent error code.

For debugging rarely reproducible failures it becomes difficult to
know the exact cause of failure
This commit updates the function to use log_debug_errno() for all
error paths and hence  provides better visibility into why FD collection
failed, including the path of the problematic FD (via fd_get_path)
and its inode type.

8 days agoportable: Split out receive_portable_metadata()
Daan De Meyer [Tue, 2 Dec 2025 08:29:26 +0000 (09:29 +0100)] 
portable: Split out receive_portable_metadata()

8 days agoportable: Make extract_now() operate on a dirfd
Daan De Meyer [Mon, 1 Dec 2025 22:52:29 +0000 (23:52 +0100)] 
portable: Make extract_now() operate on a dirfd

Preparation for making portabled support unpriv
operation.

8 days agoportable: Use report_errno_and_exit()
Daan De Meyer [Tue, 2 Dec 2025 08:39:13 +0000 (09:39 +0100)] 
portable: Use report_errno_and_exit()

8 days agomountfsd: Communicate whether the image is a single filesystem
Daan De Meyer [Tue, 20 Jan 2026 21:43:08 +0000 (22:43 +0100)] 
mountfsd: Communicate whether the image is a single filesystem

Various parts of the image dissection logic make use of whether the
thing is a single file system or not, so communicate this info back
from mountfsd.

8 days agomountfsd: Add relaxExtensionReleaseChecks
Daan De Meyer [Tue, 20 Jan 2026 21:41:40 +0000 (22:41 +0100)] 
mountfsd: Add relaxExtensionReleaseChecks

We currently pass this around as a mount option in pid1, which means
privileges are required by mountfsd to mount images that make use of it.
Add an explicit argument for it in varlink instead and remove it client
side from the mount options to remove the need for privileges.

8 days agopath-lookup: Add config_directory_generic()
Daan De Meyer [Tue, 2 Dec 2025 09:28:28 +0000 (10:28 +0100)] 
path-lookup: Add config_directory_generic()

8 days agodissect-image: Add more debug logging
DaanDeMeyer [Tue, 23 Dec 2025 11:44:12 +0000 (12:44 +0100)] 
dissect-image: Add more debug logging

8 days agodissect-image: Make make_image_name() public
DaanDeMeyer [Tue, 23 Dec 2025 11:43:51 +0000 (12:43 +0100)] 
dissect-image: Make make_image_name() public

8 days agodissect-image: Generalize foreign tree logic from import
Daan De Meyer [Mon, 15 Dec 2025 14:08:15 +0000 (15:08 +0100)] 
dissect-image: Generalize foreign tree logic from import

8 days agoloop-util: Make path optional in loop_device_make_by_path_at()
DaanDeMeyer [Mon, 22 Dec 2025 21:13:09 +0000 (22:13 +0100)] 
loop-util: Make path optional in loop_device_make_by_path_at()

8 days agotest: Set SYSTEMD_NSS_LOG_LEVEL=info
DaanDeMeyer [Tue, 23 Dec 2025 21:08:09 +0000 (22:08 +0100)] 
test: Set SYSTEMD_NSS_LOG_LEVEL=info

Currently, our test logs are flooded with useless NSS varlink debug
logs coming from nss-systemd talking to each varlink userdb service
individually. Let's set SYSTEMD_NSS_LOG_LEVEL=info to get rid of these
verbose logs.

8 days agonss-util: Add support for $SYSTEMD_NSS_LOG_LEVEL
DaanDeMeyer [Tue, 23 Dec 2025 21:06:31 +0000 (22:06 +0100)] 
nss-util: Add support for $SYSTEMD_NSS_LOG_LEVEL

When setting SYSTEMD_LOG_LEVEL=debug and debugging a tool that happens
to do NSS lookups, the resulting logs from varlink are obnoxiously
verbose. Let's parse a separate log level environment variable in NSS
to allow overriding the log level for NSS specifically so these noisy
logs can be silenced.

8 days agomkosi: Install libucontext in Arch/Fedora images
Daan De Meyer [Wed, 21 Jan 2026 10:25:36 +0000 (11:25 +0100)] 
mkosi: Install libucontext in Arch/Fedora images

Split out of #39771

We don't use make use of libucontext yet but merging this early makes
sure my mkosi cached images don't get invalidated every time I switch
between my other work and the fiber branch.

9 days agoreread-partition-table: fix typo
Mike Yuan [Wed, 21 Jan 2026 01:15:09 +0000 (02:15 +0100)] 
reread-partition-table: fix typo

9 days agoprompt-util: trivial header cleanups (#40407)
Mike Yuan [Wed, 21 Jan 2026 00:38:19 +0000 (01:38 +0100)] 
prompt-util: trivial header cleanups (#40407)

9 days agomkdir: reset mtime *after* fchown()
Mike Yuan [Tue, 20 Jan 2026 17:54:25 +0000 (18:54 +0100)] 
mkdir: reset mtime *after* fchown()

Follow-up for 34c3d574742e867ef97e79509e4051a82f1b7d9b

Also, drop pointless shortcut.

9 days agoprompt-util: use our own sd-varlink header 40407/head
Mike Yuan [Tue, 20 Jan 2026 23:10:08 +0000 (00:10 +0100)] 
prompt-util: use our own sd-varlink header

9 days agoprompt-util: drop unneeded inclusion of stdbool.h
Mike Yuan [Tue, 20 Jan 2026 23:09:24 +0000 (00:09 +0100)] 
prompt-util: drop unneeded inclusion of stdbool.h

Our -forward headers have it covered.

9 days agosysupdate: add simple "freshness" validation to systemd-sysupdate
Lennart Poettering [Mon, 19 Jan 2026 14:52:26 +0000 (15:52 +0100)] 
sysupdate: add simple "freshness" validation to systemd-sysupdate

In order to make "freeze" attacks against the update logic harder let's
add the ability to encode a "Best Before" date into SHA256SUMS directory
listings: if the current time is already beyond that time, we'll ignore
the SHA256SUMS as "stale" and fail the upgrade. Or in other words: the
freeze attack will now result in a client-side error eventually, instead
of success state.

The best before data is encoded in an optional pseudo-file listed in SHA256SUMS:
any file named BEST-BEFORE-YYYY-MM-DD.

9 days agobootctl,sbsign: fix $SOURCE_DATE_EPOCH parsing (#40404)
Mike Yuan [Tue, 20 Jan 2026 18:13:50 +0000 (19:13 +0100)] 
bootctl,sbsign: fix $SOURCE_DATE_EPOCH parsing (#40404)

A more comprehensive fix for #40403

Closes #40403

9 days agobootctl,sbsign: fix $SOURCE_DATE_EPOCH parsing 40404/head
Mike Yuan [Tue, 20 Jan 2026 14:28:59 +0000 (15:28 +0100)] 
bootctl,sbsign: fix $SOURCE_DATE_EPOCH parsing

This fixes two things:

* $SOURCE_DATE_EPOCH is previously treated as usec, while it's in seconds
* >= 0 is passed to log_debug_errno(), triggering assertion

Replaces #40403

9 days agoinstall-file: add a generalized parser for $SOURCE_DATE_EPOCH
Mike Yuan [Tue, 20 Jan 2026 14:20:57 +0000 (15:20 +0100)] 
install-file: add a generalized parser for $SOURCE_DATE_EPOCH

9 days agostat-util: make proc_mounted() not update errno
Yu Watanabe [Tue, 20 Jan 2026 09:41:11 +0000 (18:41 +0900)] 
stat-util: make proc_mounted() not update errno

Typically, proc_mounted() is used in error handling. Hence, it is better
to make it not update the original errno.

Currently, there are two places that returns wrong error code:
- pidref_get_capability() in src/basic/capability-util.c
```c
        _cleanup_fclose_ FILE *f = fopen(path, "re");
        if (!f) {
                if (errno == ENOENT && proc_mounted() == 0)
                        return -ENOSYS;

                return -errno;
        }
```
- fdset_new_fill() in src/shared/fdset.c
```c
        d = opendir("/proc/self/fd");
        if (!d) {
                if (errno == ENOENT && proc_mounted() == 0)
                        return -ENOSYS;

                return -errno;
        }
```

Rather than fixing them, let's make proc_mounted() not update errno,
otherwise we may make a similar failure in a future.

10 days agocore/dbus-execute: fix memleak on Mount/ExtensionImages parse failure (#40398)
Mike Yuan [Tue, 20 Jan 2026 02:10:34 +0000 (03:10 +0100)] 
core/dbus-execute: fix memleak on Mount/ExtensionImages parse failure (#40398)

10 days agobless-boot-generator: skip if current system is entered via soft-reboot
Mike Yuan [Mon, 19 Jan 2026 23:33:19 +0000 (00:33 +0100)] 
bless-boot-generator: skip if current system is entered via soft-reboot

Fixes #40386

10 days agoresolve: include current DNS server in JSON again (#40396)
Yu Watanabe [Tue, 20 Jan 2026 00:41:51 +0000 (09:41 +0900)] 
resolve: include current DNS server in JSON again (#40396)

Fixes a regression caused by c6b6ac63ea2e63eb86f63b18a25cda872716ac0b.

10 days agocore/dbus-execute: use strextendf_with_separator() where appropriate 40398/head
Mike Yuan [Mon, 19 Jan 2026 22:21:39 +0000 (23:21 +0100)] 
core/dbus-execute: use strextendf_with_separator() where appropriate

10 days agocore/dbus-execute: fix memleak on Mount/ExtensionImages parse failure
Mike Yuan [Mon, 19 Jan 2026 22:18:44 +0000 (23:18 +0100)] 
core/dbus-execute: fix memleak on Mount/ExtensionImages parse failure

Define mount_image_free_many() in our usual fashion for use in
CLEANUP_ARRAY and ensure proper cleanup on error paths.

10 days agotpm2: allow use of recoverable sealing keys
safforddr [Tue, 13 Jan 2026 18:27:20 +0000 (13:27 -0500)] 
tpm2: allow use of recoverable sealing keys

In some use cases it is desirable to use a recoverable (ie duplicatable)
sealing key. Currently objects have the attribute TPMA_OBJECT_FIXEDTPM
and TPMA_OBJECT_FIXEDPARENT hard coded, which will not work with a
recoverable sealing key. This patch sets the object's attributes from
the sealing key's attributes, so that both types of sealing keys will work.