LCOV - code coverage report
Current view: top level - src/backend/postmaster - auxprocess.c (source / functions) Coverage Total Hit
Test: PostgreSQL 19devel Lines: 100.0 % 25 25
Test Date: 2026-05-12 06:16:30 Functions: 100.0 % 2 2
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /*-------------------------------------------------------------------------
       2              :  * auxprocess.c
       3              :  *    functions related to auxiliary processes.
       4              :  *
       5              :  *
       6              :  * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
       7              :  * Portions Copyright (c) 1994, Regents of the University of California
       8              :  *
       9              :  * IDENTIFICATION
      10              :  *    src/backend/postmaster/auxprocess.c
      11              :  *-------------------------------------------------------------------------
      12              :  */
      13              : #include "postgres.h"
      14              : 
      15              : #include <unistd.h>
      16              : #include <signal.h>
      17              : 
      18              : #include "access/xlog.h"
      19              : #include "miscadmin.h"
      20              : #include "pgstat.h"
      21              : #include "postmaster/auxprocess.h"
      22              : #include "storage/condition_variable.h"
      23              : #include "storage/ipc.h"
      24              : #include "storage/proc.h"
      25              : #include "storage/procsignal.h"
      26              : #include "utils/memutils.h"
      27              : #include "utils/ps_status.h"
      28              : #include "utils/wait_event.h"
      29              : 
      30              : 
      31              : static void ShutdownAuxiliaryProcess(int code, Datum arg);
      32              : 
      33              : 
      34              : /*
      35              :  *   AuxiliaryProcessMainCommon
      36              :  *
      37              :  *   Common initialization code for auxiliary processes, such as the bgwriter,
      38              :  *   walwriter, walreceiver, and the startup process.
      39              :  */
      40              : void
      41         4428 : AuxiliaryProcessMainCommon(void)
      42              : {
      43              :     Assert(IsUnderPostmaster);
      44              : 
      45              :     /* Release postmaster's working memory context */
      46         4428 :     if (PostmasterContext)
      47              :     {
      48         4428 :         MemoryContextDelete(PostmasterContext);
      49         4428 :         PostmasterContext = NULL;
      50              :     }
      51              : 
      52         4428 :     init_ps_display(NULL);
      53              : 
      54              :     Assert(GetProcessingMode() == InitProcessing);
      55              : 
      56         4428 :     IgnoreSystemIndexes = true;
      57              : 
      58              :     /*
      59              :      * As an auxiliary process, we aren't going to do the full InitPostgres
      60              :      * pushups, but there are a couple of things that need to get lit up even
      61              :      * in an auxiliary process.
      62              :      */
      63              : 
      64              :     /*
      65              :      * Create a PGPROC so we can use LWLocks and access shared memory.
      66              :      */
      67         4428 :     InitAuxiliaryProcess();
      68              : 
      69         4428 :     BaseInit();
      70              : 
      71              :     /*
      72              :      * Prevent consuming interrupts between setting ProcSignalInit and setting
      73              :      * the initial local data checksum value.  If a barrier is emitted, and
      74              :      * absorbed, before local cached state is initialized the state transition
      75              :      * can be invalid.
      76              :      */
      77         4428 :     HOLD_INTERRUPTS();
      78              : 
      79         4428 :     ProcSignalInit(NULL, 0);
      80              : 
      81              :     /*
      82              :      * Initialize a local cache of the data_checksum_version, to be updated by
      83              :      * the procsignal-based barriers.
      84              :      *
      85              :      * This intentionally happens after initializing the procsignal, otherwise
      86              :      * we might miss a state change. This means we can get a barrier for the
      87              :      * state we've just initialized - but it can happen only once.
      88              :      *
      89              :      * The postmaster (which is what gets forked into the new child process)
      90              :      * does not handle barriers, therefore it may not have the current value
      91              :      * of LocalDataChecksumVersion value (it'll have the value read from the
      92              :      * control file, which may be arbitrarily old).
      93              :      *
      94              :      * NB: Even if the postmaster handled barriers, the value might still be
      95              :      * stale, as it might have changed after this process forked.
      96              :      */
      97         4428 :     InitLocalDataChecksumState();
      98              : 
      99         4428 :     RESUME_INTERRUPTS();
     100              : 
     101              :     /*
     102              :      * Initialize the process-local logical info WAL logging state.
     103              :      *
     104              :      * This must be called after ProcSignalInit() so that the process can
     105              :      * participate in procsignal-based barriers that update this state.
     106              :      */
     107         4428 :     InitializeProcessXLogLogicalInfo();
     108              : 
     109              :     /*
     110              :      * Auxiliary processes don't run transactions, but they may need a
     111              :      * resource owner anyway to manage buffer pins acquired outside
     112              :      * transactions (and, perhaps, other things in future).
     113              :      */
     114         4428 :     CreateAuxProcessResourceOwner();
     115              : 
     116              : 
     117              :     /* Initialize backend status information */
     118         4428 :     pgstat_beinit();
     119         4428 :     pgstat_bestart_initial();
     120         4428 :     pgstat_bestart_final();
     121              : 
     122              :     /* register a before-shutdown callback for LWLock cleanup */
     123         4428 :     before_shmem_exit(ShutdownAuxiliaryProcess, 0);
     124              : 
     125         4428 :     SetProcessingMode(NormalProcessing);
     126         4428 : }
     127              : 
     128              : /*
     129              :  * Begin shutdown of an auxiliary process.  This is approximately the equivalent
     130              :  * of ShutdownPostgres() in postinit.c.  We can't run transactions in an
     131              :  * auxiliary process, so most of the work of AbortTransaction() is not needed,
     132              :  * but we do need to make sure we've released any LWLocks we are holding.
     133              :  * (This is only critical during an error exit.)
     134              :  */
     135              : static void
     136         4428 : ShutdownAuxiliaryProcess(int code, Datum arg)
     137              : {
     138         4428 :     LWLockReleaseAll();
     139         4428 :     ConditionVariableCancelSleep();
     140         4428 :     pgstat_report_wait_end();
     141         4428 : }
        

Generated by: LCOV version 2.0-1