From 209a555a50e65e83dde6111cf9d4c783124fb659 Mon Sep 17 00:00:00 2001 From: Charles Kerr Date: Fri, 28 Jun 2024 03:25:55 -0500 Subject: [PATCH] fix: potential null dereference in normalizeSpawnArguments() patch (#42698) fix: potential null dereference in normalizeSpawnArguments() patch (#42260) fix: potential null deref in normalizeSpawnArguments() patch Use upstream's practice of using `env = options.env || process.env`. Previously, we were unconditionally assigning CRASHDUMP_SIGNAL_FD and CRASHPAD_HANDLER_PID to options.env. --- ...enable_crashpad_linux_node_processes.patch | 37 ++++++++++++------- 1 file changed, 23 insertions(+), 14 deletions(-) diff --git a/patches/node/enable_crashpad_linux_node_processes.patch b/patches/node/enable_crashpad_linux_node_processes.patch index 28b3c162f55..c2cd8cb15eb 100644 --- a/patches/node/enable_crashpad_linux_node_processes.patch +++ b/patches/node/enable_crashpad_linux_node_processes.patch @@ -8,7 +8,7 @@ to child processes spawned with `ELECTRON_RUN_AS_NODE` which is used by the crashpad client to connect with the handler process. diff --git a/lib/child_process.js b/lib/child_process.js -index c09fca512584ce2c674ae1d05136ff4cd8ea8471..3947e231f4e641b97d12c9639a736fab8836787b 100644 +index c09fca512584ce2c674ae1d05136ff4cd8ea8471..d4edaa71a7bf6660bad209fbfbc43014bb4bf741 100644 --- a/lib/child_process.js +++ b/lib/child_process.js @@ -61,6 +61,7 @@ let debug = require('internal/util/debuglog').debuglog( @@ -27,25 +27,34 @@ index c09fca512584ce2c674ae1d05136ff4cd8ea8471..3947e231f4e641b97d12c9639a736fab args = [...execArgv, modulePath, ...args]; if (typeof options.stdio === 'string') { -@@ -617,6 +617,21 @@ function normalizeSpawnArguments(file, args, options) { +@@ -617,6 +617,22 @@ function normalizeSpawnArguments(file, args, options) { 'options.windowsVerbatimArguments'); } -+ if (process.platform === 'linux') { -+ if (ObjectPrototypeHasOwnProperty(options.env || process.env, 'ELECTRON_RUN_AS_NODE') && -+ (file === process.execPath)) { -+ // On Linux, pass the file descriptor which crashpad handler process -+ // uses to monitor the child process and PID of the handler process. -+ // https://source.chromium.org/chromium/chromium/src/+/110.0.5415.0:components/crash/core/app/crashpad_linux.cc;l=199-206 -+ const fd = getCrashdumpSignalFD(); -+ const pid = getCrashpadHandlerPID(); -+ if (fd !== -1 && pid !== -1) { -+ options.env.CRASHDUMP_SIGNAL_FD = fd; -+ options.env.CRASHPAD_HANDLER_PID = pid; -+ } ++ const env = options.env || process.env; ++ ++ if ((process.platform === 'linux') && ++ ObjectPrototypeHasOwnProperty(env, 'ELECTRON_RUN_AS_NODE') && ++ (file === process.execPath)) { ++ // On Linux, pass the file descriptor which crashpad handler process ++ // uses to monitor the child process and PID of the handler process. ++ // https://source.chromium.org/chromium/chromium/src/+/110.0.5415.0:components/crash/core/app/crashpad_linux.cc;l=199-206 ++ const fd = getCrashdumpSignalFD(); ++ const pid = getCrashpadHandlerPID(); ++ if (fd !== -1 && pid !== -1) { ++ env.CRASHDUMP_SIGNAL_FD = fd; ++ env.CRASHPAD_HANDLER_PID = pid; + } + } + if (options.shell) { validateArgumentNullCheck(options.shell, 'options.shell'); const command = ArrayPrototypeJoin([file, ...args], ' '); +@@ -650,7 +666,6 @@ function normalizeSpawnArguments(file, args, options) { + ArrayPrototypeUnshift(args, file); + } + +- const env = options.env || process.env; + const envPairs = []; + + // process.env.NODE_V8_COVERAGE always propagates, making it possible to