Commit c91560de authored by Andres Freund's avatar Andres Freund

Move remaining code from tqual.[ch] to heapam.h / heapam_visibility.c.

Given these routines are heap specific, and that there will be more
generic visibility support in via table AM, it makes sense to move the
prototypes to heapam.h (routines like HeapTupleSatisfiesVacuum will
not be exposed in a generic fashion, because they are too storage
specific).

Similarly, the code in tqual.c is specific to heap, so moving it into
access/heap/ makes sense.

Author: Andres Freund
Discussion: https://postgr.es/m/20180703070645.wchpu5muyto5n647@alap3.anarazel.de
parent b7eda3e0
...@@ -22,7 +22,6 @@ ...@@ -22,7 +22,6 @@
#include "storage/smgr.h" #include "storage/smgr.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
PG_MODULE_MAGIC; PG_MODULE_MAGIC;
......
...@@ -38,7 +38,6 @@ ...@@ -38,7 +38,6 @@
#include "utils/builtins.h" #include "utils/builtins.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
#include "utils/varlena.h" #include "utils/varlena.h"
PG_MODULE_MAGIC; PG_MODULE_MAGIC;
......
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
*/ */
#include "postgres.h" #include "postgres.h"
#include "access/heapam.h"
#include "access/relation.h" #include "access/relation.h"
#include "access/transam.h" #include "access/transam.h"
#include "access/visibilitymap.h" #include "access/visibilitymap.h"
...@@ -26,7 +27,6 @@ ...@@ -26,7 +27,6 @@
#include "storage/procarray.h" #include "storage/procarray.h"
#include "storage/lmgr.h" #include "storage/lmgr.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "utils/tqual.h"
#include "commands/vacuum.h" #include "commands/vacuum.h"
PG_FUNCTION_INFO_V1(pgstattuple_approx); PG_FUNCTION_INFO_V1(pgstattuple_approx);
......
...@@ -36,7 +36,6 @@ ...@@ -36,7 +36,6 @@
#include "storage/bufmgr.h" #include "storage/bufmgr.h"
#include "storage/lmgr.h" #include "storage/lmgr.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "utils/tqual.h"
#include "utils/varlena.h" #include "utils/varlena.h"
PG_MODULE_MAGIC; PG_MODULE_MAGIC;
......
...@@ -12,7 +12,7 @@ subdir = src/backend/access/heap ...@@ -12,7 +12,7 @@ subdir = src/backend/access/heap
top_builddir = ../../../.. top_builddir = ../../../..
include $(top_builddir)/src/Makefile.global include $(top_builddir)/src/Makefile.global
OBJS = heapam.o hio.o pruneheap.o rewriteheap.o syncscan.o tuptoaster.o \ OBJS = heapam.o heapam_visibility.o hio.o pruneheap.o rewriteheap.o \
vacuumlazy.o visibilitymap.o syncscan.o tuptoaster.o vacuumlazy.o visibilitymap.o
include $(top_srcdir)/src/backend/common.mk include $(top_srcdir)/src/backend/common.mk
...@@ -66,7 +66,6 @@ ...@@ -66,7 +66,6 @@
#include "utils/lsyscache.h" #include "utils/lsyscache.h"
#include "utils/relcache.h" #include "utils/relcache.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
/* GUC variable */ /* GUC variable */
...@@ -5284,8 +5283,8 @@ test_lockmode_for_conflict(MultiXactStatus status, TransactionId xid, ...@@ -5284,8 +5283,8 @@ test_lockmode_for_conflict(MultiXactStatus status, TransactionId xid,
/* /*
* Note: we *must* check TransactionIdIsInProgress before * Note: we *must* check TransactionIdIsInProgress before
* TransactionIdDidAbort/Commit; see comment at top of tqual.c for an * TransactionIdDidAbort/Commit; see comment at top of heapam_visibility.c
* explanation. * for an explanation.
*/ */
if (TransactionIdIsCurrentTransactionId(xid)) if (TransactionIdIsCurrentTransactionId(xid))
{ {
...@@ -6254,7 +6253,8 @@ FreezeMultiXactId(MultiXactId multi, uint16 t_infomask, ...@@ -6254,7 +6253,8 @@ FreezeMultiXactId(MultiXactId multi, uint16 t_infomask,
* *
* As with all tuple visibility routines, it's critical to test * As with all tuple visibility routines, it's critical to test
* TransactionIdIsInProgress before TransactionIdDidCommit, * TransactionIdIsInProgress before TransactionIdDidCommit,
* because of race conditions explained in detail in tqual.c. * because of race conditions explained in detail in
* heapam_visibility.c.
*/ */
if (TransactionIdIsCurrentTransactionId(xid) || if (TransactionIdIsCurrentTransactionId(xid) ||
TransactionIdIsInProgress(xid)) TransactionIdIsInProgress(xid))
......
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* *
* tqual.c * heapam_visibility.c
* POSTGRES "time qualification" code, ie, tuple visibility rules. * Tuple visibility rules for tuples stored in heap.
* *
* NOTE: all the HeapTupleSatisfies routines will update the tuple's * NOTE: all the HeapTupleSatisfies routines will update the tuple's
* "hint" status bits if we see that the inserting or deleting transaction * "hint" status bits if we see that the inserting or deleting transaction
...@@ -56,13 +56,14 @@ ...@@ -56,13 +56,14 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* IDENTIFICATION * IDENTIFICATION
* src/backend/utils/time/tqual.c * src/backend/access/heap/heapam_visibility.c
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
#include "postgres.h" #include "postgres.h"
#include "access/heapam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/multixact.h" #include "access/multixact.h"
#include "access/subtrans.h" #include "access/subtrans.h"
...@@ -74,7 +75,6 @@ ...@@ -74,7 +75,6 @@
#include "utils/builtins.h" #include "utils/builtins.h"
#include "utils/combocid.h" #include "utils/combocid.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
/* /*
......
...@@ -25,7 +25,6 @@ ...@@ -25,7 +25,6 @@
#include "storage/bufmgr.h" #include "storage/bufmgr.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/tqual.h"
/* Working data for heap_page_prune and subroutines */ /* Working data for heap_page_prune and subroutines */
typedef struct typedef struct
......
...@@ -130,7 +130,6 @@ ...@@ -130,7 +130,6 @@
#include "utils/memutils.h" #include "utils/memutils.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/tqual.h"
#include "storage/procarray.h" #include "storage/procarray.h"
......
...@@ -42,7 +42,6 @@ ...@@ -42,7 +42,6 @@
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/typcache.h" #include "utils/typcache.h"
#include "utils/tqual.h"
#undef TOAST_DEBUG #undef TOAST_DEBUG
......
...@@ -59,7 +59,6 @@ ...@@ -59,7 +59,6 @@
#include "utils/memutils.h" #include "utils/memutils.h"
#include "utils/pg_rusage.h" #include "utils/pg_rusage.h"
#include "utils/timestamp.h" #include "utils/timestamp.h"
#include "utils/tqual.h"
/* /*
......
...@@ -35,7 +35,6 @@ ...@@ -35,7 +35,6 @@
#include "utils/ruleutils.h" #include "utils/ruleutils.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/syscache.h" #include "utils/syscache.h"
#include "utils/tqual.h"
/* ---------------------------------------------------------------- /* ----------------------------------------------------------------
......
...@@ -192,7 +192,7 @@ vacuumLeafPage(spgBulkDeleteState *bds, Relation index, Buffer buffer, ...@@ -192,7 +192,7 @@ vacuumLeafPage(spgBulkDeleteState *bds, Relation index, Buffer buffer,
* happened since VACUUM started. * happened since VACUUM started.
* *
* Note: we could make a tighter test by seeing if the xid is * Note: we could make a tighter test by seeing if the xid is
* "running" according to the active snapshot; but tqual.c doesn't * "running" according to the active snapshot; but snapmgr.c doesn't
* currently export a suitable API, and it's not entirely clear * currently export a suitable API, and it's not entirely clear
* that a tighter test is worth the cycles anyway. * that a tighter test is worth the cycles anyway.
*/ */
......
...@@ -228,8 +228,8 @@ TransactionIdDidAbort(TransactionId transactionId) ...@@ -228,8 +228,8 @@ TransactionIdDidAbort(TransactionId transactionId)
* (and so it's not named TransactionIdDidComplete, which would be the * (and so it's not named TransactionIdDidComplete, which would be the
* appropriate name for a function that worked that way). The intended * appropriate name for a function that worked that way). The intended
* use is just to short-circuit TransactionIdIsInProgress calls when doing * use is just to short-circuit TransactionIdIsInProgress calls when doing
* repeated tqual.c checks for the same XID. If this isn't extremely fast * repeated heapam_visibility.c checks for the same XID. If this isn't
* then it will be counterproductive. * extremely fast then it will be counterproductive.
* *
* Note: * Note:
* Assumes transaction identifier is valid. * Assumes transaction identifier is valid.
......
...@@ -774,10 +774,10 @@ TransactionIdIsCurrentTransactionId(TransactionId xid) ...@@ -774,10 +774,10 @@ TransactionIdIsCurrentTransactionId(TransactionId xid)
* We always say that BootstrapTransactionId is "not my transaction ID" * We always say that BootstrapTransactionId is "not my transaction ID"
* even when it is (ie, during bootstrap). Along with the fact that * even when it is (ie, during bootstrap). Along with the fact that
* transam.c always treats BootstrapTransactionId as already committed, * transam.c always treats BootstrapTransactionId as already committed,
* this causes the tqual.c routines to see all tuples as committed, which * this causes the heapam_visibility.c routines to see all tuples as
* is what we need during bootstrap. (Bootstrap mode only inserts tuples, * committed, which is what we need during bootstrap. (Bootstrap mode
* it never updates or deletes them, so all tuples can be presumed good * only inserts tuples, it never updates or deletes them, so all tuples
* immediately.) * can be presumed good immediately.)
* *
* Likewise, InvalidTransactionId and FrozenTransactionId are certainly * Likewise, InvalidTransactionId and FrozenTransactionId are certainly
* not my transaction ID, so we can just return "false" immediately for * not my transaction ID, so we can just return "false" immediately for
......
...@@ -75,7 +75,6 @@ ...@@ -75,7 +75,6 @@
#include "utils/syscache.h" #include "utils/syscache.h"
#include "utils/tuplesort.h" #include "utils/tuplesort.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
/* Potentially set by pg_upgrade_support functions */ /* Potentially set by pg_upgrade_support functions */
......
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#include <math.h> #include <math.h>
#include "access/genam.h" #include "access/genam.h"
#include "access/heapam.h"
#include "access/multixact.h" #include "access/multixact.h"
#include "access/relation.h" #include "access/relation.h"
#include "access/sysattr.h" #include "access/sysattr.h"
...@@ -63,7 +64,6 @@ ...@@ -63,7 +64,6 @@
#include "utils/sortsupport.h" #include "utils/sortsupport.h"
#include "utils/syscache.h" #include "utils/syscache.h"
#include "utils/timestamp.h" #include "utils/timestamp.h"
#include "utils/tqual.h"
/* Per-index data for ANALYZE */ /* Per-index data for ANALYZE */
......
...@@ -1955,7 +1955,7 @@ asyncQueueProcessPageEntries(volatile QueuePosition *current, ...@@ -1955,7 +1955,7 @@ asyncQueueProcessPageEntries(volatile QueuePosition *current,
* Note that we must test XidInMVCCSnapshot before we test * Note that we must test XidInMVCCSnapshot before we test
* TransactionIdDidCommit, else we might return a message from * TransactionIdDidCommit, else we might return a message from
* a transaction that is not yet visible to snapshots; compare * a transaction that is not yet visible to snapshots; compare
* the comments at the head of tqual.c. * the comments at the head of heapam_visibility.c.
* *
* Also, while our own xact won't be listed in the snapshot, * Also, while our own xact won't be listed in the snapshot,
* we need not check for TransactionIdIsCurrentTransactionId * we need not check for TransactionIdIsCurrentTransactionId
......
...@@ -52,7 +52,6 @@ ...@@ -52,7 +52,6 @@
#include "utils/relmapper.h" #include "utils/relmapper.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/syscache.h" #include "utils/syscache.h"
#include "utils/tqual.h"
#include "utils/tuplesort.h" #include "utils/tuplesort.h"
......
...@@ -51,7 +51,6 @@ ...@@ -51,7 +51,6 @@
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/spccache.h" #include "utils/spccache.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
static TupleTableSlot *BitmapHeapNext(BitmapHeapScanState *node); static TupleTableSlot *BitmapHeapNext(BitmapHeapScanState *node);
......
...@@ -53,7 +53,6 @@ ...@@ -53,7 +53,6 @@
#include "utils/builtins.h" #include "utils/builtins.h"
#include "utils/memutils.h" #include "utils/memutils.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/tqual.h"
static bool ExecOnConflictUpdate(ModifyTableState *mtstate, static bool ExecOnConflictUpdate(ModifyTableState *mtstate,
......
...@@ -25,7 +25,6 @@ ...@@ -25,7 +25,6 @@
#include "storage/predicate.h" #include "storage/predicate.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/tqual.h"
static TupleTableSlot *SampleNext(SampleScanState *node); static TupleTableSlot *SampleNext(SampleScanState *node);
static void tablesample_init(SampleScanState *scanstate); static void tablesample_init(SampleScanState *scanstate);
......
...@@ -56,6 +56,7 @@ ...@@ -56,6 +56,7 @@
#include <unistd.h> #include <unistd.h>
#include <sys/stat.h> #include <sys/stat.h>
#include "access/heapam.h"
#include "access/rewriteheap.h" #include "access/rewriteheap.h"
#include "access/transam.h" #include "access/transam.h"
#include "access/tuptoaster.h" #include "access/tuptoaster.h"
...@@ -78,7 +79,6 @@ ...@@ -78,7 +79,6 @@
#include "utils/memutils.h" #include "utils/memutils.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/relfilenodemap.h" #include "utils/relfilenodemap.h"
#include "utils/tqual.h"
/* entry for a hash table we use to map from xid to our transaction state */ /* entry for a hash table we use to map from xid to our transaction state */
...@@ -1269,7 +1269,7 @@ ReorderBufferCleanupTXN(ReorderBuffer *rb, ReorderBufferTXN *txn) ...@@ -1269,7 +1269,7 @@ ReorderBufferCleanupTXN(ReorderBuffer *rb, ReorderBufferTXN *txn)
/* /*
* Build a hash with a (relfilenode, ctid) -> (cmin, cmax) mapping for use by * Build a hash with a (relfilenode, ctid) -> (cmin, cmax) mapping for use by
* tqual.c's HeapTupleSatisfiesHistoricMVCC. * HeapTupleSatisfiesHistoricMVCC.
*/ */
static void static void
ReorderBufferBuildTupleCidHash(ReorderBuffer *rb, ReorderBufferTXN *txn) ReorderBufferBuildTupleCidHash(ReorderBuffer *rb, ReorderBufferTXN *txn)
......
...@@ -1119,7 +1119,7 @@ SnapBuildProcessRunningXacts(SnapBuild *builder, XLogRecPtr lsn, xl_running_xact ...@@ -1119,7 +1119,7 @@ SnapBuildProcessRunningXacts(SnapBuild *builder, XLogRecPtr lsn, xl_running_xact
* NB: We only increase xmax when a catalog modifying transaction commits * NB: We only increase xmax when a catalog modifying transaction commits
* (see SnapBuildCommitTxn). Because of this, xmax can be lower than * (see SnapBuildCommitTxn). Because of this, xmax can be lower than
* xmin, which looks odd but is correct and actually more efficient, since * xmin, which looks odd but is correct and actually more efficient, since
* we hit fast paths in tqual.c. * we hit fast paths in heapam_visibility.c.
*/ */
builder->xmin = running->oldestRunningXid; builder->xmin = running->oldestRunningXid;
......
...@@ -1498,7 +1498,7 @@ GetMaxSnapshotSubxidCount(void) ...@@ -1498,7 +1498,7 @@ GetMaxSnapshotSubxidCount(void)
* information may not be available. If we find any overflowed subxid arrays, * information may not be available. If we find any overflowed subxid arrays,
* we have to mark the snapshot's subxid data as overflowed, and extra work * we have to mark the snapshot's subxid data as overflowed, and extra work
* *may* need to be done to determine what's running (see XidInMVCCSnapshot() * *may* need to be done to determine what's running (see XidInMVCCSnapshot()
* in tqual.c). * in heapam_visibility.c).
* *
* We also update the following backend-global variables: * We also update the following backend-global variables:
* TransactionXmin: the oldest xmin of any snapshot in use in the * TransactionXmin: the oldest xmin of any snapshot in use in the
......
...@@ -185,6 +185,7 @@ ...@@ -185,6 +185,7 @@
#include "postgres.h" #include "postgres.h"
#include "access/heapam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/slru.h" #include "access/slru.h"
#include "access/subtrans.h" #include "access/subtrans.h"
...@@ -202,7 +203,6 @@ ...@@ -202,7 +203,6 @@
#include "storage/procarray.h" #include "storage/procarray.h"
#include "utils/rel.h" #include "utils/rel.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/tqual.h"
/* Uncomment the next line to test the graceful degradation code. */ /* Uncomment the next line to test the graceful degradation code. */
/* #define TEST_OLDSERXID */ /* #define TEST_OLDSERXID */
......
...@@ -30,6 +30,7 @@ ...@@ -30,6 +30,7 @@
#include "postgres.h" #include "postgres.h"
#include "access/heapam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
...@@ -57,7 +58,6 @@ ...@@ -57,7 +58,6 @@
#include "utils/rls.h" #include "utils/rls.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
#include "utils/syscache.h" #include "utils/syscache.h"
#include "utils/tqual.h"
/* ---------- /* ----------
......
...@@ -8,9 +8,9 @@ ...@@ -8,9 +8,9 @@
* When a tuple is updated or deleted, our standard time qualification rules * When a tuple is updated or deleted, our standard time qualification rules
* consider that it is *still valid* so long as we are in the same command, * consider that it is *still valid* so long as we are in the same command,
* ie, until the next CommandCounterIncrement() or transaction commit. * ie, until the next CommandCounterIncrement() or transaction commit.
* (See utils/time/tqual.c, and note that system catalogs are generally * (See acces/heap/heapam_visibility.c, and note that system catalogs are
* scanned under the most current snapshot available, rather than the * generally scanned under the most current snapshot available, rather than
* transaction snapshot.) At the command boundary, the old tuple stops * the transaction snapshot.) At the command boundary, the old tuple stops
* being valid and the new version, if any, becomes valid. Therefore, * being valid and the new version, if any, becomes valid. Therefore,
* we cannot simply flush a tuple from the system caches during heap_update() * we cannot simply flush a tuple from the system caches during heap_update()
* or heap_delete(). The tuple is still good at that point; what's more, * or heap_delete(). The tuple is still good at that point; what's more,
......
...@@ -12,6 +12,6 @@ subdir = src/backend/utils/time ...@@ -12,6 +12,6 @@ subdir = src/backend/utils/time
top_builddir = ../../../.. top_builddir = ../../../..
include $(top_builddir)/src/Makefile.global include $(top_builddir)/src/Makefile.global
OBJS = combocid.o tqual.o snapmgr.o OBJS = combocid.o snapmgr.o
include $(top_srcdir)/src/backend/common.mk include $(top_srcdir)/src/backend/common.mk
...@@ -60,6 +60,15 @@ typedef struct HeapUpdateFailureData ...@@ -60,6 +60,15 @@ typedef struct HeapUpdateFailureData
CommandId cmax; CommandId cmax;
} HeapUpdateFailureData; } HeapUpdateFailureData;
/* Result codes for HeapTupleSatisfiesVacuum */
typedef enum
{
HEAPTUPLE_DEAD, /* tuple is dead and deletable */
HEAPTUPLE_LIVE, /* tuple is live (committed, no deleter) */
HEAPTUPLE_RECENTLY_DEAD, /* tuple is dead, but not deletable yet */
HEAPTUPLE_INSERT_IN_PROGRESS, /* inserting xact is still in progress */
HEAPTUPLE_DELETE_IN_PROGRESS /* deleting xact is still in progress */
} HTSV_Result;
/* ---------------- /* ----------------
* function prototypes for heap access method * function prototypes for heap access method
...@@ -178,4 +187,29 @@ extern Size SyncScanShmemSize(void); ...@@ -178,4 +187,29 @@ extern Size SyncScanShmemSize(void);
struct VacuumParams; struct VacuumParams;
extern void heap_vacuum_rel(Relation onerel, int options, extern void heap_vacuum_rel(Relation onerel, int options,
struct VacuumParams *params, BufferAccessStrategy bstrategy); struct VacuumParams *params, BufferAccessStrategy bstrategy);
/* in heap/heapam_visibility.c */
extern bool HeapTupleSatisfiesVisibility(HeapTuple stup, Snapshot snapshot,
Buffer buffer);
extern HTSU_Result HeapTupleSatisfiesUpdate(HeapTuple stup, CommandId curcid,
Buffer buffer);
extern HTSV_Result HeapTupleSatisfiesVacuum(HeapTuple stup, TransactionId OldestXmin,
Buffer buffer);
extern void HeapTupleSetHintBits(HeapTupleHeader tuple, Buffer buffer,
uint16 infomask, TransactionId xid);
extern bool HeapTupleHeaderIsOnlyLocked(HeapTupleHeader tuple);
extern bool XidInMVCCSnapshot(TransactionId xid, Snapshot snapshot);
extern bool HeapTupleIsSurelyDead(HeapTuple htup, TransactionId OldestXmin);
/*
* To avoid leaking too much knowledge about reorderbuffer implementation
* details this is implemented in reorderbuffer.c not heapam_visibility.c
*/
struct HTAB;
extern bool ResolveCminCmaxDuringDecoding(struct HTAB *tuplecid_data,
Snapshot snapshot,
HeapTuple htup,
Buffer buffer,
CommandId *cmin, CommandId *cmax);
#endif /* HEAPAM_H */ #endif /* HEAPAM_H */
...@@ -185,8 +185,7 @@ typedef struct SnapshotData ...@@ -185,8 +185,7 @@ typedef struct SnapshotData
} SnapshotData; } SnapshotData;
/* /*
* Result codes for HeapTupleSatisfiesUpdate. This should really be in * Result codes for HeapTupleSatisfiesUpdate.
* tqual.h, but we want to avoid including that file elsewhere.
*/ */
typedef enum typedef enum
{ {
......
/*-------------------------------------------------------------------------
*
* tqual.h
* POSTGRES "time qualification" definitions, ie, tuple visibility rules.
*
* Should be moved/renamed... - vadim 07/28/98
*
* Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* src/include/utils/tqual.h
*
*-------------------------------------------------------------------------
*/
#ifndef TQUAL_H
#define TQUAL_H
#include "utils/snapshot.h"
extern bool HeapTupleSatisfiesVisibility(HeapTuple stup, Snapshot snapshot,
Buffer buffer);
/* Result codes for HeapTupleSatisfiesVacuum */
typedef enum
{
HEAPTUPLE_DEAD, /* tuple is dead and deletable */
HEAPTUPLE_LIVE, /* tuple is live (committed, no deleter) */
HEAPTUPLE_RECENTLY_DEAD, /* tuple is dead, but not deletable yet */
HEAPTUPLE_INSERT_IN_PROGRESS, /* inserting xact is still in progress */
HEAPTUPLE_DELETE_IN_PROGRESS /* deleting xact is still in progress */
} HTSV_Result;
/* Special "satisfies" routines with different APIs */
extern HTSU_Result HeapTupleSatisfiesUpdate(HeapTuple htup,
CommandId curcid, Buffer buffer);
extern HTSV_Result HeapTupleSatisfiesVacuum(HeapTuple htup,
TransactionId OldestXmin, Buffer buffer);
extern bool HeapTupleIsSurelyDead(HeapTuple htup,
TransactionId OldestXmin);
extern void HeapTupleSetHintBits(HeapTupleHeader tuple, Buffer buffer,
uint16 infomask, TransactionId xid);
extern bool HeapTupleHeaderIsOnlyLocked(HeapTupleHeader tuple);
/*
* To avoid leaking too much knowledge about reorderbuffer implementation
* details this is implemented in reorderbuffer.c not tqual.c.
*/
struct HTAB;
extern bool ResolveCminCmaxDuringDecoding(struct HTAB *tuplecid_data,
Snapshot snapshot,
HeapTuple htup,
Buffer buffer,
CommandId *cmin, CommandId *cmax);
#endif /* TQUAL_H */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment