Fix elog(FATAL) before PostmasterMain() or just after fork().
authorNoah Misch <[email protected]>
Tue, 10 Dec 2024 21:51:59 +0000 (13:51 -0800)
committerNoah Misch <[email protected]>
Tue, 10 Dec 2024 21:51:59 +0000 (13:51 -0800)
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- to v13 (all supported versions).

Discussion: https://postgr.es/m/20241208034614[email protected]

src/backend/main/main.c
src/backend/postmaster/fork_process.c
src/backend/postmaster/postmaster.c
src/port/pqsignal.c

index 3acb46bd464a25dc372cfe2480aa46f8c2720f06..2d98d97e8d862a1df4857f4f9c4a4f6299371947 100644 (file)
@@ -32,6 +32,7 @@
 
 #include "bootstrap/bootstrap.h"
 #include "common/username.h"
+#include "miscadmin.h"
 #include "postmaster/postmaster.h"
 #include "tcop/tcopprot.h"
 #include "utils/help_config.h"
@@ -109,6 +110,7 @@ main(int argc, char *argv[])
     * localization of messages may not work right away, and messages won't go
     * anywhere but stderr until GUC settings get loaded.
     */
+   MyProcPid = getpid();
    MemoryContextInit();
 
    /*
index 5e42a74ab5f4779448dd1389fd6f9c377b1c28e1..b3010e3e36abf7229340b177481161506f321a37 100644 (file)
@@ -19,6 +19,7 @@
 #include <unistd.h>
 
 #include "libpq/pqsignal.h"
+#include "miscadmin.h"
 #include "postmaster/fork_process.h"
 
 #ifndef WIN32
@@ -66,6 +67,7 @@ fork_process(void)
    if (result == 0)
    {
        /* fork succeeded, in child */
+       MyProcPid = getpid();
 #ifdef LINUX_PROFILE
        setitimer(ITIMER_PROF, &prof_itimer, NULL);
 #endif
index ce00f4032eea252007bf90ff2cfebaabc03c2eba..f0f9c66487c91583fac78e2ca201879965b79768 100644 (file)
@@ -1899,14 +1899,13 @@ ClosePostmasterPorts(bool am_syslogger)
 
 
 /*
- * InitProcessGlobals -- set MyProcPid, MyStartTime[stamp], random seeds
+ * InitProcessGlobals -- set MyStartTime[stamp], random seeds
  *
  * Called early in the postmaster and every backend.
  */
 void
 InitProcessGlobals(void)
 {
-   MyProcPid = getpid();
    MyStartTimestamp = GetCurrentTimestamp();
    MyStartTime = timestamptz_to_time_t(MyStartTimestamp);
 
index 6ca2d4e20a840f8f767431dff19d19635ef0dd6e..bdaa9f10c8a29c22b69f1843c7424f86c9bc8115 100644 (file)
@@ -74,8 +74,7 @@ static volatile pqsigfunc pqsignal_handlers[PG_NSIG];
 /*
  * Except when called with SIG_IGN or SIG_DFL, pqsignal() sets up this function
  * as the handler for all signals.  This wrapper handler function checks that
- * it is called within a process that the server knows about (i.e., any process
- * that has called InitProcessGlobals(), such as a client backend), and not a
+ * it is called within a process that knew to maintain MyProcPid, and not a
  * child process forked by system(3), etc.  This check ensures that such child
  * processes do not modify shared memory, which is often detrimental.  If the
  * check succeeds, the function originally provided to pqsignal() is called.