summaryrefslogtreecommitdiff
path: root/src/backend
diff options
context:
space:
mode:
Diffstat (limited to 'src/backend')
-rw-r--r--src/backend/storage/ipc/procarray.c28
-rw-r--r--src/backend/storage/lmgr/proc.c8
2 files changed, 18 insertions, 18 deletions
diff --git a/src/backend/storage/ipc/procarray.c b/src/backend/storage/ipc/procarray.c
index 6ded0f0f126..91218d0e56b 100644
--- a/src/backend/storage/ipc/procarray.c
+++ b/src/backend/storage/ipc/procarray.c
@@ -497,14 +497,14 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid)
Assert(TransactionIdIsValid(allPgXact[proc->pgprocno].xid));
/* Add ourselves to the list of processes needing a group XID clear. */
- proc->clearXid = true;
- proc->backendLatestXid = latestXid;
+ proc->procArrayGroupMember = true;
+ proc->procArrayGroupMemberXid = latestXid;
while (true)
{
- nextidx = pg_atomic_read_u32(&procglobal->firstClearXidElem);
- pg_atomic_write_u32(&proc->nextClearXidElem, nextidx);
+ nextidx = pg_atomic_read_u32(&procglobal->procArrayGroupFirst);
+ pg_atomic_write_u32(&proc->procArrayGroupNext, nextidx);
- if (pg_atomic_compare_exchange_u32(&procglobal->firstClearXidElem,
+ if (pg_atomic_compare_exchange_u32(&procglobal->procArrayGroupFirst,
&nextidx,
(uint32) proc->pgprocno))
break;
@@ -523,12 +523,12 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid)
{
/* acts as a read barrier */
PGSemaphoreLock(&proc->sem);
- if (!proc->clearXid)
+ if (!proc->procArrayGroupMember)
break;
extraWaits++;
}
- Assert(pg_atomic_read_u32(&proc->nextClearXidElem) == INVALID_PGPROCNO);
+ Assert(pg_atomic_read_u32(&proc->procArrayGroupNext) == INVALID_PGPROCNO);
/* Fix semaphore count for any absorbed wakeups */
while (extraWaits-- > 0)
@@ -546,8 +546,8 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid)
*/
while (true)
{
- nextidx = pg_atomic_read_u32(&procglobal->firstClearXidElem);
- if (pg_atomic_compare_exchange_u32(&procglobal->firstClearXidElem,
+ nextidx = pg_atomic_read_u32(&procglobal->procArrayGroupFirst);
+ if (pg_atomic_compare_exchange_u32(&procglobal->procArrayGroupFirst,
&nextidx,
INVALID_PGPROCNO))
break;
@@ -562,10 +562,10 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid)
PGPROC *proc = &allProcs[nextidx];
PGXACT *pgxact = &allPgXact[nextidx];
- ProcArrayEndTransactionInternal(proc, pgxact, proc->backendLatestXid);
+ ProcArrayEndTransactionInternal(proc, pgxact, proc->procArrayGroupMemberXid);
/* Move to next proc in list. */
- nextidx = pg_atomic_read_u32(&proc->nextClearXidElem);
+ nextidx = pg_atomic_read_u32(&proc->procArrayGroupNext);
}
/* We're done with the lock now. */
@@ -582,13 +582,13 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid)
{
PGPROC *proc = &allProcs[wakeidx];
- wakeidx = pg_atomic_read_u32(&proc->nextClearXidElem);
- pg_atomic_write_u32(&proc->nextClearXidElem, INVALID_PGPROCNO);
+ wakeidx = pg_atomic_read_u32(&proc->procArrayGroupNext);
+ pg_atomic_write_u32(&proc->procArrayGroupNext, INVALID_PGPROCNO);
/* ensure all previous writes are visible before follower continues. */
pg_write_barrier();
- proc->clearXid = false;
+ proc->procArrayGroupMember = false;
if (proc != MyProc)
PGSemaphoreUnlock(&proc->sem);
diff --git a/src/backend/storage/lmgr/proc.c b/src/backend/storage/lmgr/proc.c
index 084be5a026c..844222eec2d 100644
--- a/src/backend/storage/lmgr/proc.c
+++ b/src/backend/storage/lmgr/proc.c
@@ -181,7 +181,7 @@ InitProcGlobal(void)
ProcGlobal->startupBufferPinWaitBufId = -1;
ProcGlobal->walwriterLatch = NULL;
ProcGlobal->checkpointerLatch = NULL;
- pg_atomic_init_u32(&ProcGlobal->firstClearXidElem, INVALID_PGPROCNO);
+ pg_atomic_init_u32(&ProcGlobal->procArrayGroupFirst, INVALID_PGPROCNO);
/*
* Create and initialize all the PGPROC structures we'll need. There are
@@ -396,9 +396,9 @@ InitProcess(void)
SHMQueueElemInit(&(MyProc->syncRepLinks));
/* Initialize fields for group XID clearing. */
- MyProc->clearXid = false;
- MyProc->backendLatestXid = InvalidTransactionId;
- pg_atomic_init_u32(&MyProc->nextClearXidElem, INVALID_PGPROCNO);
+ MyProc->procArrayGroupMember = false;
+ MyProc->procArrayGroupMemberXid = InvalidTransactionId;
+ pg_atomic_init_u32(&MyProc->procArrayGroupNext, INVALID_PGPROCNO);
/* Check that group locking fields are in a proper initial state. */
Assert(MyProc->lockGroupLeaderIdentifier == 0);