PostgreSQL Source Code git master
Loading...
Searching...
No Matches
wait_event.h File Reference
#include "utils/wait_event_types.h"
Include dependency graph for wait_event.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Functions

const charpgstat_get_wait_event (uint32 wait_event_info)
 
const charpgstat_get_wait_event_type (uint32 wait_event_info)
 
static void pgstat_report_wait_start (uint32 wait_event_info)
 
static void pgstat_report_wait_end (void)
 
void pgstat_set_wait_event_storage (uint32 *wait_event_info)
 
void pgstat_reset_wait_event_storage (void)
 
uint32 WaitEventExtensionNew (const char *wait_event_name)
 
uint32 WaitEventInjectionPointNew (const char *wait_event_name)
 
char ** GetWaitEventCustomNames (uint32 classId, int *nwaitevents)
 

Variables

PGDLLIMPORT uint32my_wait_event_info
 

Function Documentation

◆ GetWaitEventCustomNames()

char ** GetWaitEventCustomNames ( uint32  classId,
int nwaitevents 
)
extern

Definition at line 292 of file wait_event.c.

293{
294 char **waiteventnames;
297 int index;
298 int els;
299
301
302 /* Now we can safely count the number of entries */
304
305 /* Allocate enough space for all entries */
307
308 /* Now scan the hash table to copy the data */
310
311 index = 0;
313 {
314 if ((hentry->wait_event_info & WAIT_EVENT_CLASS_MASK) != classId)
315 continue;
316 waiteventnames[index] = pstrdup(hentry->wait_event_name);
317 index++;
318 }
319
321
323 return waiteventnames;
324}
void * hash_seq_search(HASH_SEQ_STATUS *status)
Definition dynahash.c:1352
int64 hash_get_num_entries(HTAB *hashp)
Definition dynahash.c:1273
void hash_seq_init(HASH_SEQ_STATUS *status, HTAB *hashp)
Definition dynahash.c:1317
#define palloc_array(type, count)
Definition fe_memutils.h:76
bool LWLockAcquire(LWLock *lock, LWLockMode mode)
Definition lwlock.c:1150
void LWLockRelease(LWLock *lock)
Definition lwlock.c:1767
@ LW_SHARED
Definition lwlock.h:105
char * pstrdup(const char *in)
Definition mcxt.c:1781
static int fb(int x)
Definition type.h:96
static HTAB * WaitEventCustomHashByName
Definition wait_event.c:65
#define WAIT_EVENT_CLASS_MASK
Definition wait_event.c:44

References fb(), hash_get_num_entries(), hash_seq_init(), hash_seq_search(), LW_SHARED, LWLockAcquire(), LWLockRelease(), palloc_array, pstrdup(), WAIT_EVENT_CLASS_MASK, and WaitEventCustomHashByName.

Referenced by pg_get_wait_events().

◆ pgstat_get_wait_event()

const char * pgstat_get_wait_event ( uint32  wait_event_info)
extern

Definition at line 417 of file wait_event.c.

418{
419 uint32 classId;
421 const char *event_name;
422
423 /* report process as not waiting. */
424 if (wait_event_info == 0)
425 return NULL;
426
427 classId = wait_event_info & WAIT_EVENT_CLASS_MASK;
428 eventId = wait_event_info & WAIT_EVENT_ID_MASK;
429
430 switch (classId)
431 {
432 case PG_WAIT_LWLOCK:
434 break;
435 case PG_WAIT_LOCK:
437 break;
440 event_name = GetWaitEventCustomIdentifier(wait_event_info);
441 break;
442 case PG_WAIT_BUFFER:
443 {
444 WaitEventBuffer w = (WaitEventBuffer) wait_event_info;
445
447 break;
448 }
449 case PG_WAIT_ACTIVITY:
450 {
451 WaitEventActivity w = (WaitEventActivity) wait_event_info;
452
454 break;
455 }
456 case PG_WAIT_CLIENT:
457 {
458 WaitEventClient w = (WaitEventClient) wait_event_info;
459
461 break;
462 }
463 case PG_WAIT_IPC:
464 {
465 WaitEventIPC w = (WaitEventIPC) wait_event_info;
466
468 break;
469 }
470 case PG_WAIT_TIMEOUT:
471 {
472 WaitEventTimeout w = (WaitEventTimeout) wait_event_info;
473
475 break;
476 }
477 case PG_WAIT_IO:
478 {
479 WaitEventIO w = (WaitEventIO) wait_event_info;
480
482 break;
483 }
484 default:
485 event_name = "unknown wait event";
486 break;
487 }
488
489 return event_name;
490}
uint16_t uint16
Definition c.h:623
uint32_t uint32
Definition c.h:624
const char * GetLockNameFromTagType(uint16 locktag_type)
Definition lmgr.c:1346
const char * GetLWLockIdentifier(uint32 classId, uint16 eventId)
Definition lwlock.c:747
#define PG_WAIT_TIMEOUT
#define PG_WAIT_INJECTIONPOINT
#define PG_WAIT_LWLOCK
#define PG_WAIT_BUFFER
#define PG_WAIT_IPC
#define PG_WAIT_CLIENT
#define PG_WAIT_EXTENSION
#define PG_WAIT_ACTIVITY
#define PG_WAIT_LOCK
#define PG_WAIT_IO
static const char * pgstat_get_wait_timeout(WaitEventTimeout w)
static const char * pgstat_get_wait_activity(WaitEventActivity w)
static const char * pgstat_get_wait_io(WaitEventIO w)
static const char * GetWaitEventCustomIdentifier(uint32 wait_event_info)
Definition wait_event.c:262
static const char * pgstat_get_wait_client(WaitEventClient w)
static const char * pgstat_get_wait_ipc(WaitEventIPC w)
#define WAIT_EVENT_ID_MASK
Definition wait_event.c:45
static const char * pgstat_get_wait_buffer(WaitEventBuffer w)

References fb(), GetLockNameFromTagType(), GetLWLockIdentifier(), GetWaitEventCustomIdentifier(), PG_WAIT_ACTIVITY, PG_WAIT_BUFFER, PG_WAIT_CLIENT, PG_WAIT_EXTENSION, PG_WAIT_INJECTIONPOINT, PG_WAIT_IO, PG_WAIT_IPC, PG_WAIT_LOCK, PG_WAIT_LWLOCK, PG_WAIT_TIMEOUT, pgstat_get_wait_activity(), pgstat_get_wait_buffer(), pgstat_get_wait_client(), pgstat_get_wait_io(), pgstat_get_wait_ipc(), pgstat_get_wait_timeout(), WAIT_EVENT_CLASS_MASK, and WAIT_EVENT_ID_MASK.

Referenced by pg_stat_get_activity(), and pg_stat_get_backend_wait_event().

◆ pgstat_get_wait_event_type()

const char * pgstat_get_wait_event_type ( uint32  wait_event_info)
extern

Definition at line 359 of file wait_event.c.

360{
361 uint32 classId;
362 const char *event_type;
363
364 /* report process as not waiting. */
365 if (wait_event_info == 0)
366 return NULL;
367
368 classId = wait_event_info & WAIT_EVENT_CLASS_MASK;
369
370 switch (classId)
371 {
372 case PG_WAIT_LWLOCK:
373 event_type = "LWLock";
374 break;
375 case PG_WAIT_LOCK:
376 event_type = "Lock";
377 break;
378 case PG_WAIT_BUFFER:
379 event_type = "Buffer";
380 break;
381 case PG_WAIT_ACTIVITY:
382 event_type = "Activity";
383 break;
384 case PG_WAIT_CLIENT:
385 event_type = "Client";
386 break;
388 event_type = "Extension";
389 break;
390 case PG_WAIT_IPC:
391 event_type = "IPC";
392 break;
393 case PG_WAIT_TIMEOUT:
394 event_type = "Timeout";
395 break;
396 case PG_WAIT_IO:
397 event_type = "IO";
398 break;
400 event_type = "InjectionPoint";
401 break;
402 default:
403 event_type = "???";
404 break;
405 }
406
407 return event_type;
408}

References fb(), PG_WAIT_ACTIVITY, PG_WAIT_BUFFER, PG_WAIT_CLIENT, PG_WAIT_EXTENSION, PG_WAIT_INJECTIONPOINT, PG_WAIT_IO, PG_WAIT_IPC, PG_WAIT_LOCK, PG_WAIT_LWLOCK, PG_WAIT_TIMEOUT, and WAIT_EVENT_CLASS_MASK.

Referenced by pg_isolation_test_session_is_blocked(), pg_stat_get_activity(), pg_stat_get_backend_wait_event_type(), and WaitEventCustomNew().

◆ pgstat_report_wait_end()

static void pgstat_report_wait_end ( void  )
inlinestatic

Definition at line 83 of file wait_event.h.

84{
85 /* see pgstat_report_wait_start() */
86 *(volatile uint32 *) my_wait_event_info = 0;
87}
PGDLLIMPORT uint32 * my_wait_event_info
Definition wait_event.c:42

References my_wait_event_info.

Referenced by AbortSubTransaction(), AbortTransaction(), AddToDataDirLockFile(), ApplyLogicalMappingFile(), assign_wal_sync_method(), AutoVacLauncherMain(), BackgroundWriterMain(), basebackup_read_file(), BootStrapXLOG(), BufferLockAcquire(), CheckpointerMain(), CheckPointLogicalRewriteHeap(), clone_file(), copy_file(), CopyGetData(), CopySendEndOfRow(), CreateCheckPoint(), CreateDirAndVersionFile(), CreateLockFile(), dsm_impl_mmap(), dsm_impl_posix_resize(), ExecuteRecoveryCommand(), FileFallocate(), FilePrefetch(), FileReadV(), FileSync(), FileTruncate(), FileWriteback(), FileWriteV(), FileZero(), heap_xlog_logical_rewrite(), issue_xlog_fsync(), LWLockReportWaitEnd(), perform_spin_delay(), pgaio_io_perform_synchronously(), pgarch_archiveXlog(), ProcArrayGroupClearXid(), read_relmap_file(), ReadControlFile(), readTimeLineHistory(), ReadTwoPhaseFile(), RecheckDataDirLockFile(), RecreateTwoPhaseFile(), ReorderBufferSerializeChange(), RestoreArchivedFile(), RestoreSlotFromDisk(), SaveSlotToPath(), SendTimeLineHistory(), shell_archive_file(), ShutdownAuxiliaryProcess(), SlruPhysicalReadPage(), SlruPhysicalWritePage(), SlruSyncFileTag(), SnapBuildRestoreContents(), SnapBuildSerialize(), TransactionGroupUpdateXidStatus(), update_controlfile(), vacuum_delay_point(), WaitEventSetWait(), WaitExceedsMaxStandbyDelay(), WALRead(), WalSndErrorCleanup(), WalSummarizerMain(), WalWriterMain(), write_relmap_file(), WriteControlFile(), writeTimeLineHistory(), writeTimeLineHistoryFile(), XLogFileCopy(), XLogFileInitInternal(), XLogFlush(), XLogPageRead(), XLogWalRcvWrite(), and XLogWrite().

◆ pgstat_report_wait_start()

static void pgstat_report_wait_start ( uint32  wait_event_info)
inlinestatic

Definition at line 67 of file wait_event.h.

68{
69 /*
70 * Since this is a four-byte field which is always read and written as
71 * four-bytes, updates are atomic.
72 */
73 *(volatile uint32 *) my_wait_event_info = wait_event_info;
74}

References my_wait_event_info.

Referenced by AddToDataDirLockFile(), ApplyLogicalMappingFile(), assign_wal_sync_method(), basebackup_read_file(), BootStrapXLOG(), BufferLockAcquire(), CheckPointLogicalRewriteHeap(), clone_file(), copy_file(), CopyGetData(), CopySendEndOfRow(), CreateCheckPoint(), CreateDirAndVersionFile(), CreateLockFile(), dsm_impl_mmap(), dsm_impl_posix_resize(), ExecuteRecoveryCommand(), FileFallocate(), FilePrefetch(), FileReadV(), FileSync(), FileTruncate(), FileWriteback(), FileWriteV(), FileZero(), heap_xlog_logical_rewrite(), issue_xlog_fsync(), LWLockReportWaitStart(), perform_spin_delay(), pgaio_io_perform_synchronously(), ProcArrayGroupClearXid(), read_relmap_file(), ReadControlFile(), readTimeLineHistory(), ReadTwoPhaseFile(), RecheckDataDirLockFile(), RecreateTwoPhaseFile(), ReorderBufferSerializeChange(), RestoreArchivedFile(), RestoreSlotFromDisk(), SaveSlotToPath(), SendTimeLineHistory(), shell_archive_file(), SlruPhysicalReadPage(), SlruPhysicalWritePage(), SlruSyncFileTag(), SnapBuildRestoreContents(), SnapBuildSerialize(), TransactionGroupUpdateXidStatus(), update_controlfile(), vacuum_delay_point(), WaitEventSetWait(), WaitExceedsMaxStandbyDelay(), WALRead(), write_relmap_file(), WriteControlFile(), writeTimeLineHistory(), writeTimeLineHistoryFile(), XLogFileCopy(), XLogFileInitInternal(), XLogFlush(), XLogPageRead(), XLogWalRcvWrite(), and XLogWrite().

◆ pgstat_reset_wait_event_storage()

void pgstat_reset_wait_event_storage ( void  )
extern

Definition at line 347 of file wait_event.c.

348{
350}
static uint32 local_my_wait_event_info
Definition wait_event.c:41
uint32 * my_wait_event_info
Definition wait_event.c:42

References local_my_wait_event_info, and my_wait_event_info.

Referenced by AuxiliaryProcKill(), and ProcKill().

◆ pgstat_set_wait_event_storage()

void pgstat_set_wait_event_storage ( uint32 wait_event_info)
extern

Definition at line 335 of file wait_event.c.

336{
337 my_wait_event_info = wait_event_info;
338}

References my_wait_event_info.

Referenced by InitAuxiliaryProcess(), and InitProcess().

◆ WaitEventExtensionNew()

uint32 WaitEventExtensionNew ( const char wait_event_name)
extern

Definition at line 149 of file wait_event.c.

150{
151 return WaitEventCustomNew(PG_WAIT_EXTENSION, wait_event_name);
152}
static uint32 WaitEventCustomNew(uint32 classId, const char *wait_event_name)
Definition wait_event.c:161

References PG_WAIT_EXTENSION, and WaitEventCustomNew().

Referenced by connect_pg_server(), dblink_connect(), dblink_get_conn(), dblink_init(), GetConnection(), pgfdw_get_cleanup_result(), test_shm_mq_pipelined(), wait_for_workers_to_become_ready(), and worker_spi_main().

◆ WaitEventInjectionPointNew()

uint32 WaitEventInjectionPointNew ( const char wait_event_name)
extern

Definition at line 155 of file wait_event.c.

156{
157 return WaitEventCustomNew(PG_WAIT_INJECTIONPOINT, wait_event_name);
158}

References PG_WAIT_INJECTIONPOINT, and WaitEventCustomNew().

Referenced by injection_wait(), and test_aio_shmem_init().

Variable Documentation

◆ my_wait_event_info