]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Fix bugs in SSI tuple locking.
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Mon, 7 Oct 2013 20:57:40 +0000 (23:57 +0300)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Mon, 7 Oct 2013 21:03:24 +0000 (00:03 +0300)
commitcc736ed91f4c04773fcb8f4683542ce105997e5b
treea0a50de55dd54c7f11ec4bf830bf358068514086
parent4750eae3504e9d74eec883434cf275657d57bd25
Fix bugs in SSI tuple locking.

1. In heap_hot_search_buffer(), the PredicateLockTuple() call is passed
wrong offset number. heapTuple->t_self is set to the tid of the first
tuple in the chain that's visited, not the one actually being read.

2. CheckForSerializableConflictIn() uses the tuple's t_ctid field
instead of t_self to check for exiting predicate locks on the tuple. If
the tuple was updated, but the updater rolled back, t_ctid points to the
aborted dead tuple.

Reported by Hannu Krosing. Backpatch to 9.1.
src/backend/access/heap/heapam.c
src/backend/storage/lmgr/predicate.c