1 /*-------------------------------------------------------------------------
4 * POSTGRES lock manager definitions.
7 * Portions Copyright (c) 1996-2021, PostgreSQL Global Development Group
8 * Portions Copyright (c) 1994, Regents of the University of California
10 * src/include/storage/lmgr.h
12 *-------------------------------------------------------------------------
17 #include "lib/stringinfo.h"
18 #include "storage/itemptr.h"
19 #include "storage/lock.h"
20 #include "utils/rel.h"
23 /* XactLockTableWait operations */
24 typedef enum XLTW_Oper
32 XLTW_InsertIndexUnique
,
34 XLTW_RecheckExclusionConstr
37 extern void RelationInitLockInfo(Relation relation
);
40 extern void LockRelationOid(Oid relid
, LOCKMODE lockmode
);
41 extern bool ConditionalLockRelationOid(Oid relid
, LOCKMODE lockmode
);
42 extern void UnlockRelationId(LockRelId
*relid
, LOCKMODE lockmode
);
43 extern void UnlockRelationOid(Oid relid
, LOCKMODE lockmode
);
45 extern void LockRelation(Relation relation
, LOCKMODE lockmode
);
46 extern bool ConditionalLockRelation(Relation relation
, LOCKMODE lockmode
);
47 extern void UnlockRelation(Relation relation
, LOCKMODE lockmode
);
48 extern bool CheckRelationLockedByMe(Relation relation
, LOCKMODE lockmode
,
50 extern bool LockHasWaitersRelation(Relation relation
, LOCKMODE lockmode
);
52 extern void LockRelationIdForSession(LockRelId
*relid
, LOCKMODE lockmode
);
53 extern void UnlockRelationIdForSession(LockRelId
*relid
, LOCKMODE lockmode
);
55 /* Lock a relation for extension */
56 extern void LockRelationForExtension(Relation relation
, LOCKMODE lockmode
);
57 extern void UnlockRelationForExtension(Relation relation
, LOCKMODE lockmode
);
58 extern bool ConditionalLockRelationForExtension(Relation relation
,
60 extern int RelationExtensionLockWaiterCount(Relation relation
);
62 /* Lock to recompute pg_database.datfrozenxid in the current database */
63 extern void LockDatabaseFrozenIds(LOCKMODE lockmode
);
65 /* Lock a page (currently only used within indexes) */
66 extern void LockPage(Relation relation
, BlockNumber blkno
, LOCKMODE lockmode
);
67 extern bool ConditionalLockPage(Relation relation
, BlockNumber blkno
, LOCKMODE lockmode
);
68 extern void UnlockPage(Relation relation
, BlockNumber blkno
, LOCKMODE lockmode
);
70 /* Lock a tuple (see heap_lock_tuple before assuming you understand this) */
71 extern void LockTuple(Relation relation
, ItemPointer tid
, LOCKMODE lockmode
);
72 extern bool ConditionalLockTuple(Relation relation
, ItemPointer tid
,
74 extern void UnlockTuple(Relation relation
, ItemPointer tid
, LOCKMODE lockmode
);
76 /* Lock an XID (used to wait for a transaction to finish) */
77 extern void XactLockTableInsert(TransactionId xid
);
78 extern void XactLockTableDelete(TransactionId xid
);
79 extern void XactLockTableWait(TransactionId xid
, Relation rel
,
80 ItemPointer ctid
, XLTW_Oper oper
);
81 extern bool ConditionalXactLockTableWait(TransactionId xid
);
83 /* Lock VXIDs, specified by conflicting locktags */
84 extern void WaitForLockers(LOCKTAG heaplocktag
, LOCKMODE lockmode
, bool progress
);
85 extern void WaitForLockersMultiple(List
*locktags
, LOCKMODE lockmode
, bool progress
);
87 /* Lock an XID for tuple insertion (used to wait for an insertion to finish) */
88 extern uint32
SpeculativeInsertionLockAcquire(TransactionId xid
);
89 extern void SpeculativeInsertionLockRelease(TransactionId xid
);
90 extern void SpeculativeInsertionWait(TransactionId xid
, uint32 token
);
92 /* Lock a general object (other than a relation) of the current database */
93 extern void LockDatabaseObject(Oid classid
, Oid objid
, uint16 objsubid
,
95 extern void UnlockDatabaseObject(Oid classid
, Oid objid
, uint16 objsubid
,
98 /* Lock a shared-across-databases object (other than a relation) */
99 extern void LockSharedObject(Oid classid
, Oid objid
, uint16 objsubid
,
101 extern void UnlockSharedObject(Oid classid
, Oid objid
, uint16 objsubid
,
104 extern void LockSharedObjectForSession(Oid classid
, Oid objid
, uint16 objsubid
,
106 extern void UnlockSharedObjectForSession(Oid classid
, Oid objid
, uint16 objsubid
,
109 /* Describe a locktag for error messages */
110 extern void DescribeLockTag(StringInfo buf
, const LOCKTAG
*tag
);
112 extern const char *GetLockNameFromTagType(uint16 locktag_type
);