[gnome-build-meta/abderrahim/40-beta: 7/10] sdk/glib.bst: patch to fix crashes with subprocesses
- From: Abderrahim Kitouni <akitouni src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-build-meta/abderrahim/40-beta: 7/10] sdk/glib.bst: patch to fix crashes with subprocesses
- Date: Tue, 23 Feb 2021 09:16:35 +0000 (UTC)
commit 3dfbf489d61e7be950bad67dac4eef4f1e7f48b1
Author: Abderrahim Kitouni <akitouni gnome org>
Date: Sat Feb 20 18:45:42 2021 +0100
sdk/glib.bst: patch to fix crashes with subprocesses
elements/sdk/glib.bst | 2 +
files/glib/1958.patch | 194 ++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 196 insertions(+)
---
diff --git a/elements/sdk/glib.bst b/elements/sdk/glib.bst
index 632e0d5d..a52272ec 100644
--- a/elements/sdk/glib.bst
+++ b/elements/sdk/glib.bst
@@ -4,6 +4,8 @@ sources:
- kind: tar
url: gnome_downloads:glib/2.67/glib-2.67.4.tar.xz
ref: 8d87b962032dadfcae8df62d248aa91fed2c7a43faf2c6d8b9107eb6c50e5b14
+- kind: patch
+ path: files/glib/1958.patch
build-depends:
- sdk/gtk-doc.bst
diff --git a/files/glib/1958.patch b/files/glib/1958.patch
new file mode 100644
index 00000000..11d342cf
--- /dev/null
+++ b/files/glib/1958.patch
@@ -0,0 +1,194 @@
+From 1e74c52a6349c9c4f265b9b89fffc32730b9cd24 Mon Sep 17 00:00:00 2001
+From: Philip Withnall <pwithnall endlessos org>
+Date: Fri, 19 Feb 2021 18:19:53 +0000
+Subject: [PATCH 1/3] gsubprocesslauncher: Improve documentation formatting
+ slightly
+
+Signed-off-by: Philip Withnall <pwithnall endlessos org>
+---
+ gio/gsubprocesslauncher.c | 8 ++++----
+ 1 file changed, 4 insertions(+), 4 deletions(-)
+
+diff --git a/gio/gsubprocesslauncher.c b/gio/gsubprocesslauncher.c
+index b7257f453..16c47d542 100644
+--- a/gio/gsubprocesslauncher.c
++++ b/gio/gsubprocesslauncher.c
+@@ -596,16 +596,16 @@ g_subprocess_launcher_take_stderr_fd (GSubprocessLauncher *self,
+ * @target_fd: Target descriptor for child process
+ *
+ * Transfer an arbitrary file descriptor from parent process to the
+- * child. This function takes "ownership" of the fd; it will be closed
++ * child. This function takes ownership of the @source_fd; it will be closed
+ * in the parent when @self is freed.
+ *
+ * By default, all file descriptors from the parent will be closed.
+- * This function allows you to create (for example) a custom pipe() or
+- * socketpair() before launching the process, and choose the target
++ * This function allows you to create (for example) a custom `pipe()` or
++ * `socketpair()` before launching the process, and choose the target
+ * descriptor in the child.
+ *
+ * An example use case is GNUPG, which has a command line argument
+- * --passphrase-fd providing a file descriptor number where it expects
++ * `--passphrase-fd` providing a file descriptor number where it expects
+ * the passphrase to be written.
+ */
+ void
+--
+GitLab
+
+
+From 55a75590d0c7e703f32513cc409d6e20a7b761ea Mon Sep 17 00:00:00 2001
+From: Philip Withnall <pwithnall endlessos org>
+Date: Fri, 19 Feb 2021 18:20:25 +0000
+Subject: [PATCH 2/3] =?UTF-8?q?gsubprocesslauncher:=20Don=E2=80=99t=20clos?=
+ =?UTF-8?q?e=20target=20FDs=20in=20close()=20method?=
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+This is a regression introduced in commit 67a589e505311. Previously, the
+source/target FD pairs were stored in `needdup_fd_assignments`, in
+consecutive entries, so source FDs had even indices and target FDs had
+odd indices.
+
+I didn’t notice that the array index was being incremented by 2 when
+closing FDs, when porting from the old code. So previously the code was
+only closing the source FDs; after the port, it was closing source and
+target FDs.
+
+That’s incorrect, as the target FDs are just integers in the parent
+process. It’s only in the child process where they are actually FDs —
+and `g_subprocess_launcher_close()` is never called in the child
+process.
+
+This resulted in some strange misbehaviours in any process which used
+`g_subprocess_launcher_take_fd()` with target FDs which could have
+possibly aliased with other FDs in the parent process (and which weren’t
+equal to their mapped source FDs).
+
+Thanks to Olivier Fourdan for the detailed bug report.
+
+Signed-off-by: Philip Withnall <pwithnall endlessos org>
+
+Fixes: #2332
+---
+ gio/gsubprocesslauncher-private.h | 4 ++--
+ gio/gsubprocesslauncher.c | 8 ++++----
+ 2 files changed, 6 insertions(+), 6 deletions(-)
+
+diff --git a/gio/gsubprocesslauncher-private.h b/gio/gsubprocesslauncher-private.h
+index f8a6516c5..d6fe0d784 100644
+--- a/gio/gsubprocesslauncher-private.h
++++ b/gio/gsubprocesslauncher-private.h
+@@ -42,8 +42,8 @@ struct _GSubprocessLauncher
+ gint stderr_fd;
+ gchar *stderr_path;
+
+- GArray *source_fds;
+- GArray *target_fds; /* always the same length as source_fds */
++ GArray *source_fds; /* GSubprocessLauncher has ownership of the FD elements */
++ GArray *target_fds; /* always the same length as source_fds; elements are just integers and not FDs in
this process */
+ gboolean closed_fd;
+
+ GSpawnChildSetupFunc child_setup_func;
+diff --git a/gio/gsubprocesslauncher.c b/gio/gsubprocesslauncher.c
+index 16c47d542..a1c65e947 100644
+--- a/gio/gsubprocesslauncher.c
++++ b/gio/gsubprocesslauncher.c
+@@ -661,11 +661,11 @@ g_subprocess_launcher_close (GSubprocessLauncher *self)
+ g_assert (self->target_fds != NULL);
+ g_assert (self->source_fds->len == self->target_fds->len);
+
++ /* Note: Don’t close the target_fds, as they’re only valid FDs in the
++ * child process. This code never executes in the child process. */
+ for (i = 0; i < self->source_fds->len; i++)
+- {
+- (void) close (g_array_index (self->source_fds, int, i));
+- (void) close (g_array_index (self->target_fds, int, i));
+- }
++ (void) close (g_array_index (self->source_fds, int, i));
++
+ g_clear_pointer (&self->source_fds, g_array_unref);
+ g_clear_pointer (&self->target_fds, g_array_unref);
+ }
+--
+GitLab
+
+
+From 50cf90dc562d10efa3288357202e8cc04571292c Mon Sep 17 00:00:00 2001
+From: Philip Withnall <pwithnall endlessos org>
+Date: Fri, 19 Feb 2021 18:09:42 +0000
+Subject: [PATCH 3/3] =?UTF-8?q?tests:=20Test=20g=5Fsubprocess=5Flauncher?=
+ =?UTF-8?q?=5Fclose()=20doesn=E2=80=99t=20close=20too=20many=20FDs?=
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Expand an existing unit test to check that the target FD of a
+`g_subprocess_launcher_take_fd()` call doesn’t get closed when
+`g_subprocess_launcher_close()` is called. Only the source FD should be
+closed by the parent process.
+
+Signed-off-by: Philip Withnall <pwithnall endlessos org>
+
+Helps: #2332
+---
+ gio/tests/gsubprocess.c | 27 ++++++++++++++++++++++++---
+ 1 file changed, 24 insertions(+), 3 deletions(-)
+
+diff --git a/gio/tests/gsubprocess.c b/gio/tests/gsubprocess.c
+index 3c248e610..7e22678ec 100644
+--- a/gio/tests/gsubprocess.c
++++ b/gio/tests/gsubprocess.c
+@@ -1494,23 +1494,44 @@ test_subprocess_launcher_close (void)
+ GSubprocessLauncher *launcher;
+ GSubprocess *proc;
+ GPtrArray *args;
+- int fd;
++ int fd, fd2;
+ gboolean is_open;
+
+- fd = dup(0);
++ /* Open two arbitrary FDs. One of them, @fd, will be transferred to the
++ * launcher, and the other’s FD integer will be used as its target FD, giving
++ * the mapping `fd → fd2` if a child process were to be spawned.
++ *
++ * The launcher will then be closed, which should close @fd but *not* @fd2,
++ * as the value of @fd2 is only valid as an FD in a child process. (A child
++ * process is not actually spawned in this test.)
++ */
++ fd = dup (0);
++ fd2 = dup (0);
+ launcher = g_subprocess_launcher_new (G_SUBPROCESS_FLAGS_NONE);
+- g_subprocess_launcher_take_fd (launcher, fd, fd);
++ g_subprocess_launcher_take_fd (launcher, fd, fd2);
++
+ is_open = fcntl (fd, F_GETFD) != -1;
+ g_assert_true (is_open);
++ is_open = fcntl (fd2, F_GETFD) != -1;
++ g_assert_true (is_open);
++
+ g_subprocess_launcher_close (launcher);
++
+ is_open = fcntl (fd, F_GETFD) != -1;
+ g_assert_false (is_open);
++ is_open = fcntl (fd2, F_GETFD) != -1;
++ g_assert_true (is_open);
++
++ /* Now test that actually trying to spawn the child gives %G_IO_ERROR_CLOSED,
++ * as g_subprocess_launcher_close() has been called. */
+ args = get_test_subprocess_args ("cat", NULL);
+ proc = g_subprocess_launcher_spawnv (launcher, (const gchar * const *) args->pdata, error);
+ g_ptr_array_free (args, TRUE);
+ g_assert_null (proc);
+ g_assert_error (local_error, G_IO_ERROR, G_IO_ERROR_CLOSED);
+ g_clear_error (error);
++
++ close (fd2);
+ g_object_unref (launcher);
+ }
+
+--
+GitLab
+
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]