Qt 4.8
qatomic.h
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/legal
5 **
6 ** This file is part of the QtCore module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and Digia. For licensing terms and
14 ** conditions see http://qt.digia.com/licensing. For further information
15 ** use the contact form at http://qt.digia.com/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 2.1 as published by the Free Software
20 ** Foundation and appearing in the file LICENSE.LGPL included in the
21 ** packaging of this file. Please review the following information to
22 ** ensure the GNU Lesser General Public License version 2.1 requirements
23 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24 **
25 ** In addition, as a special exception, Digia gives you certain additional
26 ** rights. These rights are described in the Digia Qt LGPL Exception
27 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28 **
29 ** GNU General Public License Usage
30 ** Alternatively, this file may be used under the terms of the GNU
31 ** General Public License version 3.0 as published by the Free Software
32 ** Foundation and appearing in the file LICENSE.GPL included in the
33 ** packaging of this file. Please review the following information to
34 ** ensure the GNU General Public License version 3.0 requirements will be
35 ** met: http://www.gnu.org/copyleft/gpl.html.
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41 
42 #ifndef QATOMIC_H
43 #define QATOMIC_H
44 
45 #include <QtCore/qglobal.h>
46 #include <QtCore/qbasicatomic.h>
47 
49 
51 
52 QT_MODULE(Core)
53 
54 // High-level atomic integer operations
56 {
57 public:
58  inline QAtomicInt(int value = 0)
59  {
60 #ifdef QT_ARCH_PARISC
61  this->_q_lock[0] = this->_q_lock[1] = this->_q_lock[2] = this->_q_lock[3] = -1;
62 #endif
63  _q_value = value;
64  }
65  inline QAtomicInt(const QAtomicInt &other)
66  {
67 #ifdef QT_ARCH_PARISC
68  this->_q_lock[0] = this->_q_lock[1] = this->_q_lock[2] = this->_q_lock[3] = -1;
69 #endif
70  _q_value = other._q_value;
71  }
72 
73  inline QAtomicInt &operator=(int value)
74  {
75  (void) QBasicAtomicInt::operator=(value);
76  return *this;
77  }
78 
79  inline QAtomicInt &operator=(const QAtomicInt &other)
80  {
81  (void) QBasicAtomicInt::operator=(other);
82  return *this;
83  }
84 
85 #ifdef qdoc
86  bool operator==(int value) const;
87  bool operator!=(int value) const;
88  bool operator!() const;
89  operator int() const;
90 
91  static bool isReferenceCountingNative();
92  static bool isReferenceCountingWaitFree();
93 
94  bool ref();
95  bool deref();
96 
97  static bool isTestAndSetNative();
98  static bool isTestAndSetWaitFree();
99 
100  bool testAndSetRelaxed(int expectedValue, int newValue);
101  bool testAndSetAcquire(int expectedValue, int newValue);
102  bool testAndSetRelease(int expectedValue, int newValue);
103  bool testAndSetOrdered(int expectedValue, int newValue);
104 
105  static bool isFetchAndStoreNative();
106  static bool isFetchAndStoreWaitFree();
107 
108  int fetchAndStoreRelaxed(int newValue);
109  int fetchAndStoreAcquire(int newValue);
110  int fetchAndStoreRelease(int newValue);
111  int fetchAndStoreOrdered(int newValue);
112 
113  static bool isFetchAndAddNative();
114  static bool isFetchAndAddWaitFree();
115 
116  int fetchAndAddRelaxed(int valueToAdd);
117  int fetchAndAddAcquire(int valueToAdd);
118  int fetchAndAddRelease(int valueToAdd);
119  int fetchAndAddOrdered(int valueToAdd);
120 #endif
121 };
122 
123 // High-level atomic pointer operations
124 template <typename T>
125 class QAtomicPointer : public QBasicAtomicPointer<T>
126 {
127 public:
128  inline QAtomicPointer(T *value = 0)
129  {
130 #ifdef QT_ARCH_PARISC
131  this->_q_lock[0] = this->_q_lock[1] = this->_q_lock[2] = this->_q_lock[3] = -1;
132 #endif
134  }
135  inline QAtomicPointer(const QAtomicPointer<T> &other)
136  {
137 #ifdef QT_ARCH_PARISC
138  this->_q_lock[0] = this->_q_lock[1] = this->_q_lock[2] = this->_q_lock[3] = -1;
139 #endif
141  }
142 
143  inline QAtomicPointer<T> &operator=(T *value)
144  {
145  (void) QBasicAtomicPointer<T>::operator=(value);
146  return *this;
147  }
148 
150  {
151  (void) QBasicAtomicPointer<T>::operator=(other);
152  return *this;
153  }
154 
155 #ifdef qdoc
156  bool operator==(T *value) const;
157  bool operator!=(T *value) const;
158  bool operator!() const;
159  operator T *() const;
160  T *operator->() const;
161 
162  static bool isTestAndSetNative();
163  static bool isTestAndSetWaitFree();
164 
165  bool testAndSetRelaxed(T *expectedValue, T *newValue);
166  bool testAndSetAcquire(T *expectedValue, T *newValue);
167  bool testAndSetRelease(T *expectedValue, T *newValue);
168  bool testAndSetOrdered(T *expectedValue, T *newValue);
169 
170  static bool isFetchAndStoreNative();
171  static bool isFetchAndStoreWaitFree();
172 
173  T *fetchAndStoreRelaxed(T *newValue);
174  T *fetchAndStoreAcquire(T *newValue);
175  T *fetchAndStoreRelease(T *newValue);
176  T *fetchAndStoreOrdered(T *newValue);
177 
178  static bool isFetchAndAddNative();
179  static bool isFetchAndAddWaitFree();
180 
181  T *fetchAndAddRelaxed(qptrdiff valueToAdd);
182  T *fetchAndAddAcquire(qptrdiff valueToAdd);
183  T *fetchAndAddRelease(qptrdiff valueToAdd);
184  T *fetchAndAddOrdered(qptrdiff valueToAdd);
185 #endif
186 };
187 
194 template <typename T>
195 inline void qAtomicAssign(T *&d, T *x)
196 {
197  if (d == x)
198  return;
199  x->ref.ref();
200  if (!d->ref.deref())
201  delete d;
202  d = x;
203 }
204 
213 template <typename T>
214 inline void qAtomicDetach(T *&d)
215 {
216  if (d->ref == 1)
217  return;
218  T *x = d;
219  d = new T(*d);
220  if (!x->ref.deref())
221  delete x;
222 }
223 
226 
227 #endif // QATOMIC_H
T *volatile _q_value
Definition: qbasicatomic.h:148
double d
Definition: qnumeric_p.h:62
QAtomicPointer< T > & operator=(const QAtomicPointer< T > &other)
Assigns other to this QAtomicPointer and returns a reference to this QAtomicPointer.
Definition: qatomic.h:149
void qAtomicDetach(T *&d)
This is a helper for the detach method of implicitly shared classes.
Definition: qatomic.h:214
bool operator==(T *value) const
Returns true if the value is equal to the value in this QAtomicPointer; otherwise returns false...
QAtomicPointer(T *value=0)
Constructs a QAtomicPointer with the given value.
Definition: qatomic.h:128
volatile int _q_value
Definition: qbasicatomic.h:64
#define QT_END_NAMESPACE
This macro expands to.
Definition: qglobal.h:90
static bool isFetchAndStoreNative()
Returns true if fetch-and-store is implemented using atomic processor instructions, false otherwise.
#define QT_MODULE(x)
Definition: qglobal.h:2783
T * fetchAndStoreOrdered(T *newValue)
Atomic fetch-and-store.
#define QT_BEGIN_HEADER
Definition: qglobal.h:136
The QAtomicInt class provides platform-independent atomic operations on integers. ...
Definition: qatomic.h:55
T * fetchAndStoreRelease(T *newValue)
Atomic fetch-and-store.
static bool isTestAndSetWaitFree()
Returns true if atomic test-and-set is wait-free, false otherwise.
QAtomicInt(const QAtomicInt &other)
Constructs a copy of other.
Definition: qatomic.h:65
bool testAndSetOrdered(T *expectedValue, T *newValue)
Atomic test-and-set.
T * fetchAndStoreRelaxed(T *newValue)
Atomic fetch-and-store.
QAtomicInt & operator=(const QAtomicInt &other)
Assigns other to this QAtomicInt and returns a reference to this QAtomicInt.
Definition: qatomic.h:79
bool testAndSetRelease(T *expectedValue, T *newValue)
Atomic test-and-set.
#define QT_BEGIN_NAMESPACE
This macro expands to.
Definition: qglobal.h:89
bool testAndSetRelaxed(T *expectedValue, T *newValue)
Atomic test-and-set.
T * fetchAndAddAcquire(qptrdiff valueToAdd)
Atomic fetch-and-add.
QIntegerForSizeof< void * >::Signed qptrdiff
Definition: qglobal.h:987
bool operator!=(T *value) const
Returns true if the value of this QAtomicPointer is not equal to value; otherwise returns false...
static bool isFetchAndAddNative()
Returns true if fetch-and-add is implemented using atomic processor instructions, false otherwise...
QAtomicInt & operator=(int value)
Assigns the value to this QAtomicInt and returns a reference to this QAtomicInt.
Definition: qatomic.h:73
static bool isFetchAndAddWaitFree()
Returns true if atomic fetch-and-add is wait-free, false otherwise.
T * operator->() const
static bool isTestAndSetNative()
Returns true if test-and-set is implemented using atomic processor instructions, false otherwise...
bool operator!() const
Returns true is the current value of this QAtomicPointer is zero; otherwise returns false...
bool operator!=(const T *o, const QPointer< T > &p)
Definition: qpointer.h:122
The QAtomicPointer class is a template class that provides platform-independent atomic operations on ...
#define Q_CORE_EXPORT
Definition: qglobal.h:1449
void qAtomicAssign(T *&d, T *x)
This is a helper for the assignment operators of implicitly shared classes.
Definition: qatomic.h:195
T * fetchAndAddOrdered(qptrdiff valueToAdd)
Atomic fetch-and-add.
bool operator==(const T *o, const QPointer< T > &p)
Definition: qpointer.h:87
T * fetchAndAddRelaxed(qptrdiff valueToAdd)
Atomic fetch-and-add.
T * fetchAndStoreAcquire(T *newValue)
Atomic fetch-and-store.
T * fetchAndAddRelease(qptrdiff valueToAdd)
Atomic fetch-and-add.
#define class
QAtomicPointer(const QAtomicPointer< T > &other)
Constructs a copy of other.
Definition: qatomic.h:135
#define QT_END_HEADER
Definition: qglobal.h:137
bool testAndSetAcquire(T *expectedValue, T *newValue)
Atomic test-and-set.
static bool isFetchAndStoreWaitFree()
Returns true if atomic fetch-and-store is wait-free, false otherwise.
QAtomicPointer< T > & operator=(T *value)
Assigns the value to this QAtomicPointer and returns a reference to this QAtomicPointer.
Definition: qatomic.h:143
QAtomicInt(int value=0)
Constructs a QAtomicInt with the given value.
Definition: qatomic.h:58