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 "storage/fd.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 46 of file test_custom_var_stats.c.

◆ PGSTAT_KIND_TEST_CUSTOM_VAR_STATS

#define PGSTAT_KIND_TEST_CUSTOM_VAR_STATS   25

Definition at line 38 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 41 of file test_custom_var_stats.c.

◆ TEST_CUSTOM_VAR_MAGIC_NUMBER

#define TEST_CUSTOM_VAR_MAGIC_NUMBER   (0xBEEFBEEF)

Definition at line 28 of file test_custom_var_stats.c.

Typedef Documentation

◆ PgStat_StatCustomVarEntry

◆ PgStatShared_CustomVarEntry

Function Documentation

◆ _PG_init()

void _PG_init ( void  )

Definition at line 130 of file test_custom_var_stats.c.

131{
132 /* Must be loaded via shared_preload_libraries */
134 return;
135
136 /* Register custom statistics kind */
138}
bool process_shared_preload_libraries_in_progress
Definition miscinit.c:1787
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 513 of file test_custom_var_stats.c.

514{
515 PgStat_EntryRef *entry_ref;
516 PgStatShared_CustomVarEntry *shared_entry;
520 bool found;
521
522 /* Validate name length first */
526 errmsg("custom statistic name \"%s\" is too long", stat_name),
527 errdetail("Name must be less than %d characters.", NAMEDATALEN)));
528
529 /* Initialize DSA and description provided */
531 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
532
535 (errmsg("could not access DSA for custom statistics descriptions")));
536
537 /* Allocate space in DSA and copy description */
541 strlen(description) + 1);
542
543 /* Create or get existing entry */
546
547 if (!entry_ref)
549
550 shared_entry = (PgStatShared_CustomVarEntry *) entry_ref->shared_stats;
551
552 /* Zero-initialize statistics */
553 memset(&shared_entry->stats, 0, sizeof(shared_entry->stats));
554
555 /* Store description pointer */
556 shared_entry->description = dp;
557
558 pgstat_unlock_entry(entry_ref);
559
561}
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 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
static char * errmsg
#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:217
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 596 of file test_custom_var_stats.c.

597{
599
600 /* Drop entry and request GC if the entry could not be freed */
604
606}
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 491 of file test_custom_var_stats.c.

492{
493 /* Fetch entry by hashed name */
498}
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 409 of file test_custom_var_stats.c.

410{
411 switch (status)
412 {
413 case STATS_WRITE:
414 if (!fd_description)
415 return;
416
418
419 /* Check for write errors and cleanup if necessary */
421 {
422 ereport(LOG,
424 errmsg("could not write to file \"%s\": %m",
428 }
429 else if (FreeFile(fd_description) < 0)
430 {
431 ereport(LOG,
433 errmsg("could not close file \"%s\": %m",
436 }
437 break;
438
439 case STATS_READ:
440 if (fd_description)
442
443 /* Remove the file after reading */
444 elog(DEBUG2, "removing file \"%s\"", TEST_CUSTOM_AUX_DATA_DESC);
446 break;
447
448 case STATS_DISCARD:
449 {
450 int ret;
451
452 /* Attempt to remove the file */
454 if (ret != 0)
455 {
456 if (errno == ENOENT)
457 elog(LOG,
458 "didn't need to unlink file \"%s\" - didn't exist",
460 else
461 ereport(LOG,
463 errmsg("could not unlink file \"%s\": %m",
465 }
466 else
467 {
468 ereport(LOG,
469 (errmsg_internal("unlinked file \"%s\"",
471 }
472 }
473 break;
474 }
475
477}
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:2827
@ 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 155 of file test_custom_var_stats.c.

156{
158 PgStatShared_CustomVarEntry *shared_entry;
159
161 shared_entry = (PgStatShared_CustomVarEntry *) entry_ref->shared_stats;
162
163 if (!pgstat_lock_entry(entry_ref, nowait))
164 return false;
165
166 /* Add pending counts to shared totals */
167 shared_entry->stats.numcalls += pending_entry->numcalls;
168
169 pgstat_unlock_entry(entry_ref);
170
171 return true;
172}
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 280 of file test_custom_var_stats.c.

283{
286 size_t len;
287 pgoff_t offset;
288 char *buffer;
289 bool found;
292
293 /* Check the magic number first, in the main file. */
295 {
296 elog(WARNING, "failed to read magic number from statistics file");
297 return false;
298 }
299
301 {
302 elog(WARNING, "found magic number %u from statistics file, should be %u",
304 return false;
305 }
306
307 /*
308 * Read the offset from the main stats file, to be able to read the
309 * auxiliary data from the secondary statistics file.
310 */
311 if (!pgstat_read_chunk_s(statfile, &offset))
312 {
313 elog(WARNING, "failed to read metadata offset from statistics file");
314 return false;
315 }
316
317 /* Open statistics file for reading if not already open */
318 if (!fd_description)
319 {
321 if (fd_description == NULL)
322 {
323 if (errno != ENOENT)
324 ereport(LOG,
326 errmsg("could not open statistics file \"%s\" for reading: %m",
329 return false;
330 }
331 }
332
333 /* Read data from the secondary statistics file, at the specified offset */
334 if (fseeko(fd_description, offset, SEEK_SET) != 0)
335 {
336 elog(WARNING, "could not seek in file \"%s\": %m",
338 return false;
339 }
340
341 /* Read the hash key from the secondary statistics file */
343 {
344 elog(WARNING, "failed to read hash key from file");
345 return false;
346 }
347
348 /* Check key consistency */
349 if (file_key.kind != key->kind ||
350 file_key.dboid != key->dboid ||
351 file_key.objid != key->objid)
352 {
353 elog(WARNING, "found entry key %u/%u/%" PRIu64 " not matching with %u/%u/%" PRIu64,
354 file_key.kind, file_key.dboid, file_key.objid,
355 key->kind, key->dboid, key->objid);
356 return false;
357 }
358
359 entry = (PgStatShared_CustomVarEntry *) header;
360
361 /* Read the description length and its data */
363 {
364 elog(WARNING, "failed to read metadata length from statistics file");
365 return false;
366 }
367
368 /* Handle empty descriptions */
369 if (len == 0)
370 {
372 return true;
373 }
374
375 /* Initialize DSA if needed */
377 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
378
380 {
381 elog(WARNING, "could not access DSA for custom statistics descriptions");
382 return false;
383 }
384
385 buffer = palloc(len);
386 if (!pgstat_read_chunk(fd_description, buffer, len))
387 {
388 pfree(buffer);
389 elog(WARNING, "failed to read description from file");
390 return false;
391 }
392
393 /* Allocate space in DSA and copy the description */
396 entry->description = dp;
397 pfree(buffer);
398
399 return true;
400}
#define PG_BINARY_R
Definition c.h:1378
uint32_t uint32
Definition c.h:618
#define WARNING
Definition elog.h:36
FILE * AllocateFile(const char *name, const char *mode)
Definition fd.c:2628
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 617 of file test_custom_var_stats.c.

618{
620 char *stat_name;
622
623 if (SRF_IS_FIRSTCALL())
624 {
625 TupleDesc tupdesc;
626 MemoryContext oldcontext;
627
628 /* Initialize SRF context */
630 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
631
632 /* Get composite return type */
633 if (get_call_result_type(fcinfo, NULL, &tupdesc) != TYPEFUNC_COMPOSITE)
634 elog(ERROR, "test_custom_stats_var_report: return type is not composite");
635
636 funcctx->tuple_desc = BlessTupleDesc(tupdesc);
637 funcctx->max_calls = 1; /* single row result */
638
639 MemoryContextSwitchTo(oldcontext);
640 }
641
643
644 if (funcctx->call_cntr < funcctx->max_calls)
645 {
646 Datum values[3];
647 bool nulls[3] = {false, false, false};
648 HeapTuple tuple;
649 PgStat_EntryRef *entry_ref;
650 PgStatShared_CustomVarEntry *shared_entry;
651 char *description = NULL;
652 bool found;
653
656
657 /* Return row only if entry exists */
658 if (stat_entry)
659 {
660 /* Get entry ref to access shared entry */
663
664 if (entry_ref)
665 {
666 shared_entry = (PgStatShared_CustomVarEntry *) entry_ref->shared_stats;
667
668 /* Get description from DSA if available */
669 if (DsaPointerIsValid(shared_entry->description))
670 {
672 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
673
676 }
677 }
678
680 values[1] = Int64GetDatum(stat_entry->numcalls);
681
682 if (description)
684 else
685 nulls[2] = true;
686
687 tuple = heap_form_tuple(funcctx->tuple_desc, values, nulls);
689 }
690 }
691
693}
static Datum values[MAXATTR]
Definition bootstrap.c:188
#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:1037
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:413
static Datum PointerGetDatum(const void *X)
Definition postgres.h:342
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:184

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 195 of file test_custom_var_stats.c.

198{
199 char *description;
200 size_t len;
201 const PgStatShared_CustomVarEntry *entry = (const PgStatShared_CustomVarEntry *) header;
202 bool found;
204
205 /*
206 * First mark the main file with a magic number, keeping a trace that some
207 * auxiliary data will exist in the secondary statistics file.
208 */
210
211 /* Open statistics file for writing. */
212 if (!fd_description)
213 {
215 if (fd_description == NULL)
216 {
217 ereport(LOG,
219 errmsg("could not open statistics file \"%s\" for writing: %m",
221 return;
222 }
223
224 /* Initialize offset for secondary statistics file. */
226 }
227
228 /* Write offset to the main data file */
230
231 /*
232 * First write the entry key to the secondary statistics file. This will
233 * be cross-checked with the key read from main stats file at loading
234 * time.
235 */
238
240 custom_stats_description_dsa = GetNamedDSA("test_custom_stat_dsa", &found);
241
242 /* Handle entries without descriptions */
244 {
245 /* length to description file */
246 len = 0;
248 fd_description_offset += sizeof(size_t);
249 return;
250 }
251
252 /*
253 * Retrieve description from DSA, then write the length followed by the
254 * description.
255 */
257 entry->description);
258 len = strlen(description) + 1;
261
262 /*
263 * Update offset for next entry, counting for the length (size_t) of the
264 * description and the description contents.
265 */
266 fd_description_offset += len + sizeof(size_t);
267}
#define PG_BINARY_W
Definition c.h:1379
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 572 of file test_custom_var_stats.c.

573{
575 PgStat_EntryRef *entry_ref;
577
578 /* Get pending entry in local memory */
581
583 pending_entry->numcalls++;
584
586}
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 108 of file test_custom_var_stats.c.

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

Referenced by _PG_init().

◆ custom_stats_description_dsa

◆ fd_description

◆ fd_description_offset

pgoff_t fd_description_offset = 0
static