mirror of
https://github.com/postgres/postgres.git
synced 2025-11-19 13:42:17 +03:00
Fix elog(FATAL) before PostmasterMain() or just after fork().
Since commit 97550c0711, 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
This commit is contained in:
@@ -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
|
||||
|
||||
@@ -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);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user