Commit 60b142b9 authored by Heikki Linnakangas's avatar Heikki Linnakangas

Fix a tiny race condition in predicate locking. Need to hold the lock while

examining the head of predicate locks list. Also, fix the comment of
RemoveTargetIfNoLongerUsed, it was neglected when we changed the way update
chains are handled.

Kevin Grittner
parent c8ae318c
...@@ -1755,9 +1755,8 @@ CoarserLockCovers(const PREDICATELOCKTARGETTAG *newtargettag) ...@@ -1755,9 +1755,8 @@ CoarserLockCovers(const PREDICATELOCKTARGETTAG *newtargettag)
} }
/* /*
* Check whether both the list of related predicate locks and the pointer to * Check whether the list of related predicate locks is empty for a
* a prior version of the row (if this is a tuple lock target) are empty for * predicate lock target, and remove the target if it is.
* a predicate lock target, and remove the target if they are.
*/ */
static void static void
RemoveTargetIfNoLongerUsed(PREDICATELOCKTARGET *target, uint32 targettaghash) RemoveTargetIfNoLongerUsed(PREDICATELOCKTARGET *target, uint32 targettaghash)
...@@ -3120,11 +3119,11 @@ ClearOldPredicateLocks(void) ...@@ -3120,11 +3119,11 @@ ClearOldPredicateLocks(void)
/* /*
* Loop through predicate locks on dummy transaction for summarized data. * Loop through predicate locks on dummy transaction for summarized data.
*/ */
LWLockAcquire(SerializablePredicateLockListLock, LW_SHARED);
predlock = (PREDICATELOCK *) predlock = (PREDICATELOCK *)
SHMQueueNext(&OldCommittedSxact->predicateLocks, SHMQueueNext(&OldCommittedSxact->predicateLocks,
&OldCommittedSxact->predicateLocks, &OldCommittedSxact->predicateLocks,
offsetof(PREDICATELOCK, xactLink)); offsetof(PREDICATELOCK, xactLink));
LWLockAcquire(SerializablePredicateLockListLock, LW_SHARED);
while (predlock) while (predlock)
{ {
PREDICATELOCK *nextpredlock; PREDICATELOCK *nextpredlock;
......
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