PostgreSQL Source Code git master
Loading...
Searching...
No Matches
twophase.h
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * twophase.h
4 * Two-phase-commit related declarations.
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/access/twophase.h
11 *
12 *-------------------------------------------------------------------------
13 */
14#ifndef TWOPHASE_H
15#define TWOPHASE_H
16
17#include "access/xact.h"
18#include "access/xlogdefs.h"
19#include "datatype/timestamp.h"
20
21/*
22 * forward references in this file
23 */
24typedef struct PGPROC PGPROC;
26
27/*
28 * GlobalTransactionData is defined in twophase.c; other places have no
29 * business knowing the internal definition.
30 */
32
33/* GUC variable */
35
36extern void AtAbort_Twophase(void);
37extern void PostPrepare_Twophase(void);
38
40 bool *have_more);
43
47
51
53 int *nxids_p);
55extern void RecoverPreparedTransactions(void);
56
58
59extern void FinishPreparedTransaction(const char *gid, bool isCommit);
60
61extern void PrepareRedoAdd(FullTransactionId fxid, char *buf,
62 XLogRecPtr start_lsn, XLogRecPtr end_lsn,
63 ReplOriginId origin_id);
64extern void PrepareRedoRemove(TransactionId xid, bool giveWarning);
65extern void restoreTwoPhaseData(void);
66extern bool LookupGXact(const char *gid, XLogRecPtr prepare_end_lsn,
68
69extern void TwoPhaseTransactionGid(Oid subid, TransactionId xid, char *gid_res,
70 int szgid);
71extern bool LookupGXactBySubid(Oid subid);
72
74
75#endif /* TWOPHASE_H */
#define PGDLLIMPORT
Definition c.h:1421
uint32 TransactionId
Definition c.h:736
int64 TimestampTz
Definition timestamp.h:39
static char buf[DEFAULT_XLOG_SEG_SIZE]
unsigned int Oid
static int fb(int x)
TimestampTz prepared_at
Definition twophase.c:154
XLogRecPtr prepare_end_lsn
Definition twophase.c:164
FullTransactionId fxid
Definition twophase.c:165
char gid[GIDSIZE]
Definition twophase.c:172
Definition proc.h:179
TransactionId TwoPhaseGetOldestXidInCommit(void)
Definition twophase.c:2835
void TwoPhaseTransactionGid(Oid subid, TransactionId xid, char *gid_res, int szgid)
Definition twophase.c:2753
void RecoverPreparedTransactions(void)
Definition twophase.c:2089
struct GlobalTransactionData * GlobalTransaction
Definition twophase.h:31
void restoreTwoPhaseData(void)
Definition twophase.c:1910
bool LookupGXact(const char *gid, XLogRecPtr prepare_end_lsn, TimestampTz origin_prepare_timestamp)
Definition twophase.c:2694
GlobalTransaction MarkAsPreparing(FullTransactionId fxid, const char *gid, TimestampTz prepared_at, Oid owner, Oid databaseid)
Definition twophase.c:365
void PrepareRedoAdd(FullTransactionId fxid, char *buf, XLogRecPtr start_lsn, XLogRecPtr end_lsn, ReplOriginId origin_id)
Definition twophase.c:2513
void AtAbort_Twophase(void)
Definition twophase.c:310
int TwoPhaseGetDummyProcNumber(FullTransactionId fxid, bool lock_held)
Definition twophase.c:914
void FinishPreparedTransaction(const char *gid, bool isCommit)
Definition twophase.c:1503
TransactionId TwoPhaseGetXidByVirtualXID(VirtualTransactionId vxid, bool *have_more)
Definition twophase.c:862
void PrepareRedoRemove(TransactionId xid, bool giveWarning)
Definition twophase.c:2670
void EndPrepare(GlobalTransaction gxact)
Definition twophase.c:1151
TransactionId PrescanPreparedTransactions(TransactionId **xids_p, int *nxids_p)
Definition twophase.c:1972
void StartPrepare(GlobalTransaction gxact)
Definition twophase.c:1058
void StandbyRecoverPreparedTransactions(void)
Definition twophase.c:2051
void PostPrepare_Twophase(void)
Definition twophase.c:350
bool LookupGXactBySubid(Oid subid)
Definition twophase.c:2803
PGPROC * TwoPhaseGetDummyProc(FullTransactionId fxid, bool lock_held)
Definition twophase.c:929
void CheckPointTwoPhase(XLogRecPtr redo_horizon)
Definition twophase.c:1828
bool StandbyTransactionIdIsPrepared(TransactionId xid)
Definition twophase.c:1473
PGDLLIMPORT int max_prepared_xacts
Definition twophase.c:118
uint16 ReplOriginId
Definition xlogdefs.h:69
uint64 XLogRecPtr
Definition xlogdefs.h:21