[PATCH 2/3] Don't use the unsafe QAtomicPointer accessors in PHONON_GLOBAL_STATIC_WITH_ARGS.
Jon Severinsson
jon at severinsson.net
Sat Oct 6 18:12:07 UTC 2012
These could lead to race conditions, and are removed from Qt5.
---
phonon/globalstatic_p.h | 8 +++-----
1 fil ändrad, 3 tillägg(+), 5 borttagningar(-)
diff --git a/phonon/globalstatic_p.h b/phonon/globalstatic_p.h
index cf80512..7555630 100644
--- a/phonon/globalstatic_p.h
+++ b/phonon/globalstatic_p.h
@@ -260,7 +260,7 @@ static struct PHONON_GLOBAL_STATIC_STRUCT_NAME(NAME)
} \
inline TYPE *operator->() \
{ \
- TYPE *p = _k_static_##NAME; \
+ TYPE *p = _k_static_##NAME.fetchAndAddAcquire(0); \
if (!p) { \
if (isDestroyed()) { \
qFatal("Fatal Error: Accessed global static '%s *%s()' after destruction. " \
@@ -269,7 +269,7 @@ static struct PHONON_GLOBAL_STATIC_STRUCT_NAME(NAME)
p = new TYPE ARGS; \
if (!_k_static_##NAME.testAndSetOrdered(0, p)) { \
delete p; \
- p = _k_static_##NAME; \
+ p = _k_static_##NAME.fetchAndAddAcquire(0); \
} else { \
static Phonon::CleanUpGlobalStatic cleanUpObject = { destroy }; \
} \
@@ -283,9 +283,7 @@ static struct PHONON_GLOBAL_STATIC_STRUCT_NAME(NAME)
static void destroy() \
{ \
_k_static_##NAME##_destroyed = true; \
- TYPE *x = _k_static_##NAME; \
- _k_static_##NAME = 0; \
- delete x; \
+ delete _k_static_##NAME.fetchAndStoreRelease(0); \
} \
} NAME;
--
1.7.10.4
More information about the Kde-frameworks-devel
mailing list