• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 **********************************************************************
3 *   Copyright (C) 1997-2008, International Business Machines
4 *   Corporation and others.  All Rights Reserved.
5 **********************************************************************
6 *
7 * File UMUTEX.H
8 *
9 * Modification History:
10 *
11 *   Date        Name        Description
12 *   04/02/97  aliu        Creation.
13 *   04/07/99  srl         rewrite - C interface, multiple mutices
14 *   05/13/99  stephen     Changed to umutex (from cmutex)
15 ******************************************************************************
16 */
17 
18 #ifndef UMUTEX_H
19 #define UMUTEX_H
20 
21 #include "unicode/utypes.h"
22 #include "unicode/uclean.h"
23 
24 
25 /* APP_NO_THREADS is an old symbol. We'll honour it if present. */
26 #ifdef APP_NO_THREADS
27 # define ICU_USE_THREADS 0
28 #endif
29 
30 /* ICU_USE_THREADS
31  *
32  *   Allows thread support (use of mutexes) to be compiled out of ICU.
33  *   Default: use threads.
34  *   Even with thread support compiled out, applications may override the
35  *   (empty) mutex implementation with the u_setMutexFunctions() functions.
36  */
37 #ifndef ICU_USE_THREADS
38 # define ICU_USE_THREADS 1
39 #endif
40 
41 /**
42  * By default assume that we are on a machine with a weak memory model,
43  * and the double check lock won't work reliably.
44  */
45 #if !defined(UMTX_STRONG_MEMORY_MODEL)
46 #define UMTX_STRONG_MEMORY_MODEL 0
47 #endif
48 
49 /**
50  * \def UMTX_CHECK
51  * Encapsulates a safe check of an expression
52  * for use with double-checked lazy inititialization.
53  * On CPUs with weak memory models, this must use memory fence instructions
54  * or mutexes.
55  * The expression must involve only a  _single_ variable, typically
56  *    a possibly null pointer or a boolean that indicates whether some service
57  *    is initialized or not.
58  * The setting of the variable involved in the test must be the last step of
59  *    the initialization process.
60  *
61  *
62  * @internal
63  */
64 #if UMTX_STRONG_MEMORY_MODEL
65 
66 #define UMTX_CHECK(pMutex, expression, result) \
67     (result)=(expression)
68 
69 #else
70 
71 #define UMTX_CHECK(pMutex, expression, result) \
72     umtx_lock(pMutex); \
73     (result)=(expression); \
74     umtx_unlock(pMutex)
75 
76 #endif
77 
78 /*
79  * Code within ICU that accesses shared static or global data should
80  * instantiate a Mutex object while doing so.  The unnamed global mutex
81  * is used throughout ICU, so keep locking short and sweet.
82  *
83  * For example:
84  *
85  * void Function(int arg1, int arg2)
86  * {
87  *   static Object* foo;     // Shared read-write object
88  *   umtx_lock(NULL);        // Lock the ICU global mutex
89  *   foo->Method();
90  *   umtx_unlock(NULL);
91  * }
92  *
93  * an alternative C++ mutex API is defined in the file common/mutex.h
94  */
95 
96 /* Lock a mutex.
97  * @param mutex The given mutex to be locked.  Pass NULL to specify
98  *              the global ICU mutex.  Recursive locks are an error
99  *              and may cause a deadlock on some platforms.
100  */
101 U_CAPI void U_EXPORT2 umtx_lock   ( UMTX* mutex );
102 
103 /* Unlock a mutex. Pass in NULL if you want the single global
104    mutex.
105  * @param mutex The given mutex to be unlocked.  Pass NULL to specify
106  *              the global ICU mutex.
107  */
108 U_CAPI void U_EXPORT2 umtx_unlock ( UMTX* mutex );
109 
110 /* Initialize a mutex. Use it this way:
111    umtx_init( &aMutex );
112  * ICU Mutexes do not need explicit initialization before use.  Use of this
113  *   function is not necessary.
114  * Initialization of an already initialized mutex has no effect, and is safe to do.
115  * Initialization of mutexes is thread safe.  Two threads can concurrently
116  *   initialize the same mutex without causing problems.
117  * @param mutex The given mutex to be initialized
118  */
119 U_CAPI void U_EXPORT2 umtx_init   ( UMTX* mutex );
120 
121 /* Destroy a mutex. This will free the resources of a mutex.
122  * Use it this way:
123  *   umtx_destroy( &aMutex );
124  * Destroying an already destroyed mutex has no effect, and causes no problems.
125  * This function is not thread safe.  Two threads must not attempt to concurrently
126  *   destroy the same mutex.
127  * @param mutex The given mutex to be destroyed.
128  */
129 U_CAPI void U_EXPORT2 umtx_destroy( UMTX *mutex );
130 
131 
132 
133 /*
134  * Atomic Increment and Decrement of an int32_t value.
135  *
136  * Return Values:
137  *   If the result of the operation is zero, the return zero.
138  *   If the result of the operation is not zero, the sign of returned value
139  *      is the same as the sign of the result, but the returned value itself may
140  *      be different from the result of the operation.
141  */
142 U_CAPI int32_t U_EXPORT2 umtx_atomic_inc(int32_t *);
143 U_CAPI int32_t U_EXPORT2 umtx_atomic_dec(int32_t *);
144 
145 
146 #endif /*_CMUTEX*/
147 /*eof*/
148 
149 
150 
151