diff options
Diffstat (limited to 'sys-kernel/genkernel/files/genkernel-4.3.16-musl.patch')
-rw-r--r-- | sys-kernel/genkernel/files/genkernel-4.3.16-musl.patch | 297 |
1 files changed, 297 insertions, 0 deletions
diff --git a/sys-kernel/genkernel/files/genkernel-4.3.16-musl.patch b/sys-kernel/genkernel/files/genkernel-4.3.16-musl.patch new file mode 100644 index 000000000000..bdc45e941898 --- /dev/null +++ b/sys-kernel/genkernel/files/genkernel-4.3.16-musl.patch @@ -0,0 +1,297 @@ +https://bugs.gentoo.org/934773 +https://github.com/gentoo/genkernel/pull/62 + +From 553ea48d2983f6febd142b97c5b7230d87cda661 Mon Sep 17 00:00:00 2001 +From: orbea <orbea@riseup.net> +Date: Sun, 24 Nov 2024 07:33:09 -0800 +Subject: [PATCH 1/3] patches/lvm: add missing musl patches + +Gentoo-Issue: https://bugs.gentoo.org/934773 +Signed-off-by: orbea <orbea@riseup.net> +--- + .../lvm/2.03.22/lvm2-019-musl-basename.patch | 34 ++++++++++++ + .../lvm/2.03.22/lvm2-020-freopen-musl.patch | 54 +++++++++++++++++++ + 2 files changed, 88 insertions(+) + create mode 100644 patches/lvm/2.03.22/lvm2-019-musl-basename.patch + create mode 100644 patches/lvm/2.03.22/lvm2-020-freopen-musl.patch + +diff --git a/patches/lvm/2.03.22/lvm2-019-musl-basename.patch b/patches/lvm/2.03.22/lvm2-019-musl-basename.patch +new file mode 100644 +index 00000000..2dd9f8ff +--- /dev/null ++++ b/patches/lvm/2.03.22/lvm2-019-musl-basename.patch +@@ -0,0 +1,34 @@ ++https://bugs.gentoo.org/937239 ++https://github.com/lvmteam/lvm2/commit/f98d2ffe8753895c84160a7abce4223bd127cd9e ++ ++From f98d2ffe8753895c84160a7abce4223bd127cd9e Mon Sep 17 00:00:00 2001 ++From: Zdenek Kabelac <zkabelac@redhat.com> ++Date: Wed, 27 Mar 2024 00:28:14 +0100 ++Subject: [PATCH] device_id: use dm_basename ++ ++Avoid problems for other libc like muslc and use dm_basename. ++ ++Prototype for basename has been removed from string.h from latest musl [1] ++compilers e.g. clang-18 flags the absense of prototype as error. therefore ++include libgen.h for providing it. ++ ++[1] https://git.musl-libc.org/cgit/musl/commit/?id=725e17ed6dff4d0cd22487bb64470881e86a92e7 ++ ++Reported-by: Khem Raj <raj.khem@gmail.com> ++--- ++ lib/device/device_id.c | 2 +- ++ 1 file changed, 1 insertion(+), 1 deletion(-) ++ ++diff --git a/lib/device/device_id.c b/lib/device/device_id.c ++index 7d67a1cb7..200d39432 100644 ++--- a/lib/device/device_id.c +++++ b/lib/device/device_id.c ++@@ -740,7 +740,7 @@ static int _dev_read_sys_serial(struct cmd_context *cmd, struct device *dev, ++ int ret; ++ ++ /* /dev/vda to vda */ ++- base = basename(devname); +++ base = dm_basename(devname); ++ ++ /* vda1 to vda */ ++ for (i = 0; i < strlen(base); i++) { +diff --git a/patches/lvm/2.03.22/lvm2-020-freopen-musl.patch b/patches/lvm/2.03.22/lvm2-020-freopen-musl.patch +new file mode 100644 +index 00000000..2b3f0a91 +--- /dev/null ++++ b/patches/lvm/2.03.22/lvm2-020-freopen-musl.patch +@@ -0,0 +1,54 @@ ++From 4cf08811e112100a2b10c60047f3c537ad21d674 Mon Sep 17 00:00:00 2001 ++From: David Seifert <soap@gentoo.org> ++Date: Sat, 28 Jan 2023 14:22:42 +0100 ++Subject: [PATCH] Use `freopen()` on {stdin,stdout,stderr} ++ ++* ISO C does not guarantee that the standard streams are modifiable ++ lvalues. Glibc even calls out this behaviour as non-portable: ++ https://www.gnu.org/software/libc/manual/html_node/Standard-Streams.html ++--- a/lib/log/log.c +++++ b/lib/log/log.c ++@@ -208,7 +208,11 @@ int reopen_standard_stream(FILE **stream, const char *mode) ++ ++ _check_and_replace_standard_log_streams(old_stream, new_stream); ++ +++#ifdef __GLIBC__ ++ *stream = new_stream; +++#else +++ freopen(NULL, mode, *stream); +++#endif ++ return 1; ++ } ++ ++--- a/tools/lvmcmdline.c +++++ b/tools/lvmcmdline.c ++@@ -3422,7 +3422,7 @@ static int _check_standard_fds(void) ++ int err = is_valid_fd(STDERR_FILENO); ++ ++ if (!is_valid_fd(STDIN_FILENO) && ++- !(stdin = fopen(_PATH_DEVNULL, "r"))) { +++ !freopen(_PATH_DEVNULL, "r", stdin)) { ++ if (err) ++ perror("stdin stream open"); ++ else ++@@ -3432,7 +3432,7 @@ static int _check_standard_fds(void) ++ } ++ ++ if (!is_valid_fd(STDOUT_FILENO) && ++- !(stdout = fopen(_PATH_DEVNULL, "w"))) { +++ !freopen(_PATH_DEVNULL, "w", stdout)) { ++ if (err) ++ perror("stdout stream open"); ++ /* else no stdout */ ++@@ -3440,7 +3440,7 @@ static int _check_standard_fds(void) ++ } ++ ++ if (!is_valid_fd(STDERR_FILENO) && ++- !(stderr = fopen(_PATH_DEVNULL, "w"))) { +++ !freopen(_PATH_DEVNULL, "w", stderr)) { ++ printf("stderr stream open: %s\n", ++ strerror(errno)); ++ return 0; ++-- ++2.39.2 ++ + +From a9f818ab719c294a3bdd6b25730bb1b6ac6c2173 Mon Sep 17 00:00:00 2001 +From: orbea <orbea@riseup.net> +Date: Sun, 24 Nov 2024 07:33:50 -0800 +Subject: [PATCH 2/3] patches/kmod: add missing musl patch + +Signed-off-by: orbea <orbea@riseup.net> +--- + patches/kmod/31/kmod-31-musl-basename.patch | 113 ++++++++++++++++++++ + 1 file changed, 113 insertions(+) + create mode 100644 patches/kmod/31/kmod-31-musl-basename.patch + +diff --git a/patches/kmod/31/kmod-31-musl-basename.patch b/patches/kmod/31/kmod-31-musl-basename.patch +new file mode 100644 +index 00000000..f4839dad +--- /dev/null ++++ b/patches/kmod/31/kmod-31-musl-basename.patch +@@ -0,0 +1,113 @@ ++https://github.com/kmod-project/kmod/pull/32 ++ ++From 721ed6040c7aa47070faf6378c433089e178bd43 Mon Sep 17 00:00:00 2001 ++From: Khem Raj <raj.khem@gmail.com> ++Date: Sat, 9 Dec 2023 17:35:59 -0800 ++Subject: [PATCH] Use portable implementation for basename API ++ ++musl has removed the non-prototype declaration of basename from ++string.h [1] which now results in build errors with clang-17+ compiler ++ ++Implement GNU basename behavior using strchr which is portable across libcs ++ ++Fixes ++../git/tools/kmod.c:71:19: error: call to undeclared function 'basename'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration] ++71 | "Commands:\n", basename(argv[0])); ++| ^ ++ ++[1] https://git.musl-libc.org/cgit/musl/commit/?id=725e17ed6dff4d0cd22487bb64470881e86a92e7 ++ ++Suggested-by: Rich Felker ++ ++Signed-off-by: Khem Raj <raj.khem@gmail.com> ++--- a/libkmod/libkmod-config.c +++++ b/libkmod/libkmod-config.c ++@@ -794,7 +794,7 @@ static int conf_files_insert_sorted(struct kmod_ctx *ctx, ++ bool is_single = false; ++ ++ if (name == NULL) { ++- name = basename(path); +++ name = gnu_basename(path); ++ is_single = true; ++ } ++ ++--- a/shared/util.c +++++ b/shared/util.c ++@@ -172,9 +172,9 @@ char *modname_normalize(const char *modname, char buf[static PATH_MAX], size_t * ++ ++ char *path_to_modname(const char *path, char buf[static PATH_MAX], size_t *len) ++ { ++- char *modname; +++ const char *modname; ++ ++- modname = basename(path); +++ modname = gnu_basename(path); ++ if (modname == NULL || modname[0] == '\0') ++ return NULL; ++ ++--- a/shared/util.h +++++ b/shared/util.h ++@@ -5,6 +5,7 @@ ++ #include <stdbool.h> ++ #include <stdlib.h> ++ #include <stdio.h> +++#include <string.h> ++ #include <sys/types.h> ++ #include <sys/stat.h> ++ #include <time.h> ++@@ -76,6 +77,12 @@ do { \ ++ __p->__v = (val); \ ++ } while(0) ++ +++static _always_inline_ const char *gnu_basename(const char *s) +++{ +++ const char *p = strrchr(s, '/'); +++ return p ? p+1 : s; +++} +++ ++ static _always_inline_ unsigned int ALIGN_POWER2(unsigned int u) ++ { ++ return 1 << ((sizeof(u) * 8) - __builtin_clz(u - 1)); ++--- a/testsuite/testsuite.c +++++ b/testsuite/testsuite.c ++@@ -70,7 +70,7 @@ static void help(void) ++ ++ printf("Usage:\n" ++ "\t%s [options] <test>\n" ++- "Options:\n", basename(progname)); +++ "Options:\n", gnu_basename(progname)); ++ ++ for (itr = options, itr_short = options_short; ++ itr->name != NULL; itr++, itr_short++) ++--- a/tools/depmod.c +++++ b/tools/depmod.c ++@@ -762,7 +762,7 @@ static int cfg_files_insert_sorted(struct cfg_file ***p_files, size_t *p_n_files ++ if (name != NULL) ++ namelen = strlen(name); ++ else { ++- name = basename(dir); +++ name = gnu_basename(dir); ++ namelen = strlen(name); ++ dirlen -= namelen + 1; ++ } ++--- a/tools/kmod.c +++++ b/tools/kmod.c ++@@ -68,7 +68,7 @@ static int kmod_help(int argc, char *argv[]) ++ "Options:\n" ++ "\t-V, --version show version\n" ++ "\t-h, --help show this help\n\n" ++- "Commands:\n", basename(argv[0])); +++ "Commands:\n", gnu_basename(argv[0])); ++ ++ for (i = 0; i < ARRAY_SIZE(kmod_cmds); i++) { ++ if (kmod_cmds[i]->help != NULL) { ++@@ -156,7 +156,7 @@ static int handle_kmod_compat_commands(int argc, char *argv[]) ++ const char *cmd; ++ size_t i; ++ ++- cmd = basename(argv[0]); +++ cmd = gnu_basename(argv[0]); ++ ++ for (i = 0; i < ARRAY_SIZE(kmod_compat_cmds); i++) { ++ if (streq(kmod_compat_cmds[i]->name, cmd)) ++ + +From 1c7bf8a58143807134f6427ab3d7e063df3038e6 Mon Sep 17 00:00:00 2001 +From: orbea <orbea@riseup.net> +Date: Sun, 24 Nov 2024 07:34:47 -0800 +Subject: [PATCH 3/3] Bump eudev to v3.2.14 + +Update to a version that builds with musl. + +Signed-off-by: orbea <orbea@riseup.net> +--- + .../eudev-3.2.14-static.patch} | 17 ++++++++--------- + 1 file changed, 8 insertions(+), 9 deletions(-) + rename patches/eudev/{3.2.10/eudev-3.2.10-static.patch => 3.2.14/eudev-3.2.14-static.patch} (81%) + +diff --git a/patches/eudev/3.2.10/eudev-3.2.10-static.patch b/patches/eudev/3.2.14/eudev-3.2.14-static.patch +similarity index 81% +rename from patches/eudev/3.2.10/eudev-3.2.10-static.patch +rename to patches/eudev/3.2.14/eudev-3.2.14-static.patch +index fc36b547..88bc1e15 100644 +--- a/patches/eudev/3.2.10/eudev-3.2.10-static.patch ++++ b/patches/eudev/3.2.14/eudev-3.2.14-static.patch +@@ -1,14 +1,14 @@ + --- a/configure.ac + +++ b/configure.ac +-@@ -261,7 +261,7 @@ AC_ARG_ENABLE(kmod, AS_HELP_STRING([--disable-kmod], [disable loadable modules s ++@@ -252,7 +252,7 @@ AC_ARG_ENABLE(kmod, AS_HELP_STRING([--disable-kmod], [disable loadable modules s + if test "x$enable_kmod" != "xno"; then +- PKG_CHECK_EXISTS([ libkmod ], have_kmod=yes, have_kmod=no) +- if test "x$have_kmod" = "xyes"; then +-- PKG_CHECK_MODULES(KMOD, [ libkmod >= 15 ], +-+ PKG_CHECK_MODULES_STATIC(KMOD, [ libkmod >= 15 ], +- [AC_DEFINE(HAVE_KMOD, 1, [Define if kmod is available])], +- AC_MSG_ERROR([*** kmod version >= 15 not found])) +- fi ++ PKG_CHECK_EXISTS([ libkmod ], have_kmod=yes, have_kmod=no) ++ if test "x$have_kmod" = "xyes"; then ++- PKG_CHECK_MODULES(KMOD, [ libkmod >= 15 ], +++ PKG_CHECK_MODULES_STATIC(KMOD, [ libkmod >= 15 ], ++ [AC_DEFINE(HAVE_KMOD, 1, [Define if kmod is available])], ++ AC_MSG_ERROR([*** kmod version >= 15 not found])) ++ fi + --- a/src/ata_id/Makefile.am + +++ b/src/ata_id/Makefile.am + @@ -11,6 +11,8 @@ udevlibexec_PROGRAMS = \ +@@ -94,4 +94,3 @@ + v4l_id_LDADD = \ + $(top_builddir)/src/libudev/libudev-private.la \ + $(top_builddir)/src/udev/libudev-core.la +- |