PostgreSQL Source Code git master
Loading...
Searching...
No Matches
test_custom_var_stats.c File Reference
#include "postgres.h"
#include "access/htup_details.h"
#include "common/hashfn.h"
#include "funcapi.h"
#include "storage/dsm_registry.h"
#include "utils/builtins.h"
#include "utils/pgstat_internal.h"
Include dependency graph for test_custom_var_stats.c:

Go to the source code of this file.

Data Structures

struct  PgStat_StatCustomVarEntry
 
struct  PgStatShared_CustomVarEntry
 

Macros

#define TEST_CUSTOM_VAR_MAGIC_NUMBER   (0xBEEFBEEF)
 
#define PGSTAT_KIND_TEST_CUSTOM_VAR_STATS   25
 
#define TEST_CUSTOM_AUX_DATA_DESC   "pg_stat/test_custom_var_stats_desc.stats"
 
#define PGSTAT_CUSTOM_VAR_STATS_IDX(name)   hash_bytes_extended((const unsigned char *) name, strlen(name), 0)
 

Typedefs

typedef struct PgStat_StatCustomVarEntry PgStat_StatCustomVarEntry
 
typedef struct PgStatShared_CustomVarEntry PgStatShared_CustomVarEntry
 

Functions

 PG_MODULE_MAGIC_EXT (.name="test_custom_var_stats",.version=PG_VERSION)
 
static bool test_custom_stats_var_flush_pending_cb (PgStat_EntryRef *entry_ref, bool nowait)
 
static void test_custom_stats_var_to_serialized_data (const PgStat_HashKey *key, const PgStatShared_Common *header, FILE *statfile)
 
static bool test_custom_stats_var_from_serialized_data (const PgStat_HashKey *key, PgStatShared_Common *header, FILE *statfile)
 
static void test_custom_stats_var_finish (PgStat_StatsFileOp status)
 
void _PG_init (void)
 
static PgStat_StatCustomVarEntrytest_custom_stats_var_fetch_entry (const char *stat_name)
 
 PG_FUNCTION_INFO_V1 (test_custom_stats_var_create)
 
Datum test_custom_stats_var_create (PG_FUNCTION_ARGS)
 
 PG_FUNCTION_INFO_V1 (test_custom_stats_var_update)
 
Datum test_custom_stats_var_update (PG_FUNCTION_ARGS)
 
 PG_FUNCTION_INFO_V1 (test_custom_stats_var_drop)
 
Datum test_custom_stats_var_drop (PG_FUNCTION_ARGS)
 
 PG_FUNCTION_INFO_V1 (test_custom_stats_var_report)
 
Datum test_custom_stats_var_report (PG_FUNCTION_ARGS)
 

Variables

static FILEfd_description = NULL
 
static pgoff_t fd_description_offset = 0
 
static dsa_areacustom_stats_description_dsa = NULL
 
static const PgStat_KindInfo custom_stats
 

Macro Definition Documentation

◆ PGSTAT_CUSTOM_VAR_STATS_IDX

#define PGSTAT_CUSTOM_VAR_STATS_IDX (   name)    hash_bytes_extended((const unsigned char *) name, strlen(name), 0)

Definition at line 45 of file test_custom_var_stats.c.

◆ PGSTAT_KIND_TEST_CUSTOM_VAR_STATS

#define PGSTAT_KIND_TEST_CUSTOM_VAR_STATS   25

Definition at line 37 of file test_custom_var_stats.c.

◆ TEST_CUSTOM_AUX_DATA_DESC

#define TEST_CUSTOM_AUX_DATA_DESC   "pg_stat/test_custom_var_stats_desc.stats"

Definition at line 40 of file test_custom_var_stats.c.

◆ TEST_CUSTOM_VAR_MAGIC_NUMBER

#define TEST_CUSTOM_VAR_MAGIC_NUMBER   (0xBEEFBEEF)

Definition at line 27 of file test_custom_var_stats.c.

Typedef Documentation

◆ PgStat_StatCustomVarEntry

◆ PgStatShared_CustomVarEntry

Function Documentation

◆ _PG_init()

void _PG_init ( void  )

Definition at line 129 of file test_custom_var_stats.c.

130{
131 /* Must be loaded via shared_preload_libraries */
133 return;
134
135 /* Register custom statistics kind */
137}
bool process_shared_preload_libraries_in_progress
Definition miscinit.c:1786
void pgstat_register_kind(PgStat_Kind kind, const PgStat_KindInfo *kind_info)
Definition pgstat.c:1473
static const PgStat_KindInfo custom_stats
#define PGSTAT_KIND_TEST_CUSTOM_VAR_STATS

References custom_stats, PGSTAT_KIND_TEST_CUSTOM_VAR_STATS, pgstat_register_kind(), and process_shared_preload_libraries_in_progress.

◆ PG_FUNCTION_INFO_V1() [1/4]

PG_FUNCTION_INFO_V1 ( test_custom_stats_var_create  )

◆ PG_FUNCTION_INFO_V1() [2/4]

PG_FUNCTION_INFO_V1 ( test_custom_stats_var_drop  )

◆ PG_FUNCTION_INFO_V1() [3/4]

PG_FUNCTION_INFO_V1 ( test_custom_stats_var_report  )

◆ PG_FUNCTION_INFO_V1() [4/4]

PG_FUNCTION_INFO_V1 ( test_custom_stats_var_update  )

◆ PG_MODULE_MAGIC_EXT()

PG_MODULE_MAGIC_EXT ( name = "test_custom_var_stats",
version = PG_VERSION 
)

◆ test_custom_stats_var_create()

Datum test_custom_stats_var_create ( PG_FUNCTION_ARGS  )

Definition at line 512 of file test_custom_var_stats.c.

513{
514 PgStat_EntryRef *entry_ref;
515 PgStatShared_CustomVarEntry *shared_entry;
519 bool found;
520
521 /* Validate name length first */
525 errmsg("custom statistic name \"%s\" is too long", stat_name),
526 errdetail("Name must be less than %d characters.", NAMEDATALEN)));
527
528 /* Initialize DSA and description provided */
530 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
531
534 (errmsg("could not access DSA for custom statistics descriptions")));
535
536 /* Allocate space in DSA and copy description */
540 strlen(description) + 1);
541
542 /* Create or get existing entry */
545
546 if (!entry_ref)
548
549 shared_entry = (PgStatShared_CustomVarEntry *) entry_ref->shared_stats;
550
551 /* Zero-initialize statistics */
552 memset(&shared_entry->stats, 0, sizeof(shared_entry->stats));
553
554 /* Store description pointer */
555 shared_entry->description = dp;
556
557 pgstat_unlock_entry(entry_ref);
558
560}
void * dsa_get_address(dsa_area *area, dsa_pointer dp)
Definition dsa.c:957
uint64 dsa_pointer
Definition dsa.h:62
#define dsa_allocate(area, size)
Definition dsa.h:109
#define InvalidDsaPointer
Definition dsa.h:78
dsa_area * GetNamedDSA(const char *name, bool *found)
int errcode(int sqlerrcode)
Definition elog.c:874
int errmsg(const char *fmt,...)
Definition elog.c:1093
int errdetail(const char *fmt,...) pg_attribute_printf(1
#define ERROR
Definition elog.h:39
#define ereport(elevel,...)
Definition elog.h:150
#define PG_RETURN_VOID()
Definition fmgr.h:350
#define PG_GETARG_TEXT_PP(n)
Definition fmgr.h:310
#define NAMEDATALEN
void pgstat_unlock_entry(PgStat_EntryRef *entry_ref)
PgStat_EntryRef * pgstat_get_entry_ref_locked(PgStat_Kind kind, Oid dboid, uint64 objid, bool nowait)
#define InvalidOid
static int fb(int x)
PgStat_StatCustomVarEntry stats
PgStatShared_Common * shared_stats
static dsa_area * custom_stats_description_dsa
#define PGSTAT_CUSTOM_VAR_STATS_IDX(name)
char * text_to_cstring(const text *t)
Definition varlena.c:215
const char * description

References custom_stats_description_dsa, description, PgStatShared_CustomVarEntry::description, dsa_allocate, dsa_get_address(), ereport, errcode(), errdetail(), errmsg(), ERROR, fb(), GetNamedDSA(), InvalidDsaPointer, InvalidOid, NAMEDATALEN, PG_GETARG_TEXT_PP, PG_RETURN_VOID, PGSTAT_CUSTOM_VAR_STATS_IDX, pgstat_get_entry_ref_locked(), PGSTAT_KIND_TEST_CUSTOM_VAR_STATS, pgstat_unlock_entry(), PgStat_EntryRef::shared_stats, PgStatShared_CustomVarEntry::stats, and text_to_cstring().

◆ test_custom_stats_var_drop()

Datum test_custom_stats_var_drop ( PG_FUNCTION_ARGS  )

Definition at line 595 of file test_custom_var_stats.c.

596{
598
599 /* Drop entry and request GC if the entry could not be freed */
603
605}
void pgstat_request_entry_refs_gc(void)
bool pgstat_drop_entry(PgStat_Kind kind, Oid dboid, uint64 objid)

References fb(), InvalidOid, PG_GETARG_TEXT_PP, PG_RETURN_VOID, PGSTAT_CUSTOM_VAR_STATS_IDX, pgstat_drop_entry(), PGSTAT_KIND_TEST_CUSTOM_VAR_STATS, pgstat_request_entry_refs_gc(), and text_to_cstring().

◆ test_custom_stats_var_fetch_entry()

static PgStat_StatCustomVarEntry * test_custom_stats_var_fetch_entry ( const char stat_name)
static

Definition at line 490 of file test_custom_var_stats.c.

491{
492 /* Fetch entry by hashed name */
497}
void * pgstat_fetch_entry(PgStat_Kind kind, Oid dboid, uint64 objid)
Definition pgstat.c:944

References fb(), InvalidOid, PGSTAT_CUSTOM_VAR_STATS_IDX, pgstat_fetch_entry(), and PGSTAT_KIND_TEST_CUSTOM_VAR_STATS.

Referenced by test_custom_stats_var_report().

◆ test_custom_stats_var_finish()

static void test_custom_stats_var_finish ( PgStat_StatsFileOp  status)
static

Definition at line 408 of file test_custom_var_stats.c.

409{
410 switch (status)
411 {
412 case STATS_WRITE:
413 if (!fd_description)
414 return;
415
417
418 /* Check for write errors and cleanup if necessary */
420 {
421 ereport(LOG,
423 errmsg("could not write to file \"%s\": %m",
427 }
428 else if (FreeFile(fd_description) < 0)
429 {
430 ereport(LOG,
432 errmsg("could not close file \"%s\": %m",
435 }
436 break;
437
438 case STATS_READ:
439 if (fd_description)
441
442 /* Remove the file after reading */
443 elog(DEBUG2, "removing file \"%s\"", TEST_CUSTOM_AUX_DATA_DESC);
445 break;
446
447 case STATS_DISCARD:
448 {
449 int ret;
450
451 /* Attempt to remove the file */
453 if (ret != 0)
454 {
455 if (errno == ENOENT)
456 elog(LOG,
457 "didn't need to unlink file \"%s\" - didn't exist",
459 else
460 ereport(LOG,
462 errmsg("could not unlink file \"%s\": %m",
464 }
465 else
466 {
467 ereport(LOG,
468 (errmsg_internal("unlinked file \"%s\"",
470 }
471 }
472 break;
473 }
474
476}
int errcode_for_file_access(void)
Definition elog.c:897
#define LOG
Definition elog.h:31
int int errmsg_internal(const char *fmt,...) pg_attribute_printf(1
#define DEBUG2
Definition elog.h:29
#define elog(elevel,...)
Definition elog.h:226
int FreeFile(FILE *file)
Definition fd.c:2826
@ STATS_WRITE
@ STATS_READ
@ STATS_DISCARD
static pgoff_t fd_description_offset
#define TEST_CUSTOM_AUX_DATA_DESC
static FILE * fd_description

References DEBUG2, elog, ereport, errcode_for_file_access(), errmsg(), errmsg_internal(), fb(), fd_description, fd_description_offset, FreeFile(), LOG, STATS_DISCARD, STATS_READ, STATS_WRITE, and TEST_CUSTOM_AUX_DATA_DESC.

◆ test_custom_stats_var_flush_pending_cb()

static bool test_custom_stats_var_flush_pending_cb ( PgStat_EntryRef entry_ref,
bool  nowait 
)
static

Definition at line 154 of file test_custom_var_stats.c.

155{
157 PgStatShared_CustomVarEntry *shared_entry;
158
160 shared_entry = (PgStatShared_CustomVarEntry *) entry_ref->shared_stats;
161
162 if (!pgstat_lock_entry(entry_ref, nowait))
163 return false;
164
165 /* Add pending counts to shared totals */
166 shared_entry->stats.numcalls += pending_entry->numcalls;
167
168 pgstat_unlock_entry(entry_ref);
169
170 return true;
171}
bool pgstat_lock_entry(PgStat_EntryRef *entry_ref, bool nowait)

References fb(), PgStat_StatCustomVarEntry::numcalls, PgStat_EntryRef::pending, pgstat_lock_entry(), pgstat_unlock_entry(), PgStat_EntryRef::shared_stats, and PgStatShared_CustomVarEntry::stats.

◆ test_custom_stats_var_from_serialized_data()

static bool test_custom_stats_var_from_serialized_data ( const PgStat_HashKey key,
PgStatShared_Common header,
FILE statfile 
)
static

Definition at line 279 of file test_custom_var_stats.c.

282{
285 size_t len;
286 pgoff_t offset;
287 char *buffer;
288 bool found;
291
292 /* Check the magic number first, in the main file. */
294 {
295 elog(WARNING, "failed to read magic number from statistics file");
296 return false;
297 }
298
300 {
301 elog(WARNING, "found magic number %u from statistics file, should be %u",
303 return false;
304 }
305
306 /*
307 * Read the offset from the main stats file, to be able to read the
308 * auxiliary data from the secondary statistics file.
309 */
310 if (!pgstat_read_chunk_s(statfile, &offset))
311 {
312 elog(WARNING, "failed to read metadata offset from statistics file");
313 return false;
314 }
315
316 /* Open statistics file for reading if not already open */
317 if (!fd_description)
318 {
320 if (fd_description == NULL)
321 {
322 if (errno != ENOENT)
323 ereport(LOG,
325 errmsg("could not open statistics file \"%s\" for reading: %m",
328 return false;
329 }
330 }
331
332 /* Read data from the secondary statistics file, at the specified offset */
333 if (fseeko(fd_description, offset, SEEK_SET) != 0)
334 {
335 elog(WARNING, "could not seek in file \"%s\": %m",
337 return false;
338 }
339
340 /* Read the hash key from the secondary statistics file */
342 {
343 elog(WARNING, "failed to read hash key from file");
344 return false;
345 }
346
347 /* Check key consistency */
348 if (file_key.kind != key->kind ||
349 file_key.dboid != key->dboid ||
350 file_key.objid != key->objid)
351 {
352 elog(WARNING, "found entry key %u/%u/%" PRIu64 " not matching with %u/%u/%" PRIu64,
353 file_key.kind, file_key.dboid, file_key.objid,
354 key->kind, key->dboid, key->objid);
355 return false;
356 }
357
358 entry = (PgStatShared_CustomVarEntry *) header;
359
360 /* Read the description length and its data */
362 {
363 elog(WARNING, "failed to read metadata length from statistics file");
364 return false;
365 }
366
367 /* Handle empty descriptions */
368 if (len == 0)
369 {
371 return true;
372 }
373
374 /* Initialize DSA if needed */
376 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
377
379 {
380 elog(WARNING, "could not access DSA for custom statistics descriptions");
381 return false;
382 }
383
384 buffer = palloc(len);
385 if (!pgstat_read_chunk(fd_description, buffer, len))
386 {
387 pfree(buffer);
388 elog(WARNING, "failed to read description from file");
389 return false;
390 }
391
392 /* Allocate space in DSA and copy the description */
395 entry->description = dp;
396 pfree(buffer);
397
398 return true;
399}
#define PG_BINARY_R
Definition c.h:1311
uint32_t uint32
Definition c.h:558
#define WARNING
Definition elog.h:36
FILE * AllocateFile(const char *name, const char *mode)
Definition fd.c:2627
void pfree(void *pointer)
Definition mcxt.c:1616
void * palloc(Size size)
Definition mcxt.c:1387
const void size_t len
void pgstat_reset_of_kind(PgStat_Kind kind)
Definition pgstat.c:886
bool pgstat_read_chunk(FILE *fpin, void *ptr, size_t len)
Definition pgstat.c:1763
#define pgstat_read_chunk_s(fpin, ptr)
off_t pgoff_t
Definition port.h:421
#define TEST_CUSTOM_VAR_MAGIC_NUMBER
#define fseeko(stream, offset, origin)
Definition win32_port.h:206

References AllocateFile(), custom_stats_description_dsa, PgStatShared_CustomVarEntry::description, dsa_allocate, dsa_get_address(), elog, ereport, errcode_for_file_access(), errmsg(), fb(), fd_description, fseeko, GetNamedDSA(), InvalidDsaPointer, len, LOG, palloc(), pfree(), PG_BINARY_R, PGSTAT_KIND_TEST_CUSTOM_VAR_STATS, pgstat_read_chunk(), pgstat_read_chunk_s, pgstat_reset_of_kind(), TEST_CUSTOM_AUX_DATA_DESC, TEST_CUSTOM_VAR_MAGIC_NUMBER, and WARNING.

◆ test_custom_stats_var_report()

Datum test_custom_stats_var_report ( PG_FUNCTION_ARGS  )

Definition at line 616 of file test_custom_var_stats.c.

617{
619 char *stat_name;
621
622 if (SRF_IS_FIRSTCALL())
623 {
624 TupleDesc tupdesc;
625 MemoryContext oldcontext;
626
627 /* Initialize SRF context */
629 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
630
631 /* Get composite return type */
632 if (get_call_result_type(fcinfo, NULL, &tupdesc) != TYPEFUNC_COMPOSITE)
633 elog(ERROR, "test_custom_stats_var_report: return type is not composite");
634
635 funcctx->tuple_desc = BlessTupleDesc(tupdesc);
636 funcctx->max_calls = 1; /* single row result */
637
638 MemoryContextSwitchTo(oldcontext);
639 }
640
642
643 if (funcctx->call_cntr < funcctx->max_calls)
644 {
645 Datum values[3];
646 bool nulls[3] = {false, false, false};
647 HeapTuple tuple;
648 PgStat_EntryRef *entry_ref;
649 PgStatShared_CustomVarEntry *shared_entry;
650 char *description = NULL;
651 bool found;
652
655
656 /* Return row only if entry exists */
657 if (stat_entry)
658 {
659 /* Get entry ref to access shared entry */
662
663 if (entry_ref)
664 {
665 shared_entry = (PgStatShared_CustomVarEntry *) entry_ref->shared_stats;
666
667 /* Get description from DSA if available */
668 if (DsaPointerIsValid(shared_entry->description))
669 {
671 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
672
675 }
676 }
677
679 values[1] = Int64GetDatum(stat_entry->numcalls);
680
681 if (description)
683 else
684 nulls[2] = true;
685
686 tuple = heap_form_tuple(funcctx->tuple_desc, values, nulls);
688 }
689 }
690
692}
static Datum values[MAXATTR]
Definition bootstrap.c:147
#define DsaPointerIsValid(x)
Definition dsa.h:106
TupleDesc BlessTupleDesc(TupleDesc tupdesc)
TypeFuncClass get_call_result_type(FunctionCallInfo fcinfo, Oid *resultTypeId, TupleDesc *resultTupleDesc)
Definition funcapi.c:276
#define SRF_IS_FIRSTCALL()
Definition funcapi.h:304
#define SRF_PERCALL_SETUP()
Definition funcapi.h:308
@ TYPEFUNC_COMPOSITE
Definition funcapi.h:149
#define SRF_RETURN_NEXT(_funcctx, _result)
Definition funcapi.h:310
#define SRF_FIRSTCALL_INIT()
Definition funcapi.h:306
static Datum HeapTupleGetDatum(const HeapTupleData *tuple)
Definition funcapi.h:230
#define SRF_RETURN_DONE(_funcctx)
Definition funcapi.h:328
HeapTuple heap_form_tuple(TupleDesc tupleDescriptor, const Datum *values, const bool *isnull)
Definition heaptuple.c:1117
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition palloc.h:124
PgStat_EntryRef * pgstat_get_entry_ref(PgStat_Kind kind, Oid dboid, uint64 objid, bool create, bool *created_entry)
static Datum Int64GetDatum(int64 X)
Definition postgres.h:423
static Datum PointerGetDatum(const void *X)
Definition postgres.h:352
uint64_t Datum
Definition postgres.h:70
static PgStat_StatCustomVarEntry * test_custom_stats_var_fetch_entry(const char *stat_name)
text * cstring_to_text(const char *s)
Definition varlena.c:182

References BlessTupleDesc(), cstring_to_text(), custom_stats_description_dsa, description, PgStatShared_CustomVarEntry::description, dsa_get_address(), DsaPointerIsValid, elog, ERROR, fb(), get_call_result_type(), GetNamedDSA(), heap_form_tuple(), HeapTupleGetDatum(), Int64GetDatum(), InvalidOid, MemoryContextSwitchTo(), PG_GETARG_TEXT_PP, PGSTAT_CUSTOM_VAR_STATS_IDX, pgstat_get_entry_ref(), PGSTAT_KIND_TEST_CUSTOM_VAR_STATS, PointerGetDatum(), PgStat_EntryRef::shared_stats, SRF_FIRSTCALL_INIT, SRF_IS_FIRSTCALL, SRF_PERCALL_SETUP, SRF_RETURN_DONE, SRF_RETURN_NEXT, test_custom_stats_var_fetch_entry(), text_to_cstring(), TYPEFUNC_COMPOSITE, and values.

◆ test_custom_stats_var_to_serialized_data()

static void test_custom_stats_var_to_serialized_data ( const PgStat_HashKey key,
const PgStatShared_Common header,
FILE statfile 
)
static

Definition at line 194 of file test_custom_var_stats.c.

197{
198 char *description;
199 size_t len;
200 const PgStatShared_CustomVarEntry *entry = (const PgStatShared_CustomVarEntry *) header;
201 bool found;
203
204 /*
205 * First mark the main file with a magic number, keeping a trace that some
206 * auxiliary data will exist in the secondary statistics file.
207 */
209
210 /* Open statistics file for writing. */
211 if (!fd_description)
212 {
214 if (fd_description == NULL)
215 {
216 ereport(LOG,
218 errmsg("could not open statistics file \"%s\" for writing: %m",
220 return;
221 }
222
223 /* Initialize offset for secondary statistics file. */
225 }
226
227 /* Write offset to the main data file */
229
230 /*
231 * First write the entry key to the secondary statistics file. This will
232 * be cross-checked with the key read from main stats file at loading
233 * time.
234 */
237
239 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
240
241 /* Handle entries without descriptions */
243 {
244 /* length to description file */
245 len = 0;
247 fd_description_offset += sizeof(size_t);
248 return;
249 }
250
251 /*
252 * Retrieve description from DSA, then write the length followed by the
253 * description.
254 */
256 entry->description);
257 len = strlen(description) + 1;
260
261 /*
262 * Update offset for next entry, counting for the length (size_t) of the
263 * description and the description contents.
264 */
265 fd_description_offset += len + sizeof(size_t);
266}
#define PG_BINARY_W
Definition c.h:1312
void pgstat_write_chunk(FILE *fpout, void *ptr, size_t len)
Definition pgstat.c:1565
#define pgstat_write_chunk_s(fpout, ptr)

References AllocateFile(), custom_stats_description_dsa, description, PgStatShared_CustomVarEntry::description, dsa_get_address(), DsaPointerIsValid, ereport, errcode_for_file_access(), errmsg(), fb(), fd_description, fd_description_offset, GetNamedDSA(), len, LOG, PG_BINARY_W, pgstat_write_chunk(), pgstat_write_chunk_s, TEST_CUSTOM_AUX_DATA_DESC, and TEST_CUSTOM_VAR_MAGIC_NUMBER.

◆ test_custom_stats_var_update()

Datum test_custom_stats_var_update ( PG_FUNCTION_ARGS  )

Definition at line 571 of file test_custom_var_stats.c.

572{
574 PgStat_EntryRef *entry_ref;
576
577 /* Get pending entry in local memory */
580
582 pending_entry->numcalls++;
583
585}
PgStat_EntryRef * pgstat_prep_pending_entry(PgStat_Kind kind, Oid dboid, uint64 objid, bool *created_entry)
Definition pgstat.c:1275

References fb(), InvalidOid, PgStat_EntryRef::pending, PG_GETARG_TEXT_PP, PG_RETURN_VOID, PGSTAT_CUSTOM_VAR_STATS_IDX, PGSTAT_KIND_TEST_CUSTOM_VAR_STATS, pgstat_prep_pending_entry(), and text_to_cstring().

Variable Documentation

◆ custom_stats

const PgStat_KindInfo custom_stats
static
Initial value:
= {
.name = "test_custom_var_stats",
.fixed_amount = false,
.write_to_file = true,
.track_entry_count = true,
.accessed_across_databases = true,
.shared_size = sizeof(PgStatShared_CustomVarEntry),
.shared_data_off = offsetof(PgStatShared_CustomVarEntry, stats),
.shared_data_len = sizeof(((PgStatShared_CustomVarEntry *) 0)->stats),
.pending_size = sizeof(PgStat_StatCustomVarEntry),
}
static void test_custom_stats_var_to_serialized_data(const PgStat_HashKey *key, const PgStatShared_Common *header, FILE *statfile)
static void test_custom_stats_var_finish(PgStat_StatsFileOp status)
static bool test_custom_stats_var_flush_pending_cb(PgStat_EntryRef *entry_ref, bool nowait)
static bool test_custom_stats_var_from_serialized_data(const PgStat_HashKey *key, PgStatShared_Common *header, FILE *statfile)

Definition at line 107 of file test_custom_var_stats.c.

107 {
108 .name = "test_custom_var_stats",
109 .fixed_amount = false, /* variable number of entries */
110 .write_to_file = true, /* persist across restarts */
111 .track_entry_count = true, /* count active entries */
112 .accessed_across_databases = true, /* global statistics */
113 .shared_size = sizeof(PgStatShared_CustomVarEntry),
114 .shared_data_off = offsetof(PgStatShared_CustomVarEntry, stats),
115 .shared_data_len = sizeof(((PgStatShared_CustomVarEntry *) 0)->stats),
116 .pending_size = sizeof(PgStat_StatCustomVarEntry),
117 .flush_pending_cb = test_custom_stats_var_flush_pending_cb,
118 .to_serialized_data = test_custom_stats_var_to_serialized_data,
119 .from_serialized_data = test_custom_stats_var_from_serialized_data,
121};

Referenced by _PG_init().

◆ custom_stats_description_dsa

◆ fd_description

◆ fd_description_offset

pgoff_t fd_description_offset = 0
static