Add a new shmem_request_hook hook.
authorRobert Haas <rhaas@postgresql.org>
Fri, 13 May 2022 13:31:06 +0000 (09:31 -0400)
committerRobert Haas <rhaas@postgresql.org>
Fri, 13 May 2022 13:31:06 +0000 (09:31 -0400)
commit4f2400cb3f10aa79f99fba680c198237da28dd38
tree4f96c3499f0ad60ee18431317e7068a21f498358
parent8c8d307f82976122980bbccf940319d1b8a71403
Add a new shmem_request_hook hook.

Currently, preloaded libraries are expected to request additional
shared memory and LWLocks in _PG_init().  However, it is not unusal
for such requests to depend on MaxBackends, which won't be
initialized at that time.  Such requests could also depend on GUCs
that other modules might change.  This introduces a new hook where
modules can safely use MaxBackends and GUCs to request additional
shared memory and LWLocks.

Furthermore, this change restricts requests for shared memory and
LWLocks to this hook.  Previously, libraries could make requests
until the size of the main shared memory segment was calculated.
Unlike before, we no longer silently ignore requests received at
invalid times.  Instead, we FATAL if someone tries to request
additional shared memory or LWLocks outside of the hook.

Nathan Bossart and Julien Rouhaud

Discussion: https://postgr.es/m/20220412210112.GA2065815%40nathanxps13
Discussion: https://postgr.es/m/Yn2jE/lmDhKtkUdr@paquier.xyz
contrib/pg_prewarm/autoprewarm.c
contrib/pg_stat_statements/pg_stat_statements.c
doc/src/sgml/xfunc.sgml
src/backend/postmaster/postmaster.c
src/backend/storage/ipc/ipci.c
src/backend/storage/lmgr/lwlock.c
src/backend/utils/init/miscinit.c
src/include/miscadmin.h
src/tools/pgindent/typedefs.list