From 4e1f30390d3eeb3a6db7cdeaf87635045fc47f1c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pedro=20J=2E=20Est=C3=A9banez?= Date: Tue, 19 Jul 2022 10:04:59 +0200 Subject: [PATCH] Use the right memory ordering in SafeNumeric operations (cherry picked from commit 02a584d8e68fad988fbbe43e05f8437284c00733) --- core/safe_refcount.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/core/safe_refcount.h b/core/safe_refcount.h index fbafbe2f585..593c2d86e04 100644 --- a/core/safe_refcount.h +++ b/core/safe_refcount.h @@ -113,7 +113,7 @@ public: if (tmp >= p_value) { return tmp; // already greater, or equal } - if (value.compare_exchange_weak(tmp, p_value, std::memory_order_release)) { + if (value.compare_exchange_weak(tmp, p_value, std::memory_order_acq_rel)) { return p_value; } } @@ -125,7 +125,7 @@ public: if (c == 0) { return 0; } - if (value.compare_exchange_weak(c, c + 1, std::memory_order_release)) { + if (value.compare_exchange_weak(c, c + 1, std::memory_order_acq_rel)) { return c + 1; } }