mirror of
https://github.com/postgres/postgres.git
synced 2025-08-19 23:22:23 +03:00
Add support for runtime arguments in injection points
The macros INJECTION_POINT() and INJECTION_POINT_CACHED() are extended with an optional argument that can be passed down to the callback attached when an injection point is run, giving to callbacks the possibility to manipulate a stack state given by the caller. The existing callbacks in modules injection_points and test_aio have their declarations adjusted based on that.da7226993f
(core AIO infrastructure) and93bc3d75d8
(test_aio) and been relying on a set of workarounds where a static variable called pgaio_inj_cur_handle is used as runtime argument in the injection point callbacks used by the AIO tests, in combination with a TRY/CATCH block to reset the argument value. The infrastructure introduced in this commit will be reused for the AIO tests, simplifying them. Reviewed-by: Greg Burd <greg@burd.me> Discussion: https://postgr.es/m/Z_y9TtnXubvYAApS@paquier.xyz
This commit is contained in:
@@ -685,9 +685,9 @@ ginFinishSplit(GinBtree btree, GinBtreeStack *stack, bool freestack,
|
||||
|
||||
#ifdef USE_INJECTION_POINTS
|
||||
if (GinPageIsLeaf(BufferGetPage(stack->buffer)))
|
||||
INJECTION_POINT("gin-leave-leaf-split-incomplete");
|
||||
INJECTION_POINT("gin-leave-leaf-split-incomplete", NULL);
|
||||
else
|
||||
INJECTION_POINT("gin-leave-internal-split-incomplete");
|
||||
INJECTION_POINT("gin-leave-internal-split-incomplete", NULL);
|
||||
#endif
|
||||
|
||||
/* search parent to lock */
|
||||
@@ -778,7 +778,7 @@ ginFinishSplit(GinBtree btree, GinBtreeStack *stack, bool freestack,
|
||||
static void
|
||||
ginFinishOldSplit(GinBtree btree, GinBtreeStack *stack, GinStatsData *buildStats, int access)
|
||||
{
|
||||
INJECTION_POINT("gin-finish-incomplete-split");
|
||||
INJECTION_POINT("gin-finish-incomplete-split", NULL);
|
||||
elog(DEBUG1, "finishing incomplete split of block %u in gin index \"%s\"",
|
||||
stack->blkno, RelationGetRelationName(btree->index));
|
||||
|
||||
|
Reference in New Issue
Block a user