PostgreSQL Source Code git master
Loading...
Searching...
No Matches
locktag.h
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * locktag.h
4 * LOCKTAG declarations, for lookups in the Postgres lock hashtable.
5 *
6 *
7 * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
8 * Portions Copyright (c) 1994, Regents of the University of California
9 *
10 * src/include/storage/locktag.h
11 *
12 *-------------------------------------------------------------------------
13 */
14
15#ifndef _PG_LOCKTAG_H_
16#define _PG_LOCKTAG_H_
17
18/*
19 * Lock methods are identified by LOCKMETHODID. (Despite the declaration as
20 * uint16, we are constrained to 256 lockmethods by the layout of LOCKTAG.)
21 */
23
24/* These identify the known lock methods */
25#define DEFAULT_LOCKMETHOD 1
26#define USER_LOCKMETHOD 2
27
28/*
29 * LOCKTAG is the key information needed to look up a LOCK item in the
30 * lock hashtable. A LOCKTAG value uniquely identifies a lockable object.
31 *
32 * The LockTagType enum defines the different kinds of objects we can lock.
33 * We can handle up to 256 different LockTagTypes.
34 */
35typedef enum LockTagType
36{
37 LOCKTAG_RELATION, /* whole relation */
38 LOCKTAG_RELATION_EXTEND, /* the right to extend a relation */
39 LOCKTAG_DATABASE_FROZEN_IDS, /* pg_database.datfrozenxid */
40 LOCKTAG_PAGE, /* one page of a relation */
41 LOCKTAG_TUPLE, /* one physical tuple */
42 LOCKTAG_TRANSACTION, /* transaction (for waiting for xact done) */
43 LOCKTAG_VIRTUALTRANSACTION, /* virtual transaction (ditto) */
44 LOCKTAG_SPECULATIVE_TOKEN, /* speculative insertion Xid and token */
45 LOCKTAG_OBJECT, /* non-relation database object */
46 LOCKTAG_USERLOCK, /* reserved for old contrib/userlock code */
47 LOCKTAG_ADVISORY, /* advisory user locks */
48 LOCKTAG_APPLY_TRANSACTION, /* transaction being applied on a logical
49 * replication subscriber */
51
52#define LOCKTAG_LAST_TYPE LOCKTAG_APPLY_TRANSACTION
53
54extern PGDLLIMPORT const char *const LockTagTypeNames[];
55
56/*
57 * The LOCKTAG struct is defined with malice aforethought to fit into 16
58 * bytes with no padding. Note that this would need adjustment if we were
59 * to widen Oid, BlockNumber, or TransactionId to more than 32 bits.
60 *
61 * We include lockmethodid in the locktag so that a single hash table in
62 * shared memory can store locks of different lockmethods.
63 */
64typedef struct LOCKTAG
65{
66 uint32 locktag_field1; /* a 32-bit ID field */
67 uint32 locktag_field2; /* a 32-bit ID field */
68 uint32 locktag_field3; /* a 32-bit ID field */
69 uint16 locktag_field4; /* a 16-bit ID field */
70 uint8 locktag_type; /* see enum LockTagType */
71 uint8 locktag_lockmethodid; /* lockmethod indicator */
73
74/*
75 * These macros define how we map logical IDs of lockable objects into
76 * the physical fields of LOCKTAG. Use these to set up LOCKTAG values,
77 * rather than accessing the fields directly. Note multiple eval of target!
78 */
79
80/* ID info for a relation is DB OID + REL OID; DB OID = 0 if shared */
81#define SET_LOCKTAG_RELATION(locktag,dboid,reloid) \
82 ((locktag).locktag_field1 = (dboid), \
83 (locktag).locktag_field2 = (reloid), \
84 (locktag).locktag_field3 = 0, \
85 (locktag).locktag_field4 = 0, \
86 (locktag).locktag_type = LOCKTAG_RELATION, \
87 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
88
89/* same ID info as RELATION */
90#define SET_LOCKTAG_RELATION_EXTEND(locktag,dboid,reloid) \
91 ((locktag).locktag_field1 = (dboid), \
92 (locktag).locktag_field2 = (reloid), \
93 (locktag).locktag_field3 = 0, \
94 (locktag).locktag_field4 = 0, \
95 (locktag).locktag_type = LOCKTAG_RELATION_EXTEND, \
96 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
97
98/* ID info for frozen IDs is DB OID */
99#define SET_LOCKTAG_DATABASE_FROZEN_IDS(locktag,dboid) \
100 ((locktag).locktag_field1 = (dboid), \
101 (locktag).locktag_field2 = 0, \
102 (locktag).locktag_field3 = 0, \
103 (locktag).locktag_field4 = 0, \
104 (locktag).locktag_type = LOCKTAG_DATABASE_FROZEN_IDS, \
105 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
106
107/* ID info for a page is RELATION info + BlockNumber */
108#define SET_LOCKTAG_PAGE(locktag,dboid,reloid,blocknum) \
109 ((locktag).locktag_field1 = (dboid), \
110 (locktag).locktag_field2 = (reloid), \
111 (locktag).locktag_field3 = (blocknum), \
112 (locktag).locktag_field4 = 0, \
113 (locktag).locktag_type = LOCKTAG_PAGE, \
114 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
115
116/* ID info for a tuple is PAGE info + OffsetNumber */
117#define SET_LOCKTAG_TUPLE(locktag,dboid,reloid,blocknum,offnum) \
118 ((locktag).locktag_field1 = (dboid), \
119 (locktag).locktag_field2 = (reloid), \
120 (locktag).locktag_field3 = (blocknum), \
121 (locktag).locktag_field4 = (offnum), \
122 (locktag).locktag_type = LOCKTAG_TUPLE, \
123 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
124
125/* ID info for a transaction is its TransactionId */
126#define SET_LOCKTAG_TRANSACTION(locktag,xid) \
127 ((locktag).locktag_field1 = (xid), \
128 (locktag).locktag_field2 = 0, \
129 (locktag).locktag_field3 = 0, \
130 (locktag).locktag_field4 = 0, \
131 (locktag).locktag_type = LOCKTAG_TRANSACTION, \
132 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
133
134/* ID info for a virtual transaction is its VirtualTransactionId */
135#define SET_LOCKTAG_VIRTUALTRANSACTION(locktag,vxid) \
136 ((locktag).locktag_field1 = (vxid).procNumber, \
137 (locktag).locktag_field2 = (vxid).localTransactionId, \
138 (locktag).locktag_field3 = 0, \
139 (locktag).locktag_field4 = 0, \
140 (locktag).locktag_type = LOCKTAG_VIRTUALTRANSACTION, \
141 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
142
143/*
144 * ID info for a speculative insert is TRANSACTION info +
145 * its speculative insert counter.
146 */
147#define SET_LOCKTAG_SPECULATIVE_INSERTION(locktag,xid,token) \
148 ((locktag).locktag_field1 = (xid), \
149 (locktag).locktag_field2 = (token), \
150 (locktag).locktag_field3 = 0, \
151 (locktag).locktag_field4 = 0, \
152 (locktag).locktag_type = LOCKTAG_SPECULATIVE_TOKEN, \
153 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
154
155/*
156 * ID info for an object is DB OID + CLASS OID + OBJECT OID + SUBID
157 *
158 * Note: object ID has same representation as in pg_depend and
159 * pg_description, but notice that we are constraining SUBID to 16 bits.
160 * Also, we use DB OID = 0 for shared objects such as tablespaces.
161 */
162#define SET_LOCKTAG_OBJECT(locktag,dboid,classoid,objoid,objsubid) \
163 ((locktag).locktag_field1 = (dboid), \
164 (locktag).locktag_field2 = (classoid), \
165 (locktag).locktag_field3 = (objoid), \
166 (locktag).locktag_field4 = (objsubid), \
167 (locktag).locktag_type = LOCKTAG_OBJECT, \
168 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
169
170#define SET_LOCKTAG_ADVISORY(locktag,id1,id2,id3,id4) \
171 ((locktag).locktag_field1 = (id1), \
172 (locktag).locktag_field2 = (id2), \
173 (locktag).locktag_field3 = (id3), \
174 (locktag).locktag_field4 = (id4), \
175 (locktag).locktag_type = LOCKTAG_ADVISORY, \
176 (locktag).locktag_lockmethodid = USER_LOCKMETHOD)
177
178/*
179 * ID info for a remote transaction on a logical replication subscriber is: DB
180 * OID + SUBSCRIPTION OID + TRANSACTION ID + OBJID
181 */
182#define SET_LOCKTAG_APPLY_TRANSACTION(locktag,dboid,suboid,xid,objid) \
183 ((locktag).locktag_field1 = (dboid), \
184 (locktag).locktag_field2 = (suboid), \
185 (locktag).locktag_field3 = (xid), \
186 (locktag).locktag_field4 = (objid), \
187 (locktag).locktag_type = LOCKTAG_APPLY_TRANSACTION, \
188 (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
189
190#endif /* _PG_LOCKTAG_H_ */
#define PGDLLIMPORT
Definition c.h:1423
uint8_t uint8
Definition c.h:616
uint16_t uint16
Definition c.h:617
uint32_t uint32
Definition c.h:618
uint16 LOCKMETHODID
Definition locktag.h:22
LockTagType
Definition locktag.h:36
@ LOCKTAG_OBJECT
Definition locktag.h:45
@ LOCKTAG_RELATION_EXTEND
Definition locktag.h:38
@ LOCKTAG_RELATION
Definition locktag.h:37
@ LOCKTAG_TUPLE
Definition locktag.h:41
@ LOCKTAG_SPECULATIVE_TOKEN
Definition locktag.h:44
@ LOCKTAG_APPLY_TRANSACTION
Definition locktag.h:48
@ LOCKTAG_USERLOCK
Definition locktag.h:46
@ LOCKTAG_DATABASE_FROZEN_IDS
Definition locktag.h:39
@ LOCKTAG_VIRTUALTRANSACTION
Definition locktag.h:43
@ LOCKTAG_TRANSACTION
Definition locktag.h:42
@ LOCKTAG_PAGE
Definition locktag.h:40
@ LOCKTAG_ADVISORY
Definition locktag.h:47
PGDLLIMPORT const char *const LockTagTypeNames[]
Definition lockfuncs.c:28
uint8 locktag_type
Definition locktag.h:70
uint32 locktag_field3
Definition locktag.h:68
uint32 locktag_field1
Definition locktag.h:66
uint8 locktag_lockmethodid
Definition locktag.h:71
uint16 locktag_field4
Definition locktag.h:69
uint32 locktag_field2
Definition locktag.h:67