⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 proc.h

📁 PostgreSQL 8.1.4的源码 适用于Linux下的开源数据库系统
💻 H
字号:
/*------------------------------------------------------------------------- * * proc.h *	  per-process shared memory data structures * * * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $PostgreSQL: pgsql/src/include/storage/proc.h,v 1.84 2005/10/15 02:49:46 momjian Exp $ * *------------------------------------------------------------------------- */#ifndef _PROC_H_#define _PROC_H_#include "access/xlog.h"#include "storage/lock.h"#include "storage/pg_sema.h"/* * Each backend advertises up to PGPROC_MAX_CACHED_SUBXIDS TransactionIds * for non-aborted subtransactions of its current top transaction.	These * have to be treated as running XIDs by other backends. * * We also keep track of whether the cache overflowed (ie, the transaction has * generated at least one subtransaction that didn't fit in the cache). * If none of the caches have overflowed, we can assume that an XID that's not * listed anywhere in the PGPROC array is not a running transaction.  Else we * have to look at pg_subtrans. */#define PGPROC_MAX_CACHED_SUBXIDS 64	/* XXX guessed-at value */struct XidCache{	bool		overflowed;	int			nxids;	TransactionId xids[PGPROC_MAX_CACHED_SUBXIDS];};/* * Each backend has a PGPROC struct in shared memory.  There is also a list of * currently-unused PGPROC structs that will be reallocated to new backends. * * links: list link for any list the PGPROC is in.	When waiting for a lock, * the PGPROC is linked into that lock's waitProcs queue.  A recycled PGPROC * is linked into ProcGlobal's freeProcs list. * * Note: twophase.c also sets up a dummy PGPROC struct for each currently * prepared transaction.  These PGPROCs appear in the ProcArray data structure * so that the prepared transactions appear to be still running and are * correctly shown as holding locks.  A prepared transaction PGPROC can be * distinguished from a real one at need by the fact that it has pid == 0. * The semaphore and lock-related fields in a prepared-xact PGPROC are unused. */struct PGPROC{	/* proc->links MUST BE FIRST IN STRUCT (see ProcSleep,ProcWakeup,etc) */	SHM_QUEUE	links;			/* list link if process is in a list */	PGSemaphoreData sem;		/* ONE semaphore to sleep on */	int			waitStatus;		/* STATUS_OK or STATUS_ERROR after wakeup */	TransactionId xid;			/* transaction currently being executed by								 * this proc */	TransactionId xmin;			/* minimal running XID as it was when we were								 * starting our xact: vacuum must not remove								 * tuples deleted by xid >= xmin ! */	int			pid;			/* This backend's process id, or 0 */	Oid			databaseId;		/* OID of database this backend is using */	Oid			roleId;			/* OID of role using this backend */	/* Info about LWLock the process is currently waiting for, if any. */	bool		lwWaiting;		/* true if waiting for an LW lock */	bool		lwExclusive;	/* true if waiting for exclusive access */	struct PGPROC *lwWaitLink;	/* next waiter for same LW lock */	/* Info about lock the process is currently waiting for, if any. */	/* waitLock and waitProcLock are NULL if not currently waiting. */	LOCK	   *waitLock;		/* Lock object we're sleeping on ... */	PROCLOCK   *waitProcLock;	/* Per-holder info for awaited lock */	LOCKMODE	waitLockMode;	/* type of lock we're waiting for */	LOCKMASK	heldLocks;		/* bitmask for lock types already held on this								 * lock object by this backend */	SHM_QUEUE	procLocks;		/* list of PROCLOCK objects for locks held or								 * awaited by this backend */	struct XidCache subxids;	/* cache for subtransaction XIDs */};/* NOTE: "typedef struct PGPROC PGPROC" appears in storage/lock.h. */extern DLLIMPORT PGPROC *MyProc;/* * There is one ProcGlobal struct for the whole installation. */typedef struct PROC_HDR{	/* Head of list of free PGPROC structures */	SHMEM_OFFSET freeProcs;	/* Current shared estimate of appropriate spins_per_delay value */	int			spins_per_delay;} PROC_HDR;#define DUMMY_PROC_DEFAULT	0#define DUMMY_PROC_BGWRITER 1#define NUM_DUMMY_PROCS		2/* configurable options */extern int	DeadlockTimeout;extern int	StatementTimeout;extern volatile bool cancel_from_timeout;/* * Function Prototypes */extern int	ProcGlobalSemas(void);extern Size ProcGlobalShmemSize(void);extern void InitProcGlobal(void);extern void InitProcess(void);extern void InitDummyProcess(int proctype);extern bool HaveNFreeProcs(int n);extern void ProcReleaseLocks(bool isCommit);extern void ProcQueueInit(PROC_QUEUE *queue);extern int ProcSleep(LockMethod lockMethodTable, LOCKMODE lockmode,		  LOCK *lock, PROCLOCK *proclock);extern PGPROC *ProcWakeup(PGPROC *proc, int waitStatus);extern void ProcLockWakeup(LockMethod lockMethodTable, LOCK *lock);extern bool LockWaitCancel(void);extern void ProcWaitForSignal(void);extern void ProcCancelWaitForSignal(void);extern void ProcSendSignal(int pid);extern bool enable_sig_alarm(int delayms, bool is_statement_timeout);extern bool disable_sig_alarm(bool is_statement_timeout);extern void handle_sig_alarm(SIGNAL_ARGS);#endif   /* PROC_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -