summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHeikki Linnakangas2024-07-26 11:55:04 +0000
committerHeikki Linnakangas2024-07-26 12:11:50 +0000
commitb9e5249c29354186576d8fc00609fe7eaf7c8d25 (patch)
tree7827efe3eb46d439df6c7d549c18b8ca6d17678d
parentc95d2159c1dd3f269383a9bd830e1c804dba34c8 (diff)
Fix using injection points at backend startup in EXEC_BACKEND mode
Commit 86db52a506 changed the locking of injection points to use only atomic ops and spinlocks, to make it possible to define injection points in processes that don't have a PGPROC entry (yet). However, it didn't work in EXEC_BACKEND mode, because the pointer to shared memory area was not initialized until the process "attaches" to all the shared memory structs. To fix, pass the pointer to the child process along with other global variables that need to be set up early. Backpatch-through: 17
-rw-r--r--src/backend/postmaster/launch_backend.c12
-rw-r--r--src/backend/utils/misc/injection_point.c2
-rw-r--r--src/include/utils/injection_point.h4
3 files changed, 17 insertions, 1 deletions
diff --git a/src/backend/postmaster/launch_backend.c b/src/backend/postmaster/launch_backend.c
index e9fc9827878..fafe5feecc2 100644
--- a/src/backend/postmaster/launch_backend.c
+++ b/src/backend/postmaster/launch_backend.c
@@ -63,6 +63,7 @@
#include "utils/builtins.h"
#include "utils/datetime.h"
#include "utils/guc.h"
+#include "utils/injection_point.h"
#include "utils/memutils.h"
#include "utils/timestamp.h"
@@ -104,6 +105,9 @@ typedef struct
void *UsedShmemSegAddr;
slock_t *ShmemLock;
struct bkend *ShmemBackendArray;
+#ifdef USE_INJECTION_POINTS
+ struct InjectionPointsCtl *ActiveInjectionPoints;
+#endif
#ifndef HAVE_SPINLOCKS
PGSemaphore *SpinlockSemaArray;
#endif
@@ -710,6 +714,10 @@ save_backend_variables(BackendParameters *param, ClientSocket *client_sock,
param->ShmemLock = ShmemLock;
param->ShmemBackendArray = ShmemBackendArray;
+#ifdef USE_INJECTION_POINTS
+ param->ActiveInjectionPoints = ActiveInjectionPoints;
+#endif
+
#ifndef HAVE_SPINLOCKS
param->SpinlockSemaArray = SpinlockSemaArray;
#endif
@@ -969,6 +977,10 @@ restore_backend_variables(BackendParameters *param)
ShmemLock = param->ShmemLock;
ShmemBackendArray = param->ShmemBackendArray;
+#ifdef USE_INJECTION_POINTS
+ ActiveInjectionPoints = param->ActiveInjectionPoints;
+#endif
+
#ifndef HAVE_SPINLOCKS
SpinlockSemaArray = param->SpinlockSemaArray;
#endif
diff --git a/src/backend/utils/misc/injection_point.c b/src/backend/utils/misc/injection_point.c
index 8ad0c27bc8a..8ab5bc63276 100644
--- a/src/backend/utils/misc/injection_point.c
+++ b/src/backend/utils/misc/injection_point.c
@@ -85,7 +85,7 @@ typedef struct InjectionPointsCtl
InjectionPointEntry entries[MAX_INJECTION_POINTS];
} InjectionPointsCtl;
-static InjectionPointsCtl *ActiveInjectionPoints;
+NON_EXEC_STATIC InjectionPointsCtl *ActiveInjectionPoints;
/*
* Backend local cache of injection callbacks already loaded, stored in
diff --git a/src/include/utils/injection_point.h b/src/include/utils/injection_point.h
index a385e3df649..a5b4a1f0f9f 100644
--- a/src/include/utils/injection_point.h
+++ b/src/include/utils/injection_point.h
@@ -43,4 +43,8 @@ extern void InjectionPointRun(const char *name);
extern void InjectionPointCached(const char *name);
extern bool InjectionPointDetach(const char *name);
+#ifdef EXEC_BACKEND
+extern PGDLLIMPORT struct InjectionPointsCtl *ActiveInjectionPoints;
+#endif
+
#endif /* INJECTION_POINT_H */