Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

thread.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  * thread.h - thread manipulation
00059  */
00060 
00061 #ifndef GW_THREAD_H
00062 #define GW_THREAD_H
00063 
00064 #include "gw-config.h"
00065 
00066 #if !HAVE_PTHREAD_H
00067 #error "You need POSIX.1 threads and <pthread.h> header file"
00068 #endif
00069 
00070 #include <pthread.h>
00071 
00072 /*
00073  * Wrapper around pthread_mutex_t to avoid problems with recursive calls
00074  * to pthread_mutex_trylock on Linux (at least).
00075  */
00076 typedef struct {
00077     pthread_mutex_t mutex;
00078     long owner;
00079     int dynamic;
00080 #ifdef MUTEX_STATS
00081     unsigned char *filename;
00082     int lineno;
00083     long locks;
00084     long collisions;
00085 #endif
00086 } Mutex;
00087 
00088 
00089 /*
00090  * Create a Mutex.
00091  */
00092 #ifdef MUTEX_STATS
00093 #define mutex_create() gw_claim_area(mutex_make_measured(mutex_create_real(), \
00094                                                          __FILE__, __LINE__))
00095 #else
00096 #define mutex_create() gw_claim_area(mutex_create_real())
00097 #endif
00098 
00099 /*
00100  * Create a Mutex.  Call these functions via the macro defined above.
00101  */
00102 Mutex *mutex_create_measured(Mutex *mutex, unsigned char *filename, 
00103                              int lineno);
00104 Mutex *mutex_create_real(void);
00105 
00106 
00107 /*
00108  * Initialize a statically allocated Mutex.  We need those inside gwlib
00109  * modules that are in turn used by the mutex wrapper, such as "gwmem" and
00110  * "protected".
00111  */
00112 #ifdef MUTEX_STATS
00113 #define mutex_init_static(mutex) \
00114     mutex_make_measured(mutex_init_static_real(mutex), __FILE__, __LINE__)
00115 #else
00116 #define mutex_init_static(mutex) \
00117     mutex_init_static_real(mutex)
00118 #endif
00119 
00120 Mutex *mutex_init_static_real(Mutex *mutex);
00121 
00122 
00123 /*
00124  * Destroy a Mutex.
00125  */
00126 void mutex_destroy(Mutex *mutex);
00127 
00128 
00129 /* lock given mutex. PANIC if fails (non-initialized mutex or other
00130  * coding error) */ 
00131 #define mutex_lock(m) mutex_lock_real(m, __FILE__, __LINE__, __func__)
00132 void mutex_lock_real(Mutex *mutex, char *file, int line, const char *func);
00133 
00134 
00135 /* unlock given mutex, PANIC if fails (so do not call for non-locked) */
00136 /* returns 0 if ok 1 if failure for debugging */
00137 #define mutex_unlock(m) mutex_unlock_real(m, __FILE__, __LINE__, __func__)
00138 int mutex_unlock_real(Mutex *mutex, char *file, int line, const char *func);
00139 
00140 
00141 /*
00142  * Try to lock given mutex, returns -1 if mutex is NULL; 0 if mutex acquired; otherwise
00143  * EBUSY. PANIC if mutex was not properly initialized before.
00144  */
00145 #define mutex_trylock(m) mutex_trylock_real(m, __FILE__, __LINE__, __func__)
00146 int mutex_trylock_real(Mutex *mutex, const char *file, int line, const char *func);
00147 
00148 #endif
00149 
00150 
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.