]> granicus.if.org Git - postgresql/commit
Fix locking in WAL receiver/sender shmem state structs
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Fri, 30 Jun 2017 22:06:33 +0000 (18:06 -0400)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Fri, 30 Jun 2017 22:06:33 +0000 (18:06 -0400)
commit572d6ee6d41b43b8871f42c7dbbef795523b2dbf
tree8ae14bb1182b66d1042bf10d1ba19ec6dc27f9b2
parent898d24ae2ad7195869c558eb6c126ff6a90474e8
Fix locking in WAL receiver/sender shmem state structs

In WAL receiver and WAL server, some accesses to their corresponding
shared memory control structs were done without holding any kind of
lock, which could lead to inconsistent and possibly insecure results.

In walsender, fix by clarifying the locking rules and following them
correctly, as documented in the new comment in walsender_private.h;
namely that some members can be read in walsender itself without a lock,
because the only writes occur in the same process.  The rest of the
struct requires spinlock for accesses, as usual.

In walreceiver, fix by always holding spinlock while accessing the
struct.

While there is potentially a problem in all branches, it is minor in
stable ones.  This only became a real problem in pg10 because of quorum
commit in synchronous replication (commit 3901fd70cc7c), and a potential
security problem in walreceiver because a superuser() check was removed
by default monitoring roles (commit 25fff40798fc).  Thus, no backpatch.

In passing, clean up some leftover braces which were used to create
unconditional blocks.  Once upon a time these were used for
volatile-izing accesses to those shmem structs, which is no longer
required.  Many other occurrences of this pattern remain.

Author: Michaël Paquier
Reported-by: Michaël Paquier
Reviewed-by: Masahiko Sawada, Kyotaro Horiguchi, Thomas Munro,
Robert Haas
Discussion: https://postgr.es/m/CAB7nPqTWYqtzD=LN_oDaf9r-hAjUEPAy0B9yRkhcsLdRN8fzrw@mail.gmail.com
src/backend/replication/syncrep.c
src/backend/replication/walreceiver.c
src/backend/replication/walsender.c
src/include/replication/walreceiver.h
src/include/replication/walsender_private.h