pgsql: shm_mq: Third attempt at fixing nowait behavior in shm_mq_receiv - Mailing list pgsql-committers

From Robert Haas
Subject pgsql: shm_mq: Third attempt at fixing nowait behavior in shm_mq_receiv
Date
Msg-id E1Ztd45-0006gp-Qy@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
shm_mq: Third attempt at fixing nowait behavior in shm_mq_receive.

Commit a1480ec1d3bacb9acb08ec09f22bc25bc033115b purported to fix the
problems with commit b2ccb5f4e6c81305386edb34daf7d1d1e1ee112a, but it
didn't completely fix them.  The problem is that the checks were
performed in the wrong order, leading to a race condition.  If the
sender attached, sent a message, and detached after the receiver
called shm_mq_get_sender and before the receiver called
shm_mq_counterparty_gone, we'd incorrectly return SHM_MQ_DETACHED
before all messages were read.  Repair by reversing the order of
operations, and add a long comment explaining why this new logic is
(hopefully) correct.

Branch
------
REL9_5_STABLE

Details
-------
http://git.postgresql.org/pg/commitdiff/fd5ce6b89b63bdb9632a925a80f6f7d4e7bd2e00

Modified Files
--------------
src/backend/storage/ipc/shm_mq.c |   19 +++++++++++++++++--
1 file changed, 17 insertions(+), 2 deletions(-)


pgsql-committers by date:

Previous
From: Robert Haas
Date:
Subject: pgsql: Correct tiny inaccuracy in strxfrm cache comment.
Next
From: Robert Haas
Date:
Subject: pgsql: shm_mq: Third attempt at fixing nowait behavior in shm_mq_receiv