aboutsummaryrefslogtreecommitdiff
path: root/src/backend/postmaster/fork_process.c
diff options
context:
space:
mode:
authorNoah Misch <noah@leadboat.com>2024-12-10 13:51:59 -0800
committerNoah Misch <noah@leadboat.com>2024-12-10 13:52:02 -0800
commit315264d70128445fd53de199e16bb8aa562cf36f (patch)
tree08f64a8d9812fbc694fc9a86304946f87f945b25 /src/backend/postmaster/fork_process.c
parent4922ede979947bc2404e8675435184e61a57a530 (diff)
downloadpostgresql-315264d70128445fd53de199e16bb8aa562cf36f.tar.gz
postgresql-315264d70128445fd53de199e16bb8aa562cf36f.zip
Fix elog(FATAL) before PostmasterMain() or just after fork().
Since commit 97550c0711972a9856b5db751539bbaf2f88884c, these failed with "PANIC: proc_exit() called in child process" due to uninitialized or stale MyProcPid. That was reachable if close() failed in ClosePostmasterPorts() or setlocale(category, "C") failed, both unlikely. Back-patch to v13 (all supported versions). Discussion: https://postgr.es/m/20241208034614.45.nmisch@google.com
Diffstat (limited to 'src/backend/postmaster/fork_process.c')
-rw-r--r--src/backend/postmaster/fork_process.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/backend/postmaster/fork_process.c b/src/backend/postmaster/fork_process.c
index 62d068bc1e2..e4b938ca1f7 100644
--- a/src/backend/postmaster/fork_process.c
+++ b/src/backend/postmaster/fork_process.c
@@ -17,6 +17,7 @@
#include <sys/time.h>
#include <unistd.h>
+#include "miscadmin.h"
#include "postmaster/fork_process.h"
#ifndef WIN32
@@ -60,6 +61,7 @@ fork_process(void)
if (result == 0)
{
/* fork succeeded, in child */
+ MyProcPid = getpid();
#ifdef LINUX_PROFILE
setitimer(ITIMER_PROF, &prof_itimer, NULL);
#endif