]> granicus.if.org Git - postgresql/commit
Fix a rare race condition when commit_siblings > 0 and a transaction commits
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Tue, 31 Mar 2009 05:18:47 +0000 (05:18 +0000)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Tue, 31 Mar 2009 05:18:47 +0000 (05:18 +0000)
commit199d8bb60a12def69ad54c11ea26325a48c9a2ad
tree73df27a8ebaf90cbff4ad5f1ea2971b858f3709e
parenta6ecfd4719ac7eb2dcd1cdc3b472f25e0c876633
Fix a rare race condition when commit_siblings > 0 and a transaction commits
at the same instant as a new backend is spawned. Since CountActiveBackends()
doesn't hold ProcArrayLock, it needs to be prepared for the case that a
pointer at the end of the proc array is still NULL even though numProcs says
it should be valid, since it doesn't hold ProcArrayLock. Backpatch to 8.1.
8.0 and earlier had this right, but it was broken in the split of PGPROC and
sinval shared memory arrays.

Per report and proposal by Marko Kreen.
src/backend/storage/ipc/procarray.c