shm_mq: Fix detach race condition.
authorRobert Haas <rhaas@postgresql.org>
Mon, 5 Mar 2018 20:12:49 +0000 (15:12 -0500)
committerRobert Haas <rhaas@postgresql.org>
Mon, 5 Mar 2018 20:12:49 +0000 (15:12 -0500)
commit42d7074ebb832e511d1edec8091cd474d169eef1
tree8a280a8c71ebe0e82c018230207f8193052925ef
parent2f3e2340cd1b67e91cefdf45e4c915297d1034e2
shm_mq: Fix detach race condition.

Commit 34db06ef9a1d7f36391c64293bf1e0ce44a33915 adopted a lock-free
design for shm_mq.c, but it introduced a race condition that could
lose messages.  When shm_mq_receive_bytes() detects that the other end
has detached, it must make sure that it has seen the final version of
mq_bytes_written, or it might miss a message sent before detaching.

Thomas Munro

Discussion: https://postgr.es/m/CAEepm%3D2myZ4qxpt1a%3DC%2BwEv3o188K13K3UvD-44FK0SdAzHy%2Bw%40mail.gmail.com
src/backend/storage/ipc/shm_mq.c