elogind: update to 252.9.

This commit is contained in:
André Cerqueira 2023-07-05 20:28:51 +01:00 committed by Andrew J. Hesford
parent 08c5e59809
commit 571c27e513
16 changed files with 402 additions and 101 deletions

View File

@ -0,0 +1,26 @@
Upstream:no
Our musl version doesn't expose the SEEK_DATA and SEEK_HOLE in `unisted.h`...
Only version >= 1.2.3 do that.
---
src/shared/copy.h | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/src/shared/copy.h b/src/shared/copy.h
index a34a87c..d258afc 100644
--- a/src/shared/copy.h
+++ b/src/shared/copy.h
@@ -79,3 +79,11 @@ static inline int copy_rights(int fdf, int fdt) {
}
int copy_xattr(int fdf, int fdt, CopyFlags copy_flags);
#endif // 0
+
+#ifndef SEEK_DATA
+#define SEEK_DATA 3
+#endif
+
+#ifndef SEEK_HOLE
+#define SEEK_HOLE 4
+#endif
--
2.42.0

View File

@ -0,0 +1,32 @@
Upstream: no
Source: https://raw.githubusercontent.com/chimera-linux/cports/81f0a3c25df2a841c2d99d752e60296062bf7543/main/elogind/patches/getdents.patch
From dab02796780f00d689cc1c7a0ba81abe7c5f28d0 Mon Sep 17 00:00:00 2001
From: Khem Raj <raj.khem@gmail.com>
Date: Fri, 21 Jan 2022 15:15:11 -0800
Subject: [PATCH] pass correct parameters to getdents64
Fixes musl system only
../git/src/basic/recurse-dir.c:57:40: error: incompatible pointer types passing 'uint8_t *' (aka 'unsigned char *') to parameter of type 'struct dirent *' [-Werror,-Wincompatible-pointer-types]
n = getdents64(dir_fd, (uint8_t*) de->buffer + de->buffer_size, bs - de->buffer_size);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
../git/src/basic/stat-util.c:102:28: error: incompatible pointer types passing 'union (unnamed union at ../git/src/basic/stat-util.c:78:9) *' to parameter of type 'struct dirent *' [-Werror,-Wincompatible-pointer-types]
n = getdents64(fd, &buffer, sizeof(buffer));
diff --git a/src/basic/recurse-dir.c b/src/basic/recurse-dir.c
index d16ca98..0480a69 100644
--- a/src/basic/recurse-dir.c
+++ b/src/basic/recurse-dir.c
@@ -54,7 +54,11 @@ int readdir_all(int dir_fd,
bs = MIN(MALLOC_SIZEOF_SAFE(de) - offsetof(DirectoryEntries, buffer), (size_t) SSIZE_MAX);
assert(bs > de->buffer_size);
+ #ifdef __GLIBC__
n = getdents64(dir_fd, (uint8_t*) de->buffer + de->buffer_size, bs - de->buffer_size);
+ #else
+ n = getdents(dir_fd, (struct dirent*)((uint8_t*) de->buffer + de->buffer_size), bs - de->buffer_size);
+ #endif
if (n < 0)
return -errno;
if (n == 0)

View File

@ -0,0 +1,12 @@
diff --git a/src/shared/user-record-nss.h b/src/shared/user-record-nss.h
index 7a41be7..3a970a6 100644
--- a/src/shared/user-record-nss.h
+++ b/src/shared/user-record-nss.h
@@ -2,7 +2,6 @@
#pragma once
#include <grp.h>
-#include <gshadow.h>
#include <pwd.h>
#include <shadow.h>

View File

@ -10,4 +10,3 @@
+#define GID_NOBODY ((gid_t) 99U) +#define GID_NOBODY ((gid_t) 99U)
#define ETC_PASSWD_LOCK_PATH "/etc/.pwd.lock" #define ETC_PASSWD_LOCK_PATH "/etc/.pwd.lock"

View File

@ -1,11 +0,0 @@
--- a/src/basic/missing_syscall.h 2021-01-15 08:12:02.000000000 +0100
+++ b/src/basic/missing_syscall.h 2021-02-24 07:20:32.026355819 +0100
@@ -11,7 +11,7 @@
#include <sys/wait.h>
#include <unistd.h>
-#ifdef ARCH_MIPS
+#if defined(_MIPSEL) || defined(_MIPSEB)
#include <asm/sgidefs.h>
#endif

View File

@ -1,27 +0,0 @@
commit 2b09e13f7aec13105380d9d9fddc96ae51911b0c
Author: Daniel Kolesa <daniel@octaforge.org>
Date: Sat Dec 18 02:53:26 2021 +0100
reenable polkit
diff --git a/meson.build b/meson.build
index 72825a2..b14cb64 100644
--- a/meson.build
+++ b/meson.build
@@ -1155,15 +1155,6 @@ if want_polkit != 'false' and not skip_deps
message('Old polkit detected, will install pkla files')
install_polkit_pkla = true
endif
-#if 1 /// Disable polkit completely if libpolkit is not there. See elogind issue #167
- if not libpolkit.found()
- if want_polkit != 'auto'
- error('Polkit requested but libpolkit was not found.')
- endif
- install_polkit = false
- want_polkit = false
- endif
-#endif // 1
endif
conf.set10('ENABLE_POLKIT', install_polkit)

View File

@ -1,25 +0,0 @@
From 0ce8ef86e8bfc872b40bc090fea9873fa1f51836 Mon Sep 17 00:00:00 2001
From: q66 <daniel@octaforge.org>
Date: Thu, 21 Jan 2021 22:22:28 +0100
Subject: [PATCH] fix ppc64 arch tuple
---
src/basic/architecture.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git src/basic/architecture.h src/basic/architecture.h
index 620b522..3ea6e52 100644
--- a/src/basic/architecture.h
+++ b/src/basic/architecture.h
@@ -77,7 +77,7 @@ int uname_architecture(void);
#elif defined(__powerpc64__)
# if __BYTE_ORDER == __BIG_ENDIAN
# define native_architecture() ARCHITECTURE_PPC64
-# define LIB_ARCH_TUPLE "ppc64-linux-gnu"
+# define LIB_ARCH_TUPLE "powerpc64-linux-gnu"
# define SECONDARY_ARCHITECTURE ARCHITECTURE_PPC
# else
# define native_architecture() ARCHITECTURE_PPC64_LE
--
2.30.0

View File

@ -1,25 +0,0 @@
From 836f3efb84a703b3594906572a54616d25cecf5e Mon Sep 17 00:00:00 2001
From: q66 <daniel@octaforge.org>
Date: Thu, 21 Jan 2021 21:59:12 +0100
Subject: [PATCH] add ppcle arch tuple
---
src/basic/architecture.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git src/basic/architecture.h src/basic/architecture.h
index 620b522..afdff7a 100644
--- a/src/basic/architecture.h
+++ b/src/basic/architecture.h
@@ -94,7 +94,7 @@ int uname_architecture(void);
# endif
# else
# define native_architecture() ARCHITECTURE_PPC_LE
-# error "Missing LIB_ARCH_TUPLE for PPCLE"
+# define LIB_ARCH_TUPLE "powerpcle-linux-gnu"
# endif
#elif defined(__ia64__)
# define native_architecture() ARCHITECTURE_IA64
--
2.30.0

View File

@ -0,0 +1,14 @@
diff --git a/src/basic/rlimit-util.c b/src/basic/rlimit-util.c
index afd74ac..3a731f4 100644
--- a/src/basic/rlimit-util.c
+++ b/src/basic/rlimit-util.c
@@ -44,7 +44,7 @@ int setrlimit_closest(int resource, const struct rlimit *rlim) {
fixed.rlim_max == highest.rlim_max)
return 0;
- log_debug("Failed at setting rlimit " RLIM_FMT " for resource RLIMIT_%s. Will attempt setting value " RLIM_FMT " instead.", rlim->rlim_max, rlimit_to_string(resource), fixed.rlim_max);
+ log_debug("Failed at setting rlimit %ju for resource RLIMIT_%s. Will attempt setting value %ju instead.", (uintmax_t)rlim->rlim_max, rlimit_to_string(resource), (uintmax_t)fixed.rlim_max);
return RET_NERRNO(setrlimit(resource, &fixed));
}

View File

@ -0,0 +1,42 @@
Patch-Source: https://github.com/elogind/elogind/issues/258
--
diff --git a/meson.build b/meson.build
index 694a2fd..a575f69 100644
--- a/meson.build
+++ b/meson.build
@@ -2903,7 +2903,7 @@ executable('elogind',
dependencies : [threads,
libacl,
libudev],
- install_rpath : rootlibexecdir,
+ install_rpath : rootpkglibdir,
install : true,
install_dir : rootlibexecdir)
@@ -2913,7 +2913,7 @@ exe = executable('loginctl',
link_with : [libshared],
dependencies : [threads,
libudev],
- install_rpath : rootlibexecdir,
+ install_rpath : rootpkglibdir,
install : true,
install_dir : rootbindir)
public_programs += [exe]
@@ -2923,7 +2923,7 @@ exe = executable('elogind-inhibit',
include_directories : includes,
link_with : [libshared],
dependencies : [threads],
- install_rpath : rootlibexecdir,
+ install_rpath : rootpkglibdir,
install : true,
install_dir : rootbindir)
public_programs += [exe]
@@ -4283,7 +4283,7 @@ executable('elogind-uaccess-command',
libshared],
dependencies: [libacl,
libudev],
- install_rpath : rootlibexecdir,
+ install_rpath : rootpkglibdir,
install : true,
install_dir : rootlibexecdir)
#endif // 0

View File

@ -0,0 +1,12 @@
diff --git a/src/basic/async.h b/src/basic/async.h
index cf80acf..d22e77d 100644
--- a/src/basic/async.h
+++ b/src/basic/async.h
@@ -2,6 +2,7 @@
#pragma once
#include <sys/types.h>
+#include <signal.h>
#include "macro.h"

View File

@ -0,0 +1,30 @@
Upstream: no, musl only
Source: https://raw.githubusercontent.com/chimera-linux/cports/81f0a3c25df2a841c2d99d752e60296062bf7543/main/elogind/patches/statx.patch
diff --git a/src/basic/mountpoint-util.c b/src/basic/mountpoint-util.c
index ab8744b..59ff466 100644
--- a/src/basic/mountpoint-util.c
+++ b/src/basic/mountpoint-util.c
@@ -11,7 +11,7 @@
//#include "filesystems.h"
#include "fs-util.h"
#include "missing_stat.h"
-//#include "missing_syscall.h"
+#include "missing_syscall.h"
//#include "mkdir.h"
#include "mountpoint-util.h"
#include "nulstr-util.h"
diff --git a/src/basic/stat-util.c b/src/basic/stat-util.c
index d8e0693..f8324ed 100644
--- a/src/basic/stat-util.c
+++ b/src/basic/stat-util.c
@@ -18,7 +18,7 @@
#include "macro.h"
//#include "missing_fs.h"
#include "missing_magic.h"
-//#include "missing_syscall.h"
+#include "missing_syscall.h"
#include "nulstr-util.h"
//#include "parse-util.h"
#include "stat-util.h"

View File

@ -0,0 +1,90 @@
fix strerror_r use instead of whatever this define is meant to be doing
--
From 0542d27ebbb250c09bdcfcf9f2ea3d27426fe522 Mon Sep 17 00:00:00 2001
From: Chen Qi <Qi.Chen@windriver.com>
Date: Tue, 10 Jul 2018 15:40:17 +0800
Subject: [PATCH] distinguish XSI-compliant strerror_r from GNU-specifi
strerror_r
XSI-compliant strerror_r and GNU-specifi strerror_r are different.
int strerror_r(int errnum, char *buf, size_t buflen);
/* XSI-compliant */
char *strerror_r(int errnum, char *buf, size_t buflen);
/* GNU-specific */
We need to distinguish between them. Otherwise, we'll get an int value
assigned to (char *) variable, resulting in segment fault.
Upstream-Status: Inappropriate [musl specific]
Signed-off-by: Chen Qi <Qi.Chen@windriver.com>
---
src/libsystemd/sd-bus/bus-error.c | 5 +++++
src/libsystemd/sd-journal/journal-send.c | 5 +++++
2 files changed, 10 insertions(+)
diff --git a/src/basic/musl_missing.h b/src/basic/musl_missing.h
index 41c66c9..a2e1d7e 100644
--- a/src/basic/musl_missing.h
+++ b/src/basic/musl_missing.h
@@ -26,8 +26,6 @@ void elogind_set_program_name(const char* pcall);
#include <unistd.h>
#include <pthread.h> /* for pthread_atfork */
-#define strerror_r(e, m, k) (strerror_r(e, m, k) < 0 ? strdup("strerror_r() failed") : m);
-
/*
* Possibly TODO according to http://man7.org/linux/man-pages/man3/getenv.3.html
* + test if the process's effective user ID does not match its real user ID or
diff --git a/src/libelogind/sd-bus/bus-error.c b/src/libelogind/sd-bus/bus-error.c
index 4d687cf..1459396 100644
--- a/src/libelogind/sd-bus/bus-error.c
+++ b/src/libelogind/sd-bus/bus-error.c
@@ -409,7 +409,12 @@ static void bus_error_strerror(sd_bus_error *e, int error) {
return;
errno = 0;
+#ifndef __GLIBC__
+ strerror_r(error, m, k);
+ x = m;
+#else
x = strerror_r(error, m, k);
+#endif
if (errno == ERANGE || strlen(x) >= k - 1) {
free(m);
k *= 2;
@@ -594,8 +599,12 @@ const char* _bus_error_message(const sd_bus_error *e, int error, char buf[static
if (e && e->message)
return e->message;
-
+#ifndef __GLIBC__
+ strerror_r(abs(error), buf, ERRNO_BUF_LEN);
+ return buf;
+#else
return strerror_r(abs(error), buf, ERRNO_BUF_LEN);
+#endif
}
static bool map_ok(const sd_bus_error_map *map) {
diff --git a/src/libelogind/sd-journal/journal-send.c b/src/libelogind/sd-journal/journal-send.c
index 4010197..1d49868 100644
--- a/src/libelogind/sd-journal/journal-send.c
+++ b/src/libelogind/sd-journal/journal-send.c
@@ -444,7 +444,12 @@ static int fill_iovec_perror_and_send(const char *message, int skip, struct iove
char* j;
errno = 0;
+#ifndef __GLIBC__
+ strerror_r(_saved_errno_, buffer + 8 + k, n - 8 - k);
+ j = buffer + 8 + k;
+#else
j = strerror_r(_saved_errno_, buffer + 8 + k, n - 8 - k);
+#endif
if (errno == 0) {
char error[STRLEN("ERRNO=") + DECIMAL_STR_MAX(int) + 1];

View File

@ -0,0 +1,43 @@
From f66b5c802ce0a3310f5580cfc1b02446f8087568 Mon Sep 17 00:00:00 2001
From: Khem Raj <raj.khem@gmail.com>
Date: Mon, 23 Jan 2023 23:39:46 -0800
Subject: [PATCH] errno-util: Make STRERROR portable for musl
Sadly, systemd has decided to use yet another GNU extention in a macro
lets make this such that we can use XSI compliant strerror_r() for
non-glibc hosts
Upstream-Status: Inappropriate [musl specific]
Signed-off-by: Khem Raj <raj.khem@gmail.com>
---
src/basic/errno-util.h | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
diff --git a/src/basic/errno-util.h b/src/basic/errno-util.h
index 091f99c590..eb5c1f9961 100644
--- a/src/basic/errno-util.h
+++ b/src/basic/errno-util.h
@@ -14,8 +14,16 @@
* https://stackoverflow.com/questions/34880638/compound-literal-lifetime-and-if-blocks
*
* Note that we use the GNU variant of strerror_r() here. */
-#define STRERROR(errnum) strerror_r(abs(errnum), (char[ERRNO_BUF_LEN]){}, ERRNO_BUF_LEN)
-
+static inline const char * STRERROR(int errnum);
+
+static inline const char * STRERROR(int errnum) {
+#ifdef __GLIBC__
+ return strerror_r(abs(errnum), (char[ERRNO_BUF_LEN]){}, ERRNO_BUF_LEN);
+#else
+ static __thread char buf[ERRNO_BUF_LEN];
+ return strerror_r(abs(errnum), buf, ERRNO_BUF_LEN) ? "unknown error" : buf;
+#endif
+}
/* A helper to print an error message or message for functions that return 0 on EOF.
* Note that we can't use ({ … }) to define a temporary variable, so errnum is
* evaluated twice. */
--
2.39.1

View File

@ -0,0 +1,89 @@
Source: https://raw.githubusercontent.com/chimera-linux/cports/81f0a3c25df2a841c2d99d752e60296062bf7543/main/elogind/patches/tests.patch
--
diff --git a/src/libelogind/sd-bus/test-bus-error.c b/src/libelogind/sd-bus/test-bus-error.c
index 4956dd7..d60ae0a 100644
--- a/src/libelogind/sd-bus/test-bus-error.c
+++ b/src/libelogind/sd-bus/test-bus-error.c
@@ -223,6 +223,8 @@ TEST(sd_bus_error_set_errnof) {
_cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
_cleanup_free_ char *str = NULL;
+ return;
+
assert_se(sd_bus_error_set_errnof(NULL, 0, NULL) == 0);
assert_se(sd_bus_error_set_errnof(NULL, ENOANO, NULL) == -ENOANO);
diff --git a/src/libelogind/sd-device/test-sd-device-thread.c b/src/libelogind/sd-device/test-sd-device-thread.c
index 644f3c2..c0c17f2 100644
--- a/src/libelogind/sd-device/test-sd-device-thread.c
+++ b/src/libelogind/sd-device/test-sd-device-thread.c
@@ -30,6 +30,8 @@ int main(int argc, char *argv[]) {
const char *key, *value;
int r;
+ return 0;
+
r = sd_device_new_from_syspath(&loopback, "/sys/class/net/lo");
if (r < 0)
return handle_error_errno(r, "Failed to create loopback device object");
diff --git a/src/test/test-cgroup.c b/src/test/test-cgroup.c
index 4b70a85..5a0eb51 100644
--- a/src/test/test-cgroup.c
+++ b/src/test/test-cgroup.c
@@ -50,6 +50,9 @@ TEST(cg_create) {
log_tests_skipped("cgroup not mounted");
return;
}
+
+ return;
+
assert_se(r >= 0);
_cleanup_free_ char *here = NULL;
diff --git a/src/test/test-hostname-util.c b/src/test/test-hostname-util.c
index 7c4f693..dbb03dc 100644
--- a/src/test/test-hostname-util.c
+++ b/src/test/test-hostname-util.c
@@ -25,8 +25,10 @@ TEST(hostname_is_valid) {
assert_se(!hostname_is_valid(".foobar", 0));
assert_se(!hostname_is_valid("foo..bar", 0));
assert_se(!hostname_is_valid("foo.bar..", 0));
+#if 0
assert_se(!hostname_is_valid("xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", 0));
assert_se(!hostname_is_valid("au-xph5-rvgrdsb5hcxc-47et3a5vvkrc-server-wyoz4elpdpe3.openstack.local", 0));
+#endif
assert_se(hostname_is_valid("foobar", VALID_HOSTNAME_TRAILING_DOT));
assert_se(hostname_is_valid("foobar.com", VALID_HOSTNAME_TRAILING_DOT));
@@ -43,7 +45,9 @@ TEST(hostname_is_valid) {
assert_se(!hostname_is_valid(".foobar", VALID_HOSTNAME_TRAILING_DOT));
assert_se(!hostname_is_valid("foo..bar", VALID_HOSTNAME_TRAILING_DOT));
assert_se(!hostname_is_valid("foo.bar..", VALID_HOSTNAME_TRAILING_DOT));
+#if 0
assert_se(!hostname_is_valid("xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", VALID_HOSTNAME_TRAILING_DOT));
+#endif
}
#if 0 /// UNNEEDED by elogind
diff --git a/src/test/test-mountpoint-util.c b/src/test/test-mountpoint-util.c
index 75d4aa1..f2ffd86 100644
--- a/src/test/test-mountpoint-util.c
+++ b/src/test/test-mountpoint-util.c
@@ -134,6 +134,7 @@ TEST(path_is_mount_point) {
assert_se(path_is_mount_point("//", NULL, AT_SYMLINK_FOLLOW) > 0);
assert_se(path_is_mount_point("//", NULL, 0) > 0);
+#if 0
assert_se(path_is_mount_point("/proc", NULL, AT_SYMLINK_FOLLOW) > 0);
assert_se(path_is_mount_point("/proc", NULL, 0) > 0);
assert_se(path_is_mount_point("/proc/", NULL, AT_SYMLINK_FOLLOW) > 0);
@@ -148,6 +149,7 @@ TEST(path_is_mount_point) {
assert_se(path_is_mount_point("/sys", NULL, 0) > 0);
assert_se(path_is_mount_point("/sys/", NULL, AT_SYMLINK_FOLLOW) > 0);
assert_se(path_is_mount_point("/sys/", NULL, 0) > 0);
+#endif
/* we'll create a hierarchy of different kinds of dir/file/link
* layouts:

View File

@ -1,24 +1,24 @@
# Template file for 'elogind' # Template file for 'elogind'
pkgname=elogind pkgname=elogind
version=246.10 version=252.9
revision=3 revision=1
build_style=meson build_style=meson
configure_args="-Dcgroup-controller=elogind -Dhalt-path=/usr/bin/halt configure_args="-Dcgroup-controller=elogind -Ddefault-hierarchy=legacy
-Drootlibexecdir=/usr/libexec/elogind -Dreboot-path=/usr/bin/reboot -Ddefault-kill-user-processes=false -Dhalt-path=/usr/bin/halt
-Dkexec-path=/usr/bin/kexec -Ddefault-hierarchy=legacy -Dkexec-path=/usr/bin/kexec -Dman=true -Dpolkit=true
-Ddefault-kill-user-processes=false -Dman=true -Dreboot-path=/usr/bin/reboot -Drootlibdir=/usr/lib
-Dpolkit=true" -Drootlibexecdir=/usr/libexec/elogind"
hostmakedepends="docbook-xsl gettext-devel gperf intltool libxslt m4 hostmakedepends="docbook-xsl gettext-devel glib-devel gperf intltool libxslt
pkg-config shadow glib-devel" m4 pkg-config python3-Jinja2 shadow"
makedepends="acl-devel eudev-libudev-devel gettext-devel libglib-devel libcap-devel makedepends="acl-devel eudev-libudev-devel gettext-devel libcap-devel
libseccomp-devel pam-devel" libglib-devel libseccomp-devel pam-devel"
depends="dbus" depends="dbus"
short_desc="Standalone logind fork" short_desc="Standalone logind fork"
maintainer="Enno Boland <gottox@voidlinux.org>" maintainer="Enno Boland <gottox@voidlinux.org>"
license="GPL-2.0-or-later, LGPL-2.0-or-later" license="GPL-2.0-or-later, LGPL-2.0-or-later"
homepage="https://github.com/elogind/elogind" homepage="https://github.com/elogind/elogind"
distfiles="https://github.com/${pkgname}/${pkgname}/archive/v${version}.tar.gz" distfiles="https://github.com/${pkgname}/${pkgname}/archive/v${version}.tar.gz"
checksum=c490dc158c8f5bca8d00ecfcc7ad5af24d1c7b9e59990a0b3b1323996221a922 checksum=7af8caa8225a406e77fb99c9f33dba5e1f0a94f0e1277c9d91dcfc016f116d85
conf_files="/etc/elogind/*.conf" conf_files="/etc/elogind/*.conf"
# tests fail differently due to containerization and kernel features # tests fail differently due to containerization and kernel features
make_check=ci-skip make_check=ci-skip