1
/****************************************************************************
3
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
5
** This file is part of the core module of the Qt Toolkit.
7
** This file may be distributed under the terms of the Q Public License
8
** as defined by Trolltech AS of Norway and appearing in the file
9
** LICENSE.QPL included in the packaging of this file.
11
** This file may be distributed and/or modified under the terms of the
12
** GNU General Public License version 2 as published by the Free Software
13
** Foundation and appearing in the file LICENSE.GPL included in the
14
** packaging of this file.
16
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
17
** information about Qt Commercial License Agreements.
18
** See http://www.trolltech.com/qpl/ for QPL licensing information.
19
** See http://www.trolltech.com/gpl/ for GPL licensing information.
21
** Contact info@trolltech.com if any conditions of this licensing are
24
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
25
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
27
****************************************************************************/
29
#ifndef MIPS_QATOMIC_H
30
#define MIPS_QATOMIC_H
32
#include <QtCore/qglobal.h>
35
Q_CORE_EXPORT int q_atomic_test_and_set_int(volatile int *ptr, int expected, int newval);
36
Q_CORE_EXPORT int q_atomic_test_and_set_ptr(volatile void *ptr, void *expected, void *newval);
39
inline int q_atomic_increment(volatile int * const ptr)
41
register int expected;
44
if (q_atomic_test_and_set_int(ptr, expected, expected + 1)) break;
46
return expected != -1;
49
inline int q_atomic_decrement(volatile int * const ptr)
51
register int expected;
54
if (q_atomic_test_and_set_int(ptr, expected, expected - 1)) break;
59
inline int q_atomic_set_int(volatile int *ptr, int newval)
61
register int expected;
64
if (q_atomic_test_and_set_int(ptr, expected, newval)) break;
69
inline void *q_atomic_set_ptr(volatile void *ptr, void *newval)
71
register void *expected;
73
expected = *reinterpret_cast<void * volatile *>(ptr);
74
if (q_atomic_test_and_set_ptr(ptr, expected, newval)) break;
79
#endif // MIPS_QATOMIC_H