Commit 2f39106a authored by Alexander Korotkov's avatar Alexander Korotkov

Replace CAS loop with single TAS in ProcArrayGroupClearXid()

Single pg_atomic_exchange_u32() is expected to be faster than loop of
pg_atomic_compare_exchange_u32().  Also, it would be consistent with
clog group update code.

Discussion: https://postgr.es/m/CAPpHfdtxLsC-bqfxFcHswZ91OxXcZVNDBBVfg9tAWU0jvn1tQA%40mail.gmail.com
Reviewed-by: Amit Kapila
parent db361db2
...@@ -542,14 +542,8 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid) ...@@ -542,14 +542,8 @@ ProcArrayGroupClearXid(PGPROC *proc, TransactionId latestXid)
* group XID clearing, saving a pointer to the head of the list. Trying * group XID clearing, saving a pointer to the head of the list. Trying
* to pop elements one at a time could lead to an ABA problem. * to pop elements one at a time could lead to an ABA problem.
*/ */
while (true) nextidx = pg_atomic_exchange_u32(&procglobal->procArrayGroupFirst,
{ INVALID_PGPROCNO);
nextidx = pg_atomic_read_u32(&procglobal->procArrayGroupFirst);
if (pg_atomic_compare_exchange_u32(&procglobal->procArrayGroupFirst,
&nextidx,
INVALID_PGPROCNO))
break;
}
/* Remember head of list so we can perform wakeups after dropping lock. */ /* Remember head of list so we can perform wakeups after dropping lock. */
wakeidx = nextidx; wakeidx = nextidx;
......
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