mirror of
https://codeberg.org/guix/guix.git
synced 2025-10-02 02:15:12 +00:00
* gnu/packages/base.scm (glibc): Update to 2.41. (%glibc-patches): update it. (glibc/hurd)[sources]<patches>: Adjust it. * gnu/packages/patches/glibc-2.37-hurd-local-clock_gettime_MONOTONIC.patch: Rename to... glibc-2.41-hurd-local-clock_gettime_MONOTONIC.patch: ...this, and update. * gnu/packages/patches/glibc-2.28-ldd-x86_64.patch: Rename to ... * glibc-2.41-ldd-x86_64.patch: ...this, and update. * gnu/packages/patches/glibc-2.40-CVE-2025-0.patch, gnu/packages/patches/glibc-hurd64-fault.patch, gnu/packages/patches/glibc-hurd64-sgms-context.patch: Remove. * gnu/local.mk (dist_patch_DATA): Update accordingly. * gnu/packages/patches/glibc-2.41-hurd-local-clock_gettime_MONOTONIC.patch: Update for glibc-2.41. * gnu/packages/make-bootstrap.scm (glibc-for-bootstrap): Update it. * gnu/packages/patches/glibc-2.39-bootstrap-system.patch: Rename to... * glibc-2.41-bootstrap-system.patch: ...this, and update. * gnu/local.mk (dist_patch_DATA): Update accordingly. Change-Id: I51c12e3e8fa91dac340571e07a90d6220e0dc6ae
69 lines
2.2 KiB
Diff
69 lines
2.2 KiB
Diff
We want to allow builds in chroots that lack /bin/sh. Thus, system(3)
|
|
and popen(3) need to be tweaked to use the right shell. For the bootstrap
|
|
glibc, we just use whatever `sh' can be found in $PATH. The final glibc
|
|
instead uses the hard-coded absolute file name of `bash'.
|
|
|
|
In addition, status should be initialized to 0 and not -1.
|
|
|
|
Adapted to glibc-2.41.
|
|
|
|
diff --git a/libio/iopopen.c b/libio/iopopen.c
|
|
index ebc381ed7c..e0d3ed1bc3 100644
|
|
--- a/libio/iopopen.c
|
|
+++ b/libio/iopopen.c
|
|
@@ -106,8 +106,8 @@ spawn_process (posix_spawn_file_actions_t *fa, FILE *fp, const char *command,
|
|
}
|
|
}
|
|
|
|
- err = __posix_spawn (&((_IO_proc_file *) fp)->pid, _PATH_BSHELL, fa, NULL,
|
|
+ err = __posix_spawnp (&((_IO_proc_file *) fp)->pid, "sh", fa, NULL,
|
|
(char *const[]){ (char*) "sh", (char*) "-c", (char*) "--",
|
|
(char *) command, NULL }, __environ);
|
|
if (err != 0)
|
|
return err;
|
|
diff --git a/sysdeps/posix/system.c b/sysdeps/posix/system.c
|
|
index a03f478fc7..94da6facf3 100644
|
|
--- a/sysdeps/posix/system.c
|
|
+++ b/sysdeps/posix/system.c
|
|
@@ -101,7 +101,7 @@ cancel_handler (void *arg)
|
|
static int
|
|
do_system (const char *line)
|
|
{
|
|
- int status = -1;
|
|
+ int status = 0;
|
|
int ret;
|
|
pid_t pid;
|
|
struct sigaction sa;
|
|
@@ -145,7 +145,7 @@ do_system (const char *line)
|
|
__posix_spawnattr_setflags (&spawn_attr,
|
|
POSIX_SPAWN_SETSIGDEF | POSIX_SPAWN_SETSIGMASK);
|
|
|
|
- ret = __posix_spawn (&pid, SHELL_PATH, NULL, &spawn_attr,
|
|
+ ret = __posix_spawnp (&pid, SHELL_NAME, NULL, &spawn_attr,
|
|
(char *const[]){ (char *) SHELL_NAME,
|
|
(char *) "-c",
|
|
(char *) line, NULL },
|
|
|
|
--- a/include/spawn.h
|
|
+++ b/include/spawn.h
|
|
@@ -5,6 +5,9 @@
|
|
__typeof (posix_spawn) __posix_spawn;
|
|
libc_hidden_proto (__posix_spawn)
|
|
|
|
+__typeof (posix_spawnp) __posix_spawnp;
|
|
+libc_hidden_proto (__posix_spawnp)
|
|
+
|
|
__typeof (posix_spawn_file_actions_addclose)
|
|
__posix_spawn_file_actions_addclose attribute_hidden;
|
|
|
|
--- a/posix/spawnp.c
|
|
+++ b/posix/spawnp.c
|
|
@@ -31,6 +31,7 @@ __posix_spawnp (pid_t *pid, const char *file,
|
|
SPAWN_XFLAGS_USE_PATH);
|
|
}
|
|
versioned_symbol (libc, __posix_spawnp, posix_spawnp, GLIBC_2_15);
|
|
+libc_hidden_def (__posix_spawnp)
|
|
|
|
|
|
#if SHLIB_COMPAT (libc, GLIBC_2_2, GLIBC_2_15)
|
|
|