Move Q_ALWAYS_INLINE next to Q_NEVER_INLINE in qglobal.h.

Change-Id: I7e3b7ecca6b5f142fa6cb5db2e9521ed3212afe8
Reviewed-by: Lars Knoll <lars.knoll@theqtcompany.com>
This commit is contained in:
Erik Verbruggen 2015-07-27 10:46:06 +02:00 committed by Erik Verbruggen
parent 70da0b71fb
commit 670cb2edbc
3 changed files with 39 additions and 48 deletions

View File

@ -496,10 +496,13 @@ typedef qptrdiff qintptr;
#ifdef Q_CC_MSVC #ifdef Q_CC_MSVC
# define Q_NEVER_INLINE __declspec(noinline) # define Q_NEVER_INLINE __declspec(noinline)
# define Q_ALWAYS_INLINE __forceinline
#elif defined(Q_CC_GNU) #elif defined(Q_CC_GNU)
# define Q_NEVER_INLINE __attribute__((noinline)) # define Q_NEVER_INLINE __attribute__((noinline))
# define Q_ALWAYS_INLINE inline __attribute__((always_inline))
#else #else
# define Q_NEVER_INLINE # define Q_NEVER_INLINE
# define Q_ALWAYS_INLINE inline
#endif #endif
//defines the type for the WNDPROC on windows //defines the type for the WNDPROC on windows

View File

@ -46,13 +46,6 @@ QT_END_NAMESPACE
#pragma qt_sync_stop_processing #pragma qt_sync_stop_processing
#endif #endif
#ifdef Q_CC_GNU
// lowercase is fine, we'll undef it below
#define always_inline __attribute__((always_inline, gnu_inline))
#else
#define always_inline
#endif
template<int> struct QAtomicOpsSupport { enum { IsSupported = 0 }; }; template<int> struct QAtomicOpsSupport { enum { IsSupported = 0 }; };
template<> struct QAtomicOpsSupport<4> { enum { IsSupported = 1 }; }; template<> struct QAtomicOpsSupport<4> { enum { IsSupported = 1 }; };
@ -84,19 +77,19 @@ template <typename BaseClass> struct QGenericAtomicOps
{ {
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T load(const T &_q_value) Q_DECL_NOTHROW T load(const T &_q_value) Q_DECL_NOTHROW
{ {
return _q_value; return _q_value;
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
void store(T &_q_value, X newValue) Q_DECL_NOTHROW void store(T &_q_value, X newValue) Q_DECL_NOTHROW
{ {
_q_value = newValue; _q_value = newValue;
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T loadAcquire(const T &_q_value) Q_DECL_NOTHROW T loadAcquire(const T &_q_value) Q_DECL_NOTHROW
{ {
T tmp = *static_cast<const volatile T *>(&_q_value); T tmp = *static_cast<const volatile T *>(&_q_value);
@ -104,7 +97,7 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
void storeRelease(T &_q_value, X newValue) Q_DECL_NOTHROW void storeRelease(T &_q_value, X newValue) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
@ -115,13 +108,13 @@ template <typename BaseClass> struct QGenericAtomicOps
{ return BaseClass::isFetchAndAddNative(); } { return BaseClass::isFetchAndAddNative(); }
static inline Q_DECL_CONSTEXPR bool isReferenceCountingWaitFree() Q_DECL_NOTHROW static inline Q_DECL_CONSTEXPR bool isReferenceCountingWaitFree() Q_DECL_NOTHROW
{ return BaseClass::isFetchAndAddWaitFree(); } { return BaseClass::isFetchAndAddWaitFree(); }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
bool ref(T &_q_value) Q_DECL_NOTHROW bool ref(T &_q_value) Q_DECL_NOTHROW
{ {
return BaseClass::fetchAndAddRelaxed(_q_value, 1) != T(-1); return BaseClass::fetchAndAddRelaxed(_q_value, 1) != T(-1);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
bool deref(T &_q_value) Q_DECL_NOTHROW bool deref(T &_q_value) Q_DECL_NOTHROW
{ {
return BaseClass::fetchAndAddRelaxed(_q_value, -1) != 1; return BaseClass::fetchAndAddRelaxed(_q_value, -1) != 1;
@ -138,7 +131,7 @@ template <typename BaseClass> struct QGenericAtomicOps
bool testAndSetRelaxed(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW; bool testAndSetRelaxed(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW;
#endif #endif
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
bool testAndSetAcquire(T &_q_value, X expectedValue, X newValue) Q_DECL_NOTHROW bool testAndSetAcquire(T &_q_value, X expectedValue, X newValue) Q_DECL_NOTHROW
{ {
bool tmp = BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue); bool tmp = BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue);
@ -146,21 +139,21 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
bool testAndSetRelease(T &_q_value, X expectedValue, X newValue) Q_DECL_NOTHROW bool testAndSetRelease(T &_q_value, X expectedValue, X newValue) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue); return BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue);
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
bool testAndSetOrdered(T &_q_value, X expectedValue, X newValue) Q_DECL_NOTHROW bool testAndSetOrdered(T &_q_value, X expectedValue, X newValue) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
return BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue); return BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue);
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
bool testAndSetAcquire(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW bool testAndSetAcquire(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW
{ {
bool tmp = BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue, currentValue); bool tmp = BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue, currentValue);
@ -168,14 +161,14 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
bool testAndSetRelease(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW bool testAndSetRelease(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue, currentValue); return BaseClass::testAndSetRelaxed(_q_value, expectedValue, newValue, currentValue);
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
bool testAndSetOrdered(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW bool testAndSetOrdered(T &_q_value, X expectedValue, X newValue, X *currentValue) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
@ -185,7 +178,7 @@ template <typename BaseClass> struct QGenericAtomicOps
static inline Q_DECL_CONSTEXPR bool isFetchAndStoreNative() Q_DECL_NOTHROW { return false; } static inline Q_DECL_CONSTEXPR bool isFetchAndStoreNative() Q_DECL_NOTHROW { return false; }
static inline Q_DECL_CONSTEXPR bool isFetchAndStoreWaitFree() Q_DECL_NOTHROW { return false; } static inline Q_DECL_CONSTEXPR bool isFetchAndStoreWaitFree() Q_DECL_NOTHROW { return false; }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
T fetchAndStoreRelaxed(T &_q_value, X newValue) Q_DECL_NOTHROW T fetchAndStoreRelaxed(T &_q_value, X newValue) Q_DECL_NOTHROW
{ {
// implement fetchAndStore on top of testAndSet // implement fetchAndStore on top of testAndSet
@ -196,7 +189,7 @@ template <typename BaseClass> struct QGenericAtomicOps
} }
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
T fetchAndStoreAcquire(T &_q_value, X newValue) Q_DECL_NOTHROW T fetchAndStoreAcquire(T &_q_value, X newValue) Q_DECL_NOTHROW
{ {
T tmp = BaseClass::fetchAndStoreRelaxed(_q_value, newValue); T tmp = BaseClass::fetchAndStoreRelaxed(_q_value, newValue);
@ -204,14 +197,14 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
T fetchAndStoreRelease(T &_q_value, X newValue) Q_DECL_NOTHROW T fetchAndStoreRelease(T &_q_value, X newValue) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::fetchAndStoreRelaxed(_q_value, newValue); return BaseClass::fetchAndStoreRelaxed(_q_value, newValue);
} }
template <typename T, typename X> static inline always_inline template <typename T, typename X> static Q_ALWAYS_INLINE
T fetchAndStoreOrdered(T &_q_value, X newValue) Q_DECL_NOTHROW T fetchAndStoreOrdered(T &_q_value, X newValue) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
@ -220,7 +213,7 @@ template <typename BaseClass> struct QGenericAtomicOps
static inline Q_DECL_CONSTEXPR bool isFetchAndAddNative() Q_DECL_NOTHROW { return false; } static inline Q_DECL_CONSTEXPR bool isFetchAndAddNative() Q_DECL_NOTHROW { return false; }
static inline Q_DECL_CONSTEXPR bool isFetchAndAddWaitFree() Q_DECL_NOTHROW { return false; } static inline Q_DECL_CONSTEXPR bool isFetchAndAddWaitFree() Q_DECL_NOTHROW { return false; }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAddRelaxed(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW T fetchAndAddRelaxed(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW
{ {
// implement fetchAndAdd on top of testAndSet // implement fetchAndAdd on top of testAndSet
@ -231,7 +224,7 @@ template <typename BaseClass> struct QGenericAtomicOps
} }
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAddAcquire(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW T fetchAndAddAcquire(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW
{ {
T tmp = BaseClass::fetchAndAddRelaxed(_q_value, valueToAdd); T tmp = BaseClass::fetchAndAddRelaxed(_q_value, valueToAdd);
@ -239,28 +232,28 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAddRelease(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW T fetchAndAddRelease(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::fetchAndAddRelaxed(_q_value, valueToAdd); return BaseClass::fetchAndAddRelaxed(_q_value, valueToAdd);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAddOrdered(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW T fetchAndAddOrdered(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT valueToAdd) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
return BaseClass::fetchAndAddRelaxed(_q_value, valueToAdd); return BaseClass::fetchAndAddRelaxed(_q_value, valueToAdd);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndSubRelaxed(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW T fetchAndSubRelaxed(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW
{ {
// implement fetchAndSub on top of fetchAndAdd // implement fetchAndSub on top of fetchAndAdd
return fetchAndAddRelaxed(_q_value, -operand); return fetchAndAddRelaxed(_q_value, -operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndSubAcquire(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW T fetchAndSubAcquire(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW
{ {
T tmp = BaseClass::fetchAndSubRelaxed(_q_value, operand); T tmp = BaseClass::fetchAndSubRelaxed(_q_value, operand);
@ -268,21 +261,21 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndSubRelease(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW T fetchAndSubRelease(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::fetchAndSubRelaxed(_q_value, operand); return BaseClass::fetchAndSubRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndSubOrdered(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW T fetchAndSubOrdered(T &_q_value, typename QAtomicAdditiveType<T>::AdditiveT operand) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
return BaseClass::fetchAndSubRelaxed(_q_value, operand); return BaseClass::fetchAndSubRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAndRelaxed(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndAndRelaxed(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
// implement fetchAndAnd on top of testAndSet // implement fetchAndAnd on top of testAndSet
@ -293,7 +286,7 @@ template <typename BaseClass> struct QGenericAtomicOps
} }
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAndAcquire(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndAndAcquire(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
T tmp = BaseClass::fetchAndAndRelaxed(_q_value, operand); T tmp = BaseClass::fetchAndAndRelaxed(_q_value, operand);
@ -301,21 +294,21 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAndRelease(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndAndRelease(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::fetchAndAndRelaxed(_q_value, operand); return BaseClass::fetchAndAndRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndAndOrdered(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndAndOrdered(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
return BaseClass::fetchAndAndRelaxed(_q_value, operand); return BaseClass::fetchAndAndRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndOrRelaxed(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndOrRelaxed(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
// implement fetchAndOr on top of testAndSet // implement fetchAndOr on top of testAndSet
@ -326,7 +319,7 @@ template <typename BaseClass> struct QGenericAtomicOps
} }
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndOrAcquire(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndOrAcquire(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
T tmp = BaseClass::fetchAndOrRelaxed(_q_value, operand); T tmp = BaseClass::fetchAndOrRelaxed(_q_value, operand);
@ -334,21 +327,21 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndOrRelease(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndOrRelease(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::fetchAndOrRelaxed(_q_value, operand); return BaseClass::fetchAndOrRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndOrOrdered(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndOrOrdered(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
return BaseClass::fetchAndOrRelaxed(_q_value, operand); return BaseClass::fetchAndOrRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndXorRelaxed(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndXorRelaxed(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
// implement fetchAndXor on top of testAndSet // implement fetchAndXor on top of testAndSet
@ -359,7 +352,7 @@ template <typename BaseClass> struct QGenericAtomicOps
} }
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndXorAcquire(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndXorAcquire(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
T tmp = BaseClass::fetchAndXorRelaxed(_q_value, operand); T tmp = BaseClass::fetchAndXorRelaxed(_q_value, operand);
@ -367,14 +360,14 @@ template <typename BaseClass> struct QGenericAtomicOps
return tmp; return tmp;
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndXorRelease(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndXorRelease(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
BaseClass::releaseMemoryFence(_q_value); BaseClass::releaseMemoryFence(_q_value);
return BaseClass::fetchAndXorRelaxed(_q_value, operand); return BaseClass::fetchAndXorRelaxed(_q_value, operand);
} }
template <typename T> static inline always_inline template <typename T> static Q_ALWAYS_INLINE
T fetchAndXorOrdered(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW T fetchAndXorOrdered(T &_q_value, typename QtPrivate::QEnableIf<QTypeInfo<T>::isIntegral, T>::Type operand) Q_DECL_NOTHROW
{ {
BaseClass::orderedMemoryFence(_q_value); BaseClass::orderedMemoryFence(_q_value);
@ -382,7 +375,5 @@ template <typename BaseClass> struct QGenericAtomicOps
} }
}; };
#undef always_inline
QT_END_NAMESPACE QT_END_NAMESPACE
#endif // QGENERICATOMIC_H #endif // QGENERICATOMIC_H

View File

@ -62,15 +62,12 @@ QT_BEGIN_NAMESPACE
#if defined(Q_CC_GNU) #if defined(Q_CC_GNU)
# define Q_STATIC_TEMPLATE_FUNCTION static # define Q_STATIC_TEMPLATE_FUNCTION static
# define Q_ALWAYS_INLINE inline __attribute__((always_inline))
# define Q_DECL_RESTRICT __restrict__ # define Q_DECL_RESTRICT __restrict__
#elif defined(Q_CC_MSVC) #elif defined(Q_CC_MSVC)
# define Q_STATIC_TEMPLATE_FUNCTION static # define Q_STATIC_TEMPLATE_FUNCTION static
# define Q_ALWAYS_INLINE __forceinline
# define Q_DECL_RESTRICT __restrict # define Q_DECL_RESTRICT __restrict
#else #else
# define Q_STATIC_TEMPLATE_FUNCTION static # define Q_STATIC_TEMPLATE_FUNCTION static
# define Q_ALWAYS_INLINE inline
# define Q_DECL_RESTRICT # define Q_DECL_RESTRICT
#endif #endif