twophase.h 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*-------------------------------------------------------------------------
  2. *
  3. * twophase.h
  4. * Two-phase-commit related declarations.
  5. *
  6. *
  7. * Portions Copyright (c) 1996-2022, 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. #include "access/xact.h"
  17. #include "access/xlogdefs.h"
  18. #include "datatype/timestamp.h"
  19. #include "storage/lock.h"
  20. /*
  21. * GlobalTransactionData is defined in twophase.c; other places have no
  22. * business knowing the internal definition.
  23. */
  24. typedef struct GlobalTransactionData *GlobalTransaction;
  25. /* GUC variable */
  26. extern PGDLLIMPORT int max_prepared_xacts;
  27. extern Size TwoPhaseShmemSize(void);
  28. extern void TwoPhaseShmemInit(void);
  29. extern void AtAbort_Twophase(void);
  30. extern void PostPrepare_Twophase(void);
  31. extern TransactionId TwoPhaseGetXidByVirtualXID(VirtualTransactionId vxid,
  32. bool *have_more);
  33. extern PGPROC *TwoPhaseGetDummyProc(TransactionId xid, bool lock_held);
  34. extern BackendId TwoPhaseGetDummyBackendId(TransactionId xid, bool lock_held);
  35. extern GlobalTransaction MarkAsPreparing(TransactionId xid, const char *gid,
  36. TimestampTz prepared_at,
  37. Oid owner, Oid databaseid);
  38. extern void StartPrepare(GlobalTransaction gxact);
  39. extern void EndPrepare(GlobalTransaction gxact);
  40. extern bool StandbyTransactionIdIsPrepared(TransactionId xid);
  41. extern TransactionId PrescanPreparedTransactions(TransactionId **xids_p,
  42. int *nxids_p);
  43. extern void StandbyRecoverPreparedTransactions(void);
  44. extern void RecoverPreparedTransactions(void);
  45. extern void CheckPointTwoPhase(XLogRecPtr redo_horizon);
  46. extern void FinishPreparedTransaction(const char *gid, bool isCommit);
  47. extern void PrepareRedoAdd(char *buf, XLogRecPtr start_lsn,
  48. XLogRecPtr end_lsn, RepOriginId origin_id);
  49. extern void PrepareRedoRemove(TransactionId xid, bool giveWarning);
  50. extern void restoreTwoPhaseData(void);
  51. extern bool LookupGXact(const char *gid, XLogRecPtr prepare_at_lsn,
  52. TimestampTz origin_prepare_timestamp);
  53. #endif /* TWOPHASE_H */