1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-05 09:17:44 +03:00
Commit Graph

58488 Commits

Author SHA1 Message Date
Lennart Poettering
640acfb459 resolved: disable SO_BINDTOIFINDEX hack for localhost IP addresses
Fixes: #23010
(cherry picked from commit 5f9041afec)
(cherry picked from commit a0532ffd2f)
2023-01-27 09:46:47 +00:00
Ludwig Nussel
04d29e1c90 kernel-install: run depmod only if writeable
(cherry picked from commit dd003f1621)
(cherry picked from commit 8ec0142c13)
2023-01-27 09:46:47 +00:00
Lennart Poettering
2ac8824885 resolvectl: remove duplicate ':' from output
The second argument to dump_list() actually ends up in a TABLE_FIELD
cell now, where we implicitly append a ":". Hence drop it from the
strings.

Follow-up for: 37a50123fa

(cherry picked from commit ef503f1cec)
(cherry picked from commit c01cdcfb8a)
2023-01-27 09:46:47 +00:00
Lennart Poettering
51d6ffb854 resolved: downgrade inability to send varlink reply error message
Previously, if a client disconnected after sending a lookup request but
before waiting for the reply we'd log at LOG_ERR level. That's
confusing, since it's entirely OK for the client to lose interest.

Hence, let's downgrade to debug level.

Fixes: #25892
(cherry picked from commit 40557509be)
(cherry picked from commit a3ceaf0f1d)
2023-01-27 09:46:47 +00:00
Cristian Rodríguez
d857665a54 libsystemd-network: FTBS in c2x mode
cannot pass false as argument because function wants a pointer to bool
instead, use NULL instead

(cherry picked from commit 2cc697d740)
(cherry picked from commit e78a1489a8)
2023-01-27 09:46:47 +00:00
Cristian Rodríguez
db147b6d2b basic: Fix incompatible type for arguments errors in C2X
GCC-13 -std=gnu2x FTBS with:

error: incompatible type for argument 3 of ‘_hashmap_free’
(cherry picked from commit a4a1569ff1)
(cherry picked from commit 921bff2f85)
2023-01-27 09:46:47 +00:00
Cristian Rodríguez
9ca9f95122 basic: fix hosed return value in skip_session()
../src/basic/cgroup-util.c: In function ‘skip_session’:
../src/basic/cgroup-util.c:1241:32: error: incompatible types when returning type ‘_Bool’ but ‘const char *’ was expected
 1241 |                         return false;

(cherry picked from commit db8e720984)
(cherry picked from commit ad647734c7)
2023-01-27 09:46:47 +00:00
Will Fancher
3fe7a6534c sysroot: Order systemd-fsck-root after systemd-makefs
(cherry picked from commit 0941ccae3c)
(cherry picked from commit addeb46993)
2023-01-27 09:46:47 +00:00
Jacek Migacz
688bc823e2 resolve: fix enumerator name for DNS search domain
(cherry picked from commit 8b23242989)
(cherry picked from commit ec82fdc645)
2023-01-27 09:46:47 +00:00
Michal Sekletar
34f78e7e14 units: allow systemd-userdbd to change process name
rename_process() requires CAP_SYS_RESOURCE so let's make sure it is in
our permitted set after execve() by adding in to the bounding set.

Previously,
systemd-userdbd.service - User Database Manager
     Loaded: loaded (/usr/lib/systemd/system/systemd-userdbd.service; indirect; preset: disabled)
     Active: active (running) since Mon 2022-12-19 17:07:21 CET; 17min ago
TriggeredBy: ● systemd-userdbd.socket
       Docs: man:systemd-userdbd.service(8)
   Main PID: 1880 (systemd-userdbd)
     Status: "Processing requests..."
      Tasks: 4 (limit: 2272)
     Memory: 5.2M
        CPU: 244ms
     CGroup: /system.slice/systemd-userdbd.service
             ├─1880 /usr/lib/systemd/systemd-userdbd
             ├─2270 systemd-userwork
             ├─2271 systemd-userwork
             └─2272 systemd-userwork

Now,
    Loaded: loaded (/usr/lib/systemd/system/systemd-userdbd.service; indirect; preset: disabled)
     Active: active (running) since Mon 2022-12-19 17:27:02 CET; 15s ago
TriggeredBy: ● systemd-userdbd.socket
       Docs: man:systemd-userdbd.service(8)
   Main PID: 2404 (systemd-userdbd)
     Status: "Processing requests..."
      Tasks: 4 (limit: 2272)
     Memory: 5.5M
        CPU: 89ms
     CGroup: /system.slice/systemd-userdbd.service
             ├─2404 /usr/lib/systemd/systemd-userdbd
             ├─2407 "systemd-userwork: waiting..."
             ├─2408 "systemd-userwork: waiting..."
             └─2409 "systemd-userwork: waiting..."

(cherry picked from commit d5e5bc2fe9)
(cherry picked from commit 9357d23429)
2023-01-27 09:46:47 +00:00
Zbigniew Jędrzejewski-Szmek
4178457f0e sd-event: never pass negative errnos as signalfd to signalfd
We treat any negative value as "invalid fd", but signalfd only
accepts -1.

(cherry picked from commit cbff793ffb)
(cherry picked from commit 54c840ea58)
2023-01-27 09:46:47 +00:00
David Tardon
8be5a12c71 swap: tell swapon to reinitialize swap if needed
If the page size of a swap space doesn't match the page size of the
currently running kernel, swapon will fail. Let's instruct it to
reinitialize the swap space instead.

(cherry picked from commit cc137d53e3)
(cherry picked from commit a0ac79bce9)
2023-01-27 09:46:47 +00:00
Peter Cai
b6d1be1642 cryptsetup-fido2: Try all FIDO2 key slots when opening LUKS volume
After #25268, it is now possible to check whether a credential
is present on a FIDO2 token without actually attempting to retrieve said
credential. However, when cryptsetup plugins are not enabled, the
fallback unlock routines are not able to make multiple attempts with
multiple different FIDO2 key slots.

Instead of looking for one FIDO2 key slot when trying to unlock, we now
attempt to use all key slots applicable.

Fixes #19208.

(cherry picked from commit e6319a102e)
(cherry picked from commit 892cb01c2b)
2023-01-27 09:46:47 +00:00
Yu Watanabe
2682dc2164 test: name_assign_type sysattr never exists for enumerated devices
As we filtered out network devices in the test.

(cherry picked from commit 733529d812)
(cherry picked from commit a8dd94e0cc)
2023-01-27 09:46:47 +00:00
jcg
46a7e30cb9 mount-setup: don't need to mount /sys/fs/pstore if there is no ENABLE_PSTORE
(cherry picked from commit 5e5fce3e91)
(cherry picked from commit 613994c10b)
2023-01-27 09:46:47 +00:00
msizanoen1
9a0bd2ff70 core/slice: skip member units without realized cgroup during freeze or thaw
This ensures that services with `RemainAfterExit` but without any
process running won't cause failure during freeze.

(cherry picked from commit fcb0878f75)
(cherry picked from commit 2eb040f36f)
2023-01-27 09:46:47 +00:00
Siddhesh Poyarekar
4014688458 alloc-util: Disallow inlining of expand_to_usable
Explicitly set __attribute__ ((noinline)) so that the compiler does not
attempt to inline expand_to_usable, even with LTO.

(cherry picked from commit 4f79f545b3)
(cherry picked from commit e998c9d7c1)
2023-01-23 12:11:46 +01:00
Siddhesh Poyarekar
70653ebeb6 Use dummy allocator to make accesses defined as per standard
systemd uses malloc_usable_size() everywhere to use memory blocks
obtained through malloc, but that is abuse since the
malloc_usable_size() interface isn't meant for this kind of use, it is
for diagnostics only.  This is also why systemd behaviour is flaky when
built with _FORTIFY_SOURCE.

One way to make this more standard (and hence safer) is to, at every
malloc_usable_size() call, also 'reallocate' the block so that the
compiler can see the larger size.  This is done through a dummy
reallocator whose only purpose is to tell the compiler about the larger
usable size, it doesn't do any actual reallocation.

Florian Weimer pointed out that this doesn't solve the problem of an
allocator potentially growing usable size at will, which will break the
implicit assumption in systemd use that the value returned remains
constant as long as the object is valid.  The safest way to fix that is
for systemd to step away from using malloc_usable_size() like this.

Resolves #22801.

(cherry picked from commit 7929e180aa)
(cherry picked from commit 34b9eddfc1)
2023-01-23 12:10:19 +01:00
Cristian Rodríguez
85ad47e172 resolve: dns_server_feature_level_*_string type is DnsServerFeatureLevel
gcc 13 -Wenum-int-mismatch reminds us that enum != int

(cherry picked from commit e14afe31c3)
(cherry picked from commit ba5f7915d2)
2023-01-23 12:04:46 +01:00
Cristian Rodríguez
ecb0b018d2 journal-remote: code is of type enum MHD_RequestTerminationCode
Fixes gcc 13 -Wenum-int-mismatch which are enabled by default.

(cherry picked from commit aa70dd624b)
(cherry picked from commit b1b7667a44)
2023-01-23 12:04:44 +01:00
Benjamin Tissoires
4bc2b1b2d1 virt: fix container detection
Commit 1b86c7c59e ("virt: make virtualization enum a named type")
made the conversion from `if (!r)` to `if (v != VIRTUALIZATION_NONE)`.

However, the initial test was meaning "if r is null", IOW "if r IS
`VIRTUALIZATION_NONE`).

The test is wrong and this can lead to false detection of the container
environment (when calling `systemctl exit`).

For example, https://gitlab.freedesktop.org/whot/libevdev/-/jobs/34207974
is calling `systemctl exit 0`, and systemd terminates with the exit code
`130`.

Fixing that typo makes `systemctl exit 0` returns `0`.

Fixes: 1b86c7c59e.
(cherry picked from commit a91078bc57)
2023-01-22 22:28:12 +01:00
Zbigniew Jędrzejewski-Szmek
253cc95c64 Revert "cryptsetup: support keyfile-timeout for using a device as the key file"
This reverts commit 64f0e53851.

On Wed, Dec 21, 2022 at 06:19:08PM +0100, Marius Schwarz wrote:
> That patch made things worse and is disfunctional for both, usb drive and
> password.
>
> No idea if more patches are needed, but this build does not unlock a drive
> at all, if usb is configured.
2022-12-22 17:30:53 +01:00
Chih-Hsuan Yen
64f0e53851 cryptsetup: support keyfile-timeout for using a device as the key file
Closes https://github.com/systemd/systemd/issues/21993

(cherry picked from commit 7aa0b0121e)
2022-12-21 15:35:48 +01:00
Zbigniew Jędrzejewski-Szmek
efca5283dc coredump: do not allow user to access coredumps with changed uid/gid/capabilities
When the user starts a program which elevates its permissions via setuid,
setgid, or capabilities set on the file, it may access additional information
which would then be visible in the coredump. We shouldn't make the the coredump
visible to the user in such cases.

Reported-by: Matthias Gerstner <mgerstner@suse.de>

This reads the /proc/<pid>/auxv file and attaches it to the process metadata as
PROC_AUXV. Before the coredump is submitted, it is parsed and if either
at_secure was set (which the kernel will do for processes that are setuid,
setgid, or setcap), or if the effective uid/gid don't match uid/gid, the file
is not made accessible to the user. If we can't access this data, we assume the
file should not be made accessible either. In principle we could also access
the auxv data from a note in the core file, but that is much more complex and
it seems better to use the stand-alone file that is provided by the kernel.

Attaching auxv is both convient for this patch (because this way it's passed
between the stages along with other fields), but I think it makes sense to save
it in general.

We use the information early in the core file to figure out if the program was
32-bit or 64-bit and its endianness. This way we don't need heuristics to guess
whether the format of the auxv structure. This test might reject some cases on
fringe architecutes. But the impact would be limited: we just won't grant the
user permissions to view the coredump file. If people report that we're missing
some cases, we can always enhance this to support more architectures.

I tested auxv parsing on amd64, 32-bit program on amd64, arm64, arm32, and
ppc64el, but not the whole coredump handling.

(cherry picked from commit 3e4d0f6cf9)
(cherry picked from commit 9b75a3d050)
2022-12-20 19:17:00 +01:00
Zbigniew Jędrzejewski-Szmek
cb044d734c coredump: adjust whitespace
(cherry picked from commit 510a146634)
(cherry picked from commit cc2eb7a9b5)
2022-12-20 19:16:39 +01:00
Frantisek Sumsal
aca62e1b7b mkosi: work around a file conflict between systemd and systemd-boot
(cherry picked from commit a32831ae1d)
(cherry picked from commit 864c10add7)
2022-12-16 16:06:15 +00:00
Frantisek Sumsal
6a8b9e9dfd packit: drop/replace deprecated directives
(cherry picked from commit 0969bb4246)
(cherry picked from commit 7c208311d4)
2022-12-16 16:06:14 +00:00
Frantisek Sumsal
a631f52a2a packit: ignore unpackaged files
It may take a bit for newly introduced binaries/other files to get
properly integrated into the Rawhide specfile, so don't choke up in the
meantime when rpmbuild detects unpackaged files.

(cherry picked from commit ed7c45a8c8)
(cherry picked from commit 689161a301)
2022-12-16 16:06:13 +00:00
Lennart Poettering
1ee30b0ea9 mkosi: pull in libbpf1 instead of legacy libbpf0 on debian
(cherry picked from commit 0d9e6d76be)
(cherry picked from commit 31bb2ef7ea)
2022-12-14 23:27:59 +00:00
Zbigniew Jędrzejewski-Szmek
6208326afb coredump: cescape invalid json data before logging
In both cases, the json string is short, so we can print it, which is useful
for diagnosing invalid data in packages. But we need escape non-printable
characters.

https://bugzilla.redhat.com/show_bug.cgi?id=2152685

I went over the rest of the codebase, and it seems that other calls to
json_parse() don't have this problem.

(cherry picked from commit c5966ab5bf)
(cherry picked from commit 57ab4e2d47)
2022-12-14 18:23:27 +01:00
Daan De Meyer
5e5e806539 execute: Pass AT_FDCWD instead of -1
Let's enforce that callers pass AT_FDCWD as read_dfd to load_credential()
to avoid an assert() in read_full_file_full() if read_dfd is -1.

(cherry picked from commit 661e4251a5)
(cherry picked from commit d78dc885b0)
2022-12-14 18:22:59 +01:00
Zbigniew Jędrzejewski-Szmek
61cd7152a4 udev: rework 60-evdev.rules to be "additive"
We would execute up to four hwdb match patterns (+ the keyboard builtin):
After the first hit, we would skip the other patterns, because of the GOTO="evdev_end"
action.

57bb707d48 (rules: Add extended evdev/input match
rules for event nodes with the same name), added an additional match with
":phys:<phys>:ev:<ev>" inserted. This breaks backwards compatibility for user
hwdb patterns, because we quit after the first match.

In general hwdb properties are "additive". We often have a general rule that
matches a wider class and then some specific overrides. E.g. in this particular
case, we have a match for all trackpoints, and then a bunch of model-specific
settings.

So let's change the rules to try all the match patterns and combine the
received properties. We execute builtin-keyboard once at the end, if there was
at least one match.

Fixes #25698. Fixes https://bugzilla.redhat.com/show_bug.cgi?id=2152226.

This also impacts other cases which I think would be very confusing for users.
Since we quit after a first successful match, if we had e.g. a match for
'evdev:input:b*v*p*' in out database, and the user added a match using
'evdev:name:*', which is the approach we document in the .hwdb files and which
users quite often use, it would be silently ignored. What's worse, if we added
our 'evdev:input:b*v*p*' match at a later point, user's match would stop
working. If we combine all the properties, we get more stable behaviour.

(cherry picked from commit 953c928c24)
(cherry picked from commit 4cfdb1c73b)
2022-12-14 18:22:53 +01:00
Yu Watanabe
1750691cc5 core/device: verify device syspath on switching root
Otherwise, if a device is removed while switching root, then the
corresponding .device unit will never go to inactive state.

This replaces the code dropped by cf1ac0cfe4.

Fixes #25106.

(cherry picked from commit b6c86ae281)
(cherry picked from commit e3d9376692)

Upstream comment says this is for cf1… which is post-v251, but the buggy commit
was backported to v251-stable.
2022-12-14 18:21:29 +01:00
Yu Watanabe
3cc039108b core/device: also serialize/deserialize device syspath
The field will be used in later commits.

(cherry picked from commit 1ea74fca3a)
(cherry picked from commit 9523f85b2e)
2022-12-14 18:20:09 +01:00
Yu Watanabe
118e550c88 resolve: drop recursion in TXT field handling
Fixes #25683.

(cherry picked from commit 494ef16743)
(cherry picked from commit 8ff529fb80)
2022-12-14 18:06:25 +01:00
Yu Watanabe
8f4d5828aa sd-device: fix double-free
If an attribute is read but the value is not used (i.e. ret_value is NULL),
then sd_device_get_sysattr_value() mistakenly frees the read data even though
it is cached internally.

Fixes a bug introduced by acfc2a1d15.

Fixes #25702.

(cherry picked from commit eb18e7b782)
(cherry picked from commit aeb3653744)
2022-12-14 18:06:25 +01:00
Yu Watanabe
f2f863c51f network: manage addresses in the way the kernel does
This effectively reverts 5d0030310c.

With the commit 5d0030310c, networkd manages
addresses with the detailed hash and compare functions. But that causes
networkd cannot detect address update by the kernel or an external tool.
See issue
https://github.com/systemd/systemd/issues/481#issuecomment-1328132401.

With this commit, networkd (again) manages addresses in the way that the
kernel does. Hence, we can correctly detect address update.

(cherry picked from commit 42f8b6a808)
(cherry picked from commit 13de548fca)
2022-12-14 18:06:25 +01:00
Ivan Shapovalov
3bb53f281d import: wire up SYSTEMD_IMPORT_BTRFS_{SUBVOL,QUOTA} to importd
Btrfs quotas are actually being enabled in systemd-importd via
setup_machine_directory(), not in systemd-{import,pull} where those
environment variables are checked. Therefore, also check them in
systemd-importd and avoid enabling quotas if requested by the user.

Fixes: #18421
Fixes: #15903
Fixes: #24387
(cherry picked from commit c7779a61ac)
(cherry picked from commit fcc174cbdd)
2022-12-14 17:59:31 +01:00
Ivan Shapovalov
c31cceb0fd machine-pool: simplify return values from setup_machine_directory()
Non-negative return values of setup_machine_directory() were never used
and never had clear meaning, so do not distinguish between various
non-error conditions and just return 0 in all cases.

(cherry picked from commit e9231901a2)
(cherry picked from commit 6cb0724a06)
2022-12-14 17:59:30 +01:00
Yu Watanabe
18bfa23b9b hexdecoct: fix NULL pointer dereferences in hexmem()
Fixes oss-fuzz#54090 (https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=54090).

Fixes #25655.

(cherry picked from commit 7d34567444)
(cherry picked from commit 772e89452e)
2022-12-14 17:58:31 +01:00
Yu Watanabe
671ea8cce4 hexdecoct: add missing NULL check
Fixes oss-fuzz#54065 (https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=54065).

Fixes #25650.

(cherry picked from commit 45655e776f)
(cherry picked from commit 002fc46688)
2022-12-14 17:58:31 +01:00
Yu Watanabe
82a6ac3a2c test: add tests for base64_append()
(cherry picked from commit 6b0df52e58)
(cherry picked from commit be1088b7a0)
2022-12-14 17:58:30 +01:00
Yu Watanabe
d62a3e20e4 hexdecoct: several cleanups for base64_append()
- add missing assertions,
- use size_t for buffser size or memory index,
- handle empty input more gracefully,
- return the length or the result string,
- fix off-by-one issue when the prefix is already long enough.

(cherry picked from commit c21b316964)
(cherry picked from commit acb0414a1f)
2022-12-14 17:58:29 +01:00
Lennart Poettering
5bbc2ecaf9 selinux: accept the fact that getxyzcon() can return success and NULL
Inspired by #25664: let's check explicitly for NULL everywhere we do one
of those getXYZcon() calls.

We usually turn this into EOPNOTSUPP, as when selinux is off (which is
supposed to be the only case this can happen according to selinux docs)
we otherwise return EOPNOTSUPP in that case.

Note that in most cases we have an explicit mac_selinux_use() call
beforehand, hence this should mostly not be triggerable codepaths.

(cherry picked from commit af614e45c3)
(cherry picked from commit 6c869ad3bd)
2022-12-14 17:57:54 +01:00
Jade Lovelace
8c1683a0e7 oomd: print dry run output at INFO level
Otherwise, the dry run isn't much use since it would be logged at debug
and not seen.

(cherry picked from commit 3b703840d9)
(cherry picked from commit 0fdeb7c640)
2022-12-14 17:56:31 +01:00
Space Meyer
9070c9f2f3 journald: prevent segfault on empty attr/current
getpidcon() might set con to NULL, even when it returned a 0 return
code[0]. The subsequent strlen(con) will then cause a segfault.

Alternatively the behaviour could also be changed in getpidcon. I
don't know whether the libselinux folks are comitted to the current
behaviour, but the getpidcon man page doesn't really make it obvious
this case could happen.

[0] fb7f35495f/libselinux/src/procattr.c (L155-L158)

(cherry picked from commit ff868eaade)
(cherry picked from commit 4119d25e62)
2022-12-14 17:56:26 +01:00
Yu Watanabe
d966d00e8d core: use correct scope of looking up units
Fixes a bug introduced by 3b3557c410.

Fixes #25625.

(cherry picked from commit 47c57b4813)
(cherry picked from commit 6fdf196f99)
2022-12-14 17:56:17 +01:00
Jian Zhang
19aed86574 test-network: add test for bond mac address config
Signed-off-by: Jian Zhang <zhangjian.3032@bytedance.com>
(cherry picked from commit 23b6bf274f)
(cherry picked from commit 6d7b0dacc6)
2022-12-14 17:55:12 +01:00
Jian Zhang
dfbdb3a8d5 network: Fix set bond device MAC address failed
Issue:
When device is in bond mode and booting up, there is a probability of
set bond MAC address failed due to `Device or resource busy` error.

In systemd-networkd, set MAC address steps are:
1. Try to set MAC address to device.
2. If failed with `Device or resource busy`, then `Down` the device.
3. Try to set MAC address to device again.

Currently, Even down the bond device, the bond device is still return
`Device or resource busy` error. So the MAC address set failed.

The root cause is that this not enough to down the bond device. We need
to down all the slaves of the bond device.
About this descprition, we could use those commands to check:
```shell
We have two network devices: eth0, bond1, eth0 is slave of bond1.
They are all up.

1. Down bond1, and set MAC address to bond1.
~# ip link set bond1 down
~# ip link set bond1 address 00:11:22:33:44:55
ip: SIOCSIFHWADDR: Device or resource busy

2. Down eth0, and set MAC address to bond1.
~# ip link set eth0 down
~# ip link set bond1 address 00:11:22:33:44:55
Set okay.
```

Fix:
When setting the mac for the second time, if the device kind is bond,
then we need to down the slave devices of bond device.

Tested: Verified in a long time test( reboot cycles ).

Fixes: #25627

Signed-off-by: Jian Zhang <zhangjian.3032@bytedance.com>
(cherry picked from commit f1a69d5acc)
(cherry picked from commit 6405eba4b6)
2022-12-14 17:55:06 +01:00
Daan De Meyer
07b62913a6 test-fs-util: Add relative path chase_symlinks() tests
(cherry picked from commit 94799c305a)
(cherry picked from commit dbc59253ec)
2022-12-14 17:54:48 +01:00