Centralize support for QBasicAtomic for ints and longs
No need to redefine everywhere, since they're required to be supported. Change-Id: I2bdbbd0b0c44871e3bd0edcf0289fc58dd50ff31 Reviewed-by: Lars Knoll <lars.knoll@digia.com>
This commit is contained in:
parent
8d2a9bcf1d
commit
fd0d576709
@ -72,9 +72,6 @@ QT_END_NAMESPACE
|
||||
# error "Qt is misconfigured: this ARMv5 implementation is only possible on Linux"
|
||||
#endif
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
|
||||
template <int size> struct QBasicAtomicOps: QGenericAtomicOps<QBasicAtomicOps<size> >
|
||||
{
|
||||
// kernel places a restartable cmpxchg implementation at a fixed address
|
||||
|
@ -69,16 +69,6 @@ QT_END_NAMESPACE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_STORE_IS_ALWAYS_NATIVE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_ADD_IS_ALWAYS_NATIVE
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
#if defined(Q_COMPILER_UNICODE_STRINGS) && !defined(Q_PROCESSOR_ARM_V6)
|
||||
// for ARMv5, ensure that char32_t (an uint_least32_t), is 32-bit
|
||||
// it's extremely unlikely it won't be on a 32-bit ARM, but just to be sure
|
||||
// For ARMv6 and up, we're sure it works, but the definition is below
|
||||
template<> struct QAtomicIntegerTraits<char32_t>
|
||||
{ enum { IsInteger = sizeof(char32_t) == sizeof(int) ? 1 : -1 }; };
|
||||
#endif
|
||||
|
||||
template <int size> struct QBasicAtomicOps: QGenericAtomicOps<QBasicAtomicOps<size> >
|
||||
{
|
||||
template <typename T>
|
||||
@ -225,14 +215,11 @@ template<> struct QAtomicIntegerTraits<signed char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long long> { enum { IsInteger = 1 }; };
|
||||
|
||||
# ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char16_t> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<char32_t> { enum { IsInteger = 1 }; };
|
||||
# endif
|
||||
|
||||
#define Q_ATOMIC_INT8_IS_SUPPORTED
|
||||
|
@ -54,7 +54,6 @@ QT_END_NAMESPACE
|
||||
#pragma qt_sync_stop_processing
|
||||
#endif
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template <typename T> struct QAtomicOps: QGenericAtomicOps<QAtomicOps<T> >
|
||||
{
|
||||
typedef T Type;
|
||||
|
@ -70,21 +70,16 @@ QT_END_NAMESPACE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_STORE_IS_SOMETIMES_NATIVE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_ADD_IS_SOMETIMES_NATIVE
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<signed char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long long> { enum { IsInteger = 1 }; };
|
||||
|
||||
# ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char16_t> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<char32_t> { enum { IsInteger = 1 }; };
|
||||
# endif
|
||||
|
||||
#define Q_ATOMIC_INT8_IS_SUPPORTED
|
||||
|
@ -53,12 +53,6 @@ QT_END_NAMESPACE
|
||||
#pragma qt_sync_stop_processing
|
||||
#endif
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
#ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char32_t> { enum { IsInteger = 1 }; };
|
||||
#endif
|
||||
|
||||
#define Q_ATOMIC_INT_REFERENCE_COUNTING_IS_SOMETIMES_NATIVE
|
||||
#define Q_ATOMIC_INT_TEST_AND_SET_IS_SOMETIMES_NATIVE
|
||||
#define Q_ATOMIC_INT_FETCH_AND_STORE_IS_SOMETIMES_NATIVE
|
||||
|
@ -123,21 +123,16 @@ QT_END_NAMESPACE
|
||||
|
||||
#define Q_ATOMIC_INT64_FETCH_AND_ADD_IS_ALWAYS_NATIVE
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<signed char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long long> { enum { IsInteger = 1 }; };
|
||||
|
||||
# ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char16_t> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<char32_t> { enum { IsInteger = 1 }; };
|
||||
# endif
|
||||
|
||||
template <int size> struct QBasicAtomicOps: QGenericAtomicOps<QBasicAtomicOps<size> >
|
||||
|
@ -69,16 +69,6 @@ QT_END_NAMESPACE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_STORE_IS_ALWAYS_NATIVE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_ADD_IS_ALWAYS_NATIVE
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
#if defined(Q_COMPILER_UNICODE_STRINGS) && !defined(Q_PROCESSOR_MIPS_64)
|
||||
// for MIPS32, ensure that char32_t (an uint_least32_t), is 32-bit
|
||||
// it's extremely unlikely it won't be on a 32-bit MIPS, but just to be sure
|
||||
// For MIPS64, we're sure it works, but the definition is below
|
||||
template<> struct QAtomicIntegerTraits<char32_t>
|
||||
{ enum { IsInteger = sizeof(char32_t) == sizeof(int) ? 1 : -1 }; };
|
||||
#endif
|
||||
|
||||
template <int size> struct QBasicAtomicOps: QGenericAtomicOps<QBasicAtomicOps<size> >
|
||||
{
|
||||
template <typename T>
|
||||
|
@ -301,14 +301,6 @@ template<> struct QAtomicIntegerTraits<unsigned long long> { enum { IsInteger =
|
||||
template <int N> struct QAtomicWindowsType { typedef typename QIntegerForSize<N>::Signed Type; };
|
||||
template <> struct QAtomicWindowsType<4> { typedef long Type; };
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long> { enum { IsInteger = 1 }; };
|
||||
#ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char32_t> { enum { IsInteger = 1 }; };
|
||||
#endif
|
||||
|
||||
|
||||
template <int N> struct QAtomicOpsBySize : QGenericAtomicOps<QAtomicOpsBySize<N> >
|
||||
{
|
||||
|
@ -74,8 +74,6 @@ QT_END_NAMESPACE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_STORE_IS_NOT_NATIVE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_ADD_IS_NOT_NATIVE
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long long> { enum { IsInteger = 1 }; };
|
||||
|
||||
|
@ -89,9 +89,6 @@ QT_END_NAMESPACE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_ADD_IS_ALWAYS_NATIVE
|
||||
#define Q_ATOMIC_POINTER_FETCH_AND_ADD_IS_WAIT_FREE
|
||||
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
|
||||
template <int size> struct QBasicAtomicOps: QGenericAtomicOps<QBasicAtomicOps<size> >
|
||||
{
|
||||
static inline Q_DECL_CONSTEXPR bool isReferenceCountingNative() Q_DECL_NOTHROW { return true; }
|
||||
@ -125,14 +122,11 @@ template<> struct QAtomicIntegerTraits<signed char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned char> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned short> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long long> { enum { IsInteger = 1 }; };
|
||||
|
||||
# ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char16_t> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<char32_t> { enum { IsInteger = 1 }; };
|
||||
# endif
|
||||
|
||||
|
||||
|
@ -1221,9 +1221,34 @@
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
|
||||
// The following three specializations must always be defined
|
||||
// The following specializations must always be defined
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<unsigned>));
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<long>));
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<unsigned long>));
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<quintptr>));
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<qptrdiff>));
|
||||
#ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<char32_t>));
|
||||
#endif
|
||||
|
||||
#ifdef Q_ATOMIC_INT16_IS_SUPPORTED
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<short>));
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<unsigned short>));
|
||||
# if WCHAR_MAX < 0x10000
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<wchar_t>));
|
||||
# endif
|
||||
# ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<char16_t>));
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef Q_ATOMIC_INT64_IS_SUPPORTED
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<qint64>));
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<quint64>));
|
||||
#endif
|
||||
|
||||
#if WCHAR_MAX == INT_MAX
|
||||
Q_STATIC_ASSERT(sizeof(QAtomicInteger<wchar_t>));
|
||||
#endif
|
||||
|
||||
QT_END_NAMESPACE
|
||||
|
@ -62,6 +62,19 @@ QT_END_NAMESPACE
|
||||
|
||||
template<typename T> struct QAtomicIntegerTraits { enum { IsInteger = 0 }; };
|
||||
|
||||
// these integers are always supported, on all platforms
|
||||
// - int, unsigned int and char32_t are 32-bit wide
|
||||
// - long and unsigned long might be 64-bit wide on 64-bit platforms,
|
||||
// but 64-bit integer support is required anyway
|
||||
template<> struct QAtomicIntegerTraits<int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned int> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<long> { enum { IsInteger = 1 }; };
|
||||
template<> struct QAtomicIntegerTraits<unsigned long> { enum { IsInteger = 1 }; };
|
||||
#ifdef Q_COMPILER_UNICODE_STRINGS
|
||||
template<> struct QAtomicIntegerTraits<char32_t>
|
||||
{ enum { IsInteger = sizeof(char32_t) == sizeof(int) ? 1 : -1 }; };
|
||||
#endif
|
||||
|
||||
template <typename T> struct QAtomicAdditiveType
|
||||
{
|
||||
typedef T AdditiveT;
|
||||
|
Loading…
x
Reference in New Issue
Block a user