pgsql: Fix and improve pg_atomic_flag fallback implementation. - Mailing list pgsql-committers

From Andres Freund
Subject pgsql: Fix and improve pg_atomic_flag fallback implementation.
Date
Msg-id E1f4eCj-0000t9-SP@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Fix and improve pg_atomic_flag fallback implementation.

The atomics fallback implementation for pg_atomic_flag was broken,
returning the inverted value from pg_atomic_test_set_flag().  This was
unnoticed because a) atomic flags were unused until recently b) the
test code wasn't run when the fallback implementation was in
use (because it didn't allow to test for some edge cases).

Fix the bug, and improve the fallback so it has the same behaviour as
the non-fallback implementation in the problematic edge cases. That
breaks ABI compatibility in the back branches when fallbacks are in
use, but given they were broken until now...

Author: Andres Freund
Reported-by: Daniel Gustafsson
Discussion:
    https://postgr.es/m/FB948276-7B32-4B77-83E6-D00167F8EEB4@yesql.se
    https://postgr.es/m/20180406233854.uni2h3mbnveczl32@alap3.anarazel.de
Backpatch: 9.5-, where the atomics abstraction was introduced.

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/8c3debbbf61892dabd8b6f3f8d55e600a7901f2b

Modified Files
--------------
src/backend/port/atomics.c          | 21 +++++++++++++++++++--
src/include/port/atomics/fallback.h | 13 ++-----------
src/test/regress/regress.c          | 14 --------------
3 files changed, 21 insertions(+), 27 deletions(-)


pgsql-committers by date:

Previous
From: Tom Lane
Date:
Subject: pgsql: Doc: fix broken markup.
Next
From: Andres Freund
Date:
Subject: pgsql: Fix and improve pg_atomic_flag fallback implementation.