source: trunk/src/dbus/qdbusthreaddebug_p.h@ 337

Last change on this file since 337 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 7.2 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information (qt-info@nokia.com)
5**
6** This file is part of the QtDBus module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at qt-sales@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41#ifndef QDBUSTHREADDEBUG_P_H
42#define QDBUSTHREADDEBUG_P_H
43
44//
45// W A R N I N G
46// -------------
47//
48// This file is not part of the Qt API. It exists purely as an
49// implementation detail. This header file may change from version to
50// version without notice, or even be removed.
51//
52// We mean it.
53//
54
55#if !defined(QDBUS_THREAD_DEBUG) && defined(QT_BUILD_INTERNAL)
56# define QDBUS_THREAD_DEBUG 1
57#endif
58
59#if QDBUS_THREAD_DEBUG
60QT_BEGIN_NAMESPACE
61typedef void (*qdbusThreadDebugFunc)(int, int, QDBusConnectionPrivate *);
62QDBUS_EXPORT void qdbusDefaultThreadDebug(int, int, QDBusConnectionPrivate *);
63extern QDBUS_EXPORT qdbusThreadDebugFunc qdbusThreadDebug;
64QT_END_NAMESPACE
65#endif
66
67enum ThreadAction {
68 ConnectAction = 0,
69 DisconnectAction = 1,
70 RegisterObjectAction = 2,
71 UnregisterObjectAction = 3,
72 ObjectRegisteredAtAction = 4,
73
74 CloseConnectionAction = 10,
75 ObjectDestroyedAction = 11,
76 RelaySignalAction = 12,
77 HandleObjectCallAction = 13,
78 HandleSignalAction = 14,
79 ConnectRelayAction = 15,
80 DisconnectRelayAction = 16,
81 FindMetaObject1Action = 17,
82 FindMetaObject2Action = 18,
83 RegisterServiceAction = 19,
84 UnregisterServiceAction = 20,
85 UpdateSignalHookOwnerAction = 21,
86 HandleObjectCallPostEventAction = 22,
87 HandleObjectCallSemaphoreAction = 23,
88 DoDispatchAction = 24,
89 SendWithReplyAsyncAction = 25,
90 MessageResultReceivedAction = 26,
91 ActivateSignalAction = 27,
92 PendingCallBlockAction = 28,
93
94 AddTimeoutAction = 50,
95 RealAddTimeoutAction = 51,
96 RemoveTimeoutAction = 52,
97 KillTimerAction = 58,
98 TimerEventAction = 59,
99 AddWatchAction = 60,
100 RemoveWatchAction = 61,
101 ToggleWatchAction = 62,
102 SocketReadAction = 63,
103 SocketWriteAction = 64,
104};
105
106struct QDBusLockerBase
107{
108 enum Condition
109 {
110 BeforeLock,
111 AfterLock,
112 BeforeUnlock,
113 AfterUnlock,
114
115 BeforePost,
116 AfterPost,
117 BeforeDeliver,
118 AfterDeliver,
119
120 BeforeAcquire,
121 AfterAcquire,
122 BeforeRelease,
123 AfterRelease
124 };
125
126#if QDBUS_THREAD_DEBUG
127 static inline void reportThreadAction(int action, int condition, QDBusConnectionPrivate *ptr)
128 { if (qdbusThreadDebug) qdbusThreadDebug(action, condition, ptr); }
129#else
130 static inline void reportThreadAction(int, int, QDBusConnectionPrivate *) { }
131#endif
132};
133
134struct QDBusReadLocker: QDBusLockerBase
135{
136 QDBusConnectionPrivate *self;
137 ThreadAction action;
138 inline QDBusReadLocker(ThreadAction a, QDBusConnectionPrivate *s)
139 : self(s), action(a)
140 {
141 reportThreadAction(action, BeforeLock, self);
142 self->lock.lockForRead();
143 reportThreadAction(action, AfterLock, self);
144 }
145
146 inline ~QDBusReadLocker()
147 {
148 reportThreadAction(action, BeforeUnlock, self);
149 self->lock.unlock();
150 reportThreadAction(action, AfterUnlock, self);
151 }
152};
153
154struct QDBusWriteLocker: QDBusLockerBase
155{
156 QDBusConnectionPrivate *self;
157 ThreadAction action;
158 inline QDBusWriteLocker(ThreadAction a, QDBusConnectionPrivate *s)
159 : self(s), action(a)
160 {
161 reportThreadAction(action, BeforeLock, self);
162 self->lock.lockForWrite();
163 reportThreadAction(action, AfterLock, self);
164 }
165
166 inline ~QDBusWriteLocker()
167 {
168 reportThreadAction(action, BeforeUnlock, self);
169 self->lock.unlock();
170 reportThreadAction(action, AfterUnlock, self);
171 }
172};
173
174struct QDBusMutexLocker: QDBusLockerBase
175{
176 QDBusConnectionPrivate *self;
177 QMutex *mutex;
178 ThreadAction action;
179 inline QDBusMutexLocker(ThreadAction a, QDBusConnectionPrivate *s,
180 QMutex *m)
181 : self(s), mutex(m), action(a)
182 {
183 reportThreadAction(action, BeforeLock, self);
184 mutex->lock();
185 reportThreadAction(action, AfterLock, self);
186 }
187
188 inline ~QDBusMutexLocker()
189 {
190 reportThreadAction(action, BeforeUnlock, self);
191 mutex->unlock();
192 reportThreadAction(action, AfterUnlock, self);
193 }
194};
195
196struct QDBusDispatchLocker: QDBusMutexLocker
197{
198 inline QDBusDispatchLocker(ThreadAction a, QDBusConnectionPrivate *s)
199 : QDBusMutexLocker(a, s, &s->dispatchLock)
200 { }
201};
202
203struct QDBusWatchAndTimeoutLocker: QDBusMutexLocker
204{
205 inline QDBusWatchAndTimeoutLocker(ThreadAction a, QDBusConnectionPrivate *s)
206 : QDBusMutexLocker(a, s, &s->watchAndTimeoutLock)
207 { }
208};
209
210#if QDBUS_THREAD_DEBUG
211# define SEM_ACQUIRE(action, sem) \
212 do { \
213 QDBusLockerBase::reportThreadAction(action, QDBusLockerBase::BeforeAcquire, this); \
214 sem.acquire(); \
215 QDBusLockerBase::reportThreadAction(action, QDBusLockerBase::AfterAcquire, this); \
216 } while (0)
217
218# define SEM_RELEASE(action, sem) \
219 do { \
220 QDBusLockerBase::reportThreadAction(action, QDBusLockerBase::BeforeRelease, that); \
221 sem.release(); \
222 QDBusLockerBase::reportThreadAction(action, QDBusLockerBase::AfterRelease, that); \
223 } while (0)
224
225#else
226# define SEM_ACQUIRE(action, sem) sem.acquire()
227# define SEM_RELEASE(action, sem) sem.release()
228#endif
229
230#endif
Note: See TracBrowser for help on using the repository browser.