From 53e91c8dcd718980a39a1a0b0f0e55f98c43489a872b88ef847b3d887e1976d2 Mon Sep 17 00:00:00 2001 From: Franck Bui Date: Fri, 9 Dec 2022 08:02:50 +0000 Subject: [PATCH 1/3] - Import commit 82898a14f5b0a965ba9c1efc1913fcdf29d446a8 (merge of v252.3) For a complete list of changes, visit: https://github.com/openSUSE/systemd/compare/e7e931b07edd786dc6ca1dae6c23ff7b785f8efd...82898a14f5b0a965ba9c1efc1913fcdf29d446a8 Additionally, it also includes the following backports: - 17b2f9f196 utmp-wtmp: fix error in case isatty() fails - 8d5c487c87 sd-bus: handle -EINTR return from bus_poll() (bsc#1201982) - 2dd217c8b5 tree-wide: modernizations with RET_NERRNO() OBS-URL: https://build.opensuse.org/package/show/Base:System/systemd?expand=0&rev=1333 --- systemd-v252.2+suse.29.ge7e931b07e.tar.xz | 3 --- systemd-v252.3+suse.35.g82898a14f5.tar.xz | 3 +++ systemd.changes | 14 ++++++++++++++ systemd.spec | 4 ++-- 4 files changed, 19 insertions(+), 5 deletions(-) delete mode 100644 systemd-v252.2+suse.29.ge7e931b07e.tar.xz create mode 100644 systemd-v252.3+suse.35.g82898a14f5.tar.xz diff --git a/systemd-v252.2+suse.29.ge7e931b07e.tar.xz b/systemd-v252.2+suse.29.ge7e931b07e.tar.xz deleted file mode 100644 index e67235d2..00000000 --- a/systemd-v252.2+suse.29.ge7e931b07e.tar.xz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:981382ec6df9b609d8ecd5cb7e570064567840e1f618c205df9d0fc67d803dca -size 8035936 diff --git a/systemd-v252.3+suse.35.g82898a14f5.tar.xz b/systemd-v252.3+suse.35.g82898a14f5.tar.xz new file mode 100644 index 00000000..908992ee --- /dev/null +++ b/systemd-v252.3+suse.35.g82898a14f5.tar.xz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:f28cbc4f37c8a9fb7e5adbae8b8f6112fa405f69a33f6523ab017eb7895a09e9 +size 8041076 diff --git a/systemd.changes b/systemd.changes index c29812f8..36a93d94 100644 --- a/systemd.changes +++ b/systemd.changes @@ -1,3 +1,17 @@ +------------------------------------------------------------------- +Fri Dec 9 07:41:04 UTC 2022 - Franck Bui + +- Import commit 82898a14f5b0a965ba9c1efc1913fcdf29d446a8 (merge of v252.3) + + For a complete list of changes, visit: + https://github.com/openSUSE/systemd/compare/e7e931b07edd786dc6ca1dae6c23ff7b785f8efd...82898a14f5b0a965ba9c1efc1913fcdf29d446a8 + + Additionally, it also includes the following backports: + + - 17b2f9f196 utmp-wtmp: fix error in case isatty() fails + - 8d5c487c87 sd-bus: handle -EINTR return from bus_poll() (bsc#1201982) + - 2dd217c8b5 tree-wide: modernizations with RET_NERRNO() + ------------------------------------------------------------------- Fri Dec 2 14:06:08 UTC 2022 - Franck Bui diff --git a/systemd.spec b/systemd.spec index ca60b72b..855d8d17 100644 --- a/systemd.spec +++ b/systemd.spec @@ -19,7 +19,7 @@ %global flavor @BUILD_FLAVOR@%{nil} %define min_kernel_version 4.5 -%define archive_version +suse.29.ge7e931b07e +%define archive_version +suse.35.g82898a14f5 %define _testsuitedir /usr/lib/systemd/tests %define xinitconfdir %{?_distconfdir}%{!?_distconfdir:%{_sysconfdir}}/X11/xinit @@ -72,7 +72,7 @@ Name: systemd%{?mini} URL: http://www.freedesktop.org/wiki/Software/systemd -Version: 252.2 +Version: 252.3 Release: 0 Summary: A System and Session Manager License: LGPL-2.1-or-later From 409caf911b3ec81446d87028906ae0b7273cb1c55a9addab2d1923ccbdc9de52 Mon Sep 17 00:00:00 2001 From: Franck Bui Date: Fri, 9 Dec 2022 08:42:43 +0000 Subject: [PATCH 2/3] - Import commit bf3fef99886bd977a1c7a51d20087bc8977fff44 6372fb0cc4 btrfs-util: convert O_PATH if necessary, in btrfs quota call (bsc#1205560) 12e68eb0e5 blockdev-util: move O_PATH fd conversion into btrfs_get_block_device_fd() to shorten things bb2bafdc9d btrfs-util: convert to fd_reopen_condition() 1323232948 fd-util: add new helper fd_reopen_conditional() - Drop 6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch It's no more needed as a fix for bsc#1205560 has been queued, see above. OBS-URL: https://build.opensuse.org/package/show/Base:System/systemd?expand=0&rev=1334 --- ...whenever-creating-an-inode-immediate.patch | 479 ------------------ systemd-v252.3+suse.35.g82898a14f5.tar.xz | 3 - systemd-v252.3+suse.40.gbf3fef9988.tar.xz | 3 + systemd.changes | 14 + systemd.spec | 3 +- 5 files changed, 18 insertions(+), 484 deletions(-) delete mode 100644 6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch delete mode 100644 systemd-v252.3+suse.35.g82898a14f5.tar.xz create mode 100644 systemd-v252.3+suse.40.gbf3fef9988.tar.xz diff --git a/6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch b/6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch deleted file mode 100644 index cdc9200e..00000000 --- a/6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch +++ /dev/null @@ -1,479 +0,0 @@ -From 3aabdad41fecf8004a1e0e4ca4bfc7b2f935404c Mon Sep 17 00:00:00 2001 -From: Franck Bui -Date: Tue, 22 Nov 2022 14:45:56 +0100 -Subject: [PATCH 6000/6000] Revert "tmpfiles: whenever creating an inode, - immediately O_PATH open it to pin it" - -This reverts commit 8f6fb95cd069884f4ce0a24eb20efc821ae3bc5e. ---- - src/tmpfiles/tmpfiles.c | 283 +++++++++++++++++----------------------- - 1 file changed, 118 insertions(+), 165 deletions(-) - -diff --git a/src/tmpfiles/tmpfiles.c b/src/tmpfiles/tmpfiles.c -index 18bb75715b..9c2740f6ce 100644 ---- a/src/tmpfiles/tmpfiles.c -+++ b/src/tmpfiles/tmpfiles.c -@@ -31,7 +31,6 @@ - #include "dirent-util.h" - #include "dissect-image.h" - #include "env-util.h" --#include "errno-util.h" - #include "escape.h" - #include "fd-util.h" - #include "fileio.h" -@@ -1527,9 +1526,11 @@ static int create_file(Item *i, const char *path) { - st = &stbuf; - creation = CREATION_EXISTING; - } else { -- r = write_argument_data(i, fd, path); -- if (r < 0) -- return r; -+ if (item_binary_argument(i)) { -+ r = write_argument_data(i, fd, path); -+ if (r < 0) -+ return r; -+ } - - creation = CREATION_NORMAL; - } -@@ -1629,7 +1630,6 @@ static int truncate_file(Item *i, const char *path) { - static int copy_files(Item *i) { - _cleanup_close_ int dfd = -1, fd = -1; - _cleanup_free_ char *bn = NULL; -- struct stat st, a; - int r; - - log_debug("Copying tree \"%s\" to \"%s\".", i->argument, i->path); -@@ -1649,27 +1649,35 @@ static int copy_files(Item *i) { - i->uid_set ? i->uid : UID_INVALID, - i->gid_set ? i->gid : GID_INVALID, - COPY_REFLINK | COPY_MERGE_EMPTY | COPY_MAC_CREATE | COPY_HARDLINKS); -+ if (r < 0) { -+ struct stat a, b; - -- fd = openat(dfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -- if (fd < 0) { -- if (r < 0) /* Look at original error first */ -- return log_error_errno(r, "Failed to copy files to %s: %m", i->path); -+ /* If the target already exists on read-only filesystems, trying -+ * to create the target will not fail with EEXIST but with -+ * EROFS. */ -+ if (r == -EROFS && faccessat(dfd, bn, F_OK, AT_SYMLINK_NOFOLLOW) == 0) -+ r = -EEXIST; - -- return log_error_errno(errno, "Failed to openat(%s): %m", i->path); -- } -+ if (r != -EEXIST) -+ return log_error_errno(r, "Failed to copy files to %s: %m", i->path); - -- if (fstat(fd, &st) < 0) -- return log_error_errno(errno, "Failed to fstat(%s): %m", i->path); -+ if (stat(i->argument, &a) < 0) -+ return log_error_errno(errno, "stat(%s) failed: %m", i->argument); - -- if (stat(i->argument, &a) < 0) -- return log_error_errno(errno, "Failed to stat(%s): %m", i->argument); -+ if (fstatat(dfd, bn, &b, AT_SYMLINK_NOFOLLOW) < 0) -+ return log_error_errno(errno, "stat(%s) failed: %m", i->path); - -- if (((st.st_mode ^ a.st_mode) & S_IFMT) != 0) { -- log_debug("Can't copy to %s, file exists already and is of different type", i->path); -- return 0; -+ if ((a.st_mode ^ b.st_mode) & S_IFMT) { -+ log_debug("Can't copy to %s, file exists already and is of different type", i->path); -+ return 0; -+ } - } - -- return fd_set_perms(i, fd, i->path, &st, _CREATION_MODE_INVALID); -+ fd = openat(dfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -+ if (fd < 0) -+ return log_error_errno(errno, "Failed to openat(%s): %m", i->path); -+ -+ return fd_set_perms(i, fd, i->path, /* st = */ NULL, _CREATION_MODE_INVALID); - } - - static int create_directory_or_subvolume( -@@ -1677,13 +1685,11 @@ static int create_directory_or_subvolume( - mode_t mode, - bool subvol, - bool allow_failure, -- struct stat *ret_st, - CreationMode *ret_creation) { - - _cleanup_free_ char *bn = NULL; - _cleanup_close_ int pfd = -1; -- CreationMode creation; -- struct stat st; -+ CreationMode c; - int r, fd; - - assert(path); -@@ -1703,7 +1709,7 @@ static int create_directory_or_subvolume( - log_warning_errno(r, "Cannot parse value of $SYSTEMD_TMPFILES_FORCE_SUBVOL, ignoring."); - r = btrfs_is_subvol(empty_to_root(arg_root)) > 0; - } -- if (r == 0) -+ if (!r) - /* Don't create a subvolume unless the root directory is one, too. We do this under - * the assumption that if the root directory is just a plain directory (i.e. very - * light-weight), we shouldn't try to split it up into subvolumes (i.e. more -@@ -1719,40 +1725,41 @@ static int create_directory_or_subvolume( - } else - r = 0; - -- if (!subvol || ERRNO_IS_NOT_SUPPORTED(r)) -+ if (!subvol || r == -ENOTTY) - RUN_WITH_UMASK(0000) - r = mkdirat_label(pfd, bn, mode); - -- creation = r >= 0 ? CREATION_NORMAL : CREATION_EXISTING; -- -- fd = openat(pfd, bn, O_NOFOLLOW|O_CLOEXEC|O_DIRECTORY|O_PATH); -- if (fd < 0) { -- /* We couldn't open it because it is not actually a directory? */ -- if (errno == ENOTDIR) -- return log_error_errno(SYNTHETIC_ERRNO(EEXIST), "\"%s\" already exists and is not a directory.", path); -+ if (r < 0) { -+ int k; - -- /* Then look at the original error */ -- if (r < 0) -+ if (!IN_SET(r, -EEXIST, -EROFS)) - return log_full_errno(allow_failure ? LOG_INFO : LOG_ERR, - r, - "Failed to create directory or subvolume \"%s\"%s: %m", - path, - allow_failure ? ", ignoring" : ""); - -- return log_error_errno(errno, "Failed to open directory/subvolume we just created '%s': %m", path); -- } -+ k = is_dir_full(pfd, bn, /* follow= */ false); -+ if (k == -ENOENT && r == -EROFS) -+ return log_error_errno(r, "%s does not exist and cannot be created as the file system is read-only.", path); -+ if (k < 0) -+ return log_error_errno(k, "Failed to check if %s exists: %m", path); -+ if (!k) -+ return log_warning_errno(SYNTHETIC_ERRNO(EEXIST), -+ "\"%s\" already exists and is not a directory.", path); - -- if (fstat(fd, &st) < 0) -- return log_error_errno(errno, "Failed to fstat(%s): %m", path); -+ c = CREATION_EXISTING; -+ } else -+ c = CREATION_NORMAL; - -- assert(S_ISDIR(st.st_mode)); /* we used O_DIRECTORY above */ -+ log_debug("%s directory \"%s\".", creation_mode_verb_to_string(c), path); - -- log_debug("%s directory \"%s\".", creation_mode_verb_to_string(creation), path); -+ fd = openat(pfd, bn, O_NOCTTY|O_CLOEXEC|O_DIRECTORY); -+ if (fd < 0) -+ return log_error_errno(errno, "Failed to open directory '%s': %m", bn); - -- if (ret_st) -- *ret_st = st; - if (ret_creation) -- *ret_creation = creation; -+ *ret_creation = c; - - return fd; - } -@@ -1760,30 +1767,28 @@ static int create_directory_or_subvolume( - static int create_directory(Item *i, const char *path) { - _cleanup_close_ int fd = -1; - CreationMode creation; -- struct stat st; - - assert(i); - assert(IN_SET(i->type, CREATE_DIRECTORY, TRUNCATE_DIRECTORY)); - -- fd = create_directory_or_subvolume(path, i->mode, /* subvol= */ false, i->allow_failure, &st, &creation); -+ fd = create_directory_or_subvolume(path, i->mode, /* subvol= */ false, i->allow_failure, &creation); - if (fd == -EEXIST) - return 0; - if (fd < 0) - return fd; - -- return fd_set_perms(i, fd, path, &st, creation); -+ return fd_set_perms(i, fd, path, /* st= */ NULL, creation); - } - - static int create_subvolume(Item *i, const char *path) { - _cleanup_close_ int fd = -1; - CreationMode creation; -- struct stat st; - int r, q = 0; - - assert(i); - assert(IN_SET(i->type, CREATE_SUBVOLUME, CREATE_SUBVOLUME_NEW_QUOTA, CREATE_SUBVOLUME_INHERIT_QUOTA)); - -- fd = create_directory_or_subvolume(path, i->mode, /* subvol = */ true, i->allow_failure, &st, &creation); -+ fd = create_directory_or_subvolume(path, i->mode, /* subvol = */ true, i->allow_failure, &creation); - if (fd == -EEXIST) - return 0; - if (fd < 0) -@@ -1806,7 +1811,7 @@ static int create_subvolume(Item *i, const char *path) { - log_debug("Quota for subvolume \"%s\" already in place, no change made.", i->path); - } - -- r = fd_set_perms(i, fd, path, &st, creation); -+ r = fd_set_perms(i, fd, path, /* st= */ NULL, creation); - if (q < 0) /* prefer the quota change error from above */ - return q; - -@@ -1847,11 +1852,9 @@ static int create_device(Item *i, mode_t file_type) { - _cleanup_close_ int dfd = -1, fd = -1; - _cleanup_free_ char *bn = NULL; - CreationMode creation; -- struct stat st; - int r; - - assert(i); -- assert(IN_SET(i->type, CREATE_BLOCK_DEVICE, CREATE_CHAR_DEVICE)); - assert(IN_SET(file_type, S_IFBLK, S_IFCHR)); - - r = path_extract_filename(i->path, &bn); -@@ -1871,166 +1874,116 @@ static int create_device(Item *i, mode_t file_type) { - r = RET_NERRNO(mknodat(dfd, bn, i->mode | file_type, i->major_minor)); - mac_selinux_create_file_clear(); - } -- creation = r >= 0 ? CREATION_NORMAL : CREATION_EXISTING; -- -- /* Try to open the inode via O_PATH, regardless if we could create it or not. Maybe everything is in -- * order anyway and we hence can ignore the error to create the device node */ -- fd = openat(dfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -- if (fd < 0) { -- /* OK, so opening the inode failed, let's look at the original error then. */ - -- if (r < 0) { -- if (ERRNO_IS_PRIVILEGE(r)) -- goto handle_privilege; -+ if (r < 0) { -+ struct stat st; - -- return log_error_errno(r, "Failed to create device node '%s': %m", i->path); -+ if (r == -EPERM) { -+ log_debug_errno(r, -+ "We lack permissions, possibly because of cgroup configuration; " -+ "skipping creation of device node %s.", i->path); -+ return 0; - } - -- return log_error_errno(errno, "Failed to open device node '%s' we just created: %m", i->path); -- } -+ if (r != -EEXIST) -+ return log_error_errno(r, "Failed to create device node %s: %m", i->path); - -- if (fstat(fd, &st) < 0) -- return log_error_errno(errno, "Failed to fstat(%s): %m", i->path); -+ if (fstatat(dfd, bn, &st, 0) < 0) -+ return log_error_errno(errno, "stat(%s) failed: %m", i->path); - -- if (((st.st_mode ^ file_type) & S_IFMT) != 0) { -+ if ((st.st_mode & S_IFMT) != file_type) { - -- if (i->append_or_force) { -- fd = safe_close(fd); -+ if (i->append_or_force) { - -- RUN_WITH_UMASK(0000) { -- mac_selinux_create_file_prepare(i->path, file_type); -- r = mknodat_atomic(dfd, bn, i->mode | file_type, i->major_minor); -- mac_selinux_create_file_clear(); -- } -- if (ERRNO_IS_PRIVILEGE(r)) -- goto handle_privilege; -- if (IN_SET(r, -EISDIR, -EEXIST, -ENOTEMPTY)) { -- r = rm_rf_child(dfd, bn, REMOVE_PHYSICAL); -- if (r < 0) -- return log_error_errno(r, "rm -rf %s failed: %m", i->path); -+ RUN_WITH_UMASK(0000) { -+ mac_selinux_create_file_prepare(i->path, file_type); -+ /* FIXME: need to introduce mknodat_atomic() */ -+ r = mknod_atomic(i->path, i->mode | file_type, i->major_minor); -+ mac_selinux_create_file_clear(); -+ } - -- mac_selinux_create_file_prepare(i->path, file_type); -- r = RET_NERRNO(mknodat(dfd, bn, i->mode | file_type, i->major_minor)); -- mac_selinux_create_file_clear(); -+ if (r < 0) -+ return log_error_errno(r, "Failed to create device node \"%s\": %m", i->path); -+ creation = CREATION_FORCE; -+ } else { -+ log_warning("\"%s\" already exists is not a device node.", i->path); -+ return 0; - } -- if (r < 0) -- return log_error_errno(r, "Failed to create device node '%s': %m", i->path); -- -- fd = openat(dfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -- if (fd < 0) -- return log_error_errno(errno, "Failed to open device node we just created '%s': %m", i->path); -- -- /* Validate type before change ownership below */ -- if (fstat(fd, &st) < 0) -- return log_error_errno(errno, "Failed to fstat(%s): %m", i->path); -- -- if (((st.st_mode ^ file_type) & S_IFMT) != 0) -- return log_error_errno(SYNTHETIC_ERRNO(EBADF), "Device node we just created is not a device node, refusing."); -- -- creation = CREATION_FORCE; -- } else { -- log_warning("\"%s\" already exists and is not a device node.", i->path); -- return 0; -- } -- } -+ } else -+ creation = CREATION_EXISTING; -+ } else -+ creation = CREATION_NORMAL; - - log_debug("%s %s device node \"%s\" %u:%u.", - creation_mode_verb_to_string(creation), - i->type == CREATE_BLOCK_DEVICE ? "block" : "char", - i->path, major(i->mode), minor(i->mode)); - -- return fd_set_perms(i, fd, i->path, &st, creation); -+ fd = openat(dfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -+ if (fd < 0) -+ return log_error_errno(errno, "Failed to openat(%s): %m", i->path); - --handle_privilege: -- log_debug_errno(r, -- "We lack permissions, possibly because of cgroup configuration; " -- "skipping creation of device node '%s'.", i->path); -- return 0; -+ return fd_set_perms(i, fd, i->path, /* st = */ NULL, creation); - } - --static int create_fifo(Item *i) { -+static int create_fifo(Item *i, const char *path) { - _cleanup_close_ int pfd = -1, fd = -1; - _cleanup_free_ char *bn = NULL; - CreationMode creation; - struct stat st; - int r; - -- assert(i); -- assert(i->type == CREATE_FIFO); -- - r = path_extract_filename(i->path, &bn); - if (r < 0) -- return log_error_errno(r, "Failed to extract filename from path '%s': %m", i->path); -+ return log_error_errno(r, "Failed to extract filename from path '%s': %m", path); - if (r == O_DIRECTORY) -- return log_error_errno(SYNTHETIC_ERRNO(EISDIR), "Cannot open path '%s' for creating FIFO, is a directory.", i->path); -+ return log_error_errno(SYNTHETIC_ERRNO(EISDIR), "Cannot open path '%s' for creating FIFO, is a directory.", path); - -- pfd = path_open_parent_safe(i->path, i->allow_failure); -+ pfd = path_open_parent_safe(path, i->allow_failure); - if (pfd < 0) - return pfd; - - RUN_WITH_UMASK(0000) { -- mac_selinux_create_file_prepare(i->path, S_IFIFO); -+ mac_selinux_create_file_prepare(path, S_IFIFO); - r = RET_NERRNO(mkfifoat(pfd, bn, i->mode)); - mac_selinux_create_file_clear(); - } - -- creation = r >= 0 ? CREATION_NORMAL : CREATION_EXISTING; -- -- /* Open the inode via O_PATH, regardless if we managed to create it or not. Maybe it is is already the FIFO we want */ -- fd = openat(pfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -- if (fd < 0) { -- if (r < 0) -- return log_error_errno(r, "Failed to create FIFO %s: %m", i->path); /* original error! */ -- -- return log_error_errno(errno, "Failed to open FIFO we just created %s: %m", i->path); -- } -+ if (r < 0) { -+ if (r != -EEXIST) -+ return log_error_errno(r, "Failed to create fifo %s: %m", path); - -- if (fstat(fd, &st) < 0) -- return log_error_errno(errno, "Failed to fstat(%s): %m", i->path); -+ if (fstatat(pfd, bn, &st, AT_SYMLINK_NOFOLLOW) < 0) -+ return log_error_errno(errno, "stat(%s) failed: %m", path); - -- if (!S_ISFIFO(st.st_mode)) { -+ if (!S_ISFIFO(st.st_mode)) { - -- if (i->append_or_force) { -- fd = safe_close(fd); -+ if (i->append_or_force) { -+ RUN_WITH_UMASK(0000) { -+ mac_selinux_create_file_prepare(path, S_IFIFO); -+ r = mkfifoat_atomic(pfd, bn, i->mode); -+ mac_selinux_create_file_clear(); -+ } - -- RUN_WITH_UMASK(0000) { -- mac_selinux_create_file_prepare(i->path, S_IFIFO); -- r = mkfifoat_atomic(pfd, bn, i->mode); -- mac_selinux_create_file_clear(); -- } -- if (IN_SET(r, -EISDIR, -EEXIST, -ENOTEMPTY)) { -- r = rm_rf_child(pfd, bn, REMOVE_PHYSICAL); - if (r < 0) -- return log_error_errno(r, "rm -rf %s failed: %m", i->path); -- -- mac_selinux_create_file_prepare(i->path, S_IFIFO); -- r = RET_NERRNO(mkfifoat(pfd, bn, i->mode)); -- mac_selinux_create_file_clear(); -+ return log_error_errno(r, "Failed to create fifo %s: %m", path); -+ creation = CREATION_FORCE; -+ } else { -+ log_warning("\"%s\" already exists and is not a fifo.", path); -+ return 0; - } -- if (r < 0) -- return log_error_errno(r, "Failed to create FIFO %s: %m", i->path); -- -- fd = openat(pfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -- if (fd < 0) -- return log_error_errno(errno, "Failed to open FIFO we just created '%s': %m", i->path); -- -- /* Validate type before change ownership below */ -- if (fstat(fd, &st) < 0) -- return log_error_errno(errno, "Failed to fstat(%s): %m", i->path); -+ } else -+ creation = CREATION_EXISTING; -+ } else -+ creation = CREATION_NORMAL; - -- if (!S_ISFIFO(st.st_mode)) -- return log_error_errno(SYNTHETIC_ERRNO(EBADF), "FIFO inode we just created is not a FIFO, refusing."); -+ log_debug("%s fifo \"%s\".", creation_mode_verb_to_string(creation), path); - -- creation = CREATION_FORCE; -- } else { -- log_warning("\"%s\" already exists and is not a FIFO.", i->path); -- return 0; -- } -- } -- -- log_debug("%s fifo \"%s\".", creation_mode_verb_to_string(creation), i->path); -+ fd = openat(pfd, bn, O_NOFOLLOW|O_CLOEXEC|O_PATH); -+ if (fd < 0) -+ return log_error_errno(errno, "Failed to openat(%s): %m", path); - -- return fd_set_perms(i, fd, i->path, &st, creation); -+ return fd_set_perms(i, fd, i->path, /* st = */ NULL, creation); - } - - static int create_symlink(Item *i) { -@@ -2499,7 +2452,7 @@ static int create_item(Item *i) { - if (r < 0) - return r; - -- r = create_fifo(i); -+ r = create_fifo(i, i->path); - if (r < 0) - return r; - break; --- -2.35.3 - diff --git a/systemd-v252.3+suse.35.g82898a14f5.tar.xz b/systemd-v252.3+suse.35.g82898a14f5.tar.xz deleted file mode 100644 index 908992ee..00000000 --- a/systemd-v252.3+suse.35.g82898a14f5.tar.xz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:f28cbc4f37c8a9fb7e5adbae8b8f6112fa405f69a33f6523ab017eb7895a09e9 -size 8041076 diff --git a/systemd-v252.3+suse.40.gbf3fef9988.tar.xz b/systemd-v252.3+suse.40.gbf3fef9988.tar.xz new file mode 100644 index 00000000..a630a377 --- /dev/null +++ b/systemd-v252.3+suse.40.gbf3fef9988.tar.xz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:4274c52c308874f73756af1fe91d0cf35ab72112f6ba593399398eddd17cc0c4 +size 8040380 diff --git a/systemd.changes b/systemd.changes index 36a93d94..596e173a 100644 --- a/systemd.changes +++ b/systemd.changes @@ -1,3 +1,17 @@ +------------------------------------------------------------------- +Fri Dec 9 08:28:50 UTC 2022 - Franck Bui + +- Import commit bf3fef99886bd977a1c7a51d20087bc8977fff44 + + 6372fb0cc4 btrfs-util: convert O_PATH if necessary, in btrfs quota call (bsc#1205560) + 12e68eb0e5 blockdev-util: move O_PATH fd conversion into btrfs_get_block_device_fd() to shorten things + bb2bafdc9d btrfs-util: convert to fd_reopen_condition() + 1323232948 fd-util: add new helper fd_reopen_conditional() + +- Drop 6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch + + It's no more needed as a fix for bsc#1205560 has been queued, see above. + ------------------------------------------------------------------- Fri Dec 9 07:41:04 UTC 2022 - Franck Bui diff --git a/systemd.spec b/systemd.spec index 855d8d17..ad7989d5 100644 --- a/systemd.spec +++ b/systemd.spec @@ -19,7 +19,7 @@ %global flavor @BUILD_FLAVOR@%{nil} %define min_kernel_version 4.5 -%define archive_version +suse.35.g82898a14f5 +%define archive_version +suse.40.gbf3fef9988 %define _testsuitedir /usr/lib/systemd/tests %define xinitconfdir %{?_distconfdir}%{!?_distconfdir:%{_sysconfdir}}/X11/xinit @@ -216,7 +216,6 @@ Patch1000: 1000-Revert-getty-Pass-tty-to-use-by-agetty-via-stdin.patch # very few cases, some stuff might be broken in upstream and need to be fixed # quickly. But even in these cases, the patches are temporary and should be # removed as soon as a fix is merged by upstream. -Patch6000: 6000-Revert-tmpfiles-whenever-creating-an-inode-immediate.patch %description Systemd is a system and service manager, compatible with SysV and LSB From a8691e9d39d8164c06ff867d01d48ee156418a49d4b93cc1af8afbd1e91db216 Mon Sep 17 00:00:00 2001 From: Franck Bui Date: Fri, 9 Dec 2022 08:59:00 +0000 Subject: [PATCH 3/3] document that bsc#1204944 has been fixed during the merge of v252.3 OBS-URL: https://build.opensuse.org/package/show/Base:System/systemd?expand=0&rev=1335 --- systemd.changes | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/systemd.changes b/systemd.changes index 596e173a..c887dc75 100644 --- a/systemd.changes +++ b/systemd.changes @@ -17,6 +17,10 @@ Fri Dec 9 07:41:04 UTC 2022 - Franck Bui - Import commit 82898a14f5b0a965ba9c1efc1913fcdf29d446a8 (merge of v252.3) + It includes the following fixes: + + 9410eb20eb cryptsetup: retry TPM2 unseal operation if it fails with TPM2_RC_PCR_CHANGED (bsc#1204944) + For a complete list of changes, visit: https://github.com/openSUSE/systemd/compare/e7e931b07edd786dc6ca1dae6c23ff7b785f8efd...82898a14f5b0a965ba9c1efc1913fcdf29d446a8