blob: 85d698d4c9eb848204294da3300ef9ba85dd792f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
/*
LibRCC - module responsible for thread synchronization
Copyright (C) 2005-2018 Suren A. Chilingaryan <csa@suren.me>
This library is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License version 2.1 or later
as published by the Free Software Foundation.
This library is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include <stdlib.h>
#include <time.h>
#ifdef HAVE_UNISTD_H
# include <unistd.h>
#endif /* HAVE_UNISTD_H */
#ifdef WIN32
# include <windows.h>
#endif /* WIN32 */
#include "rccmutex.h"
#define RCC_MUTEX_SLEEP 500
rcc_mutex rccMutexCreate() {
rcc_mutex mutex;
mutex = (rcc_mutex)malloc(sizeof(rcc_mutex_s));
if (mutex) {
#ifdef HAVE_PTHREAD
pthread_mutex_init(&mutex->mutex, NULL);
#else
mutex->mutex = 0;
#endif /* HAVE_PTHREAD */
}
return mutex;
}
void rccMutexFree(rcc_mutex mutex) {
if (mutex) {
#ifdef HAVE_PTHREAD
pthread_mutex_destroy(&mutex->mutex);
#endif /* HAVE_PTHREAD */
free(mutex);
}
}
int rccMutexLock(rcc_mutex mutex) {
#ifndef HAVE_PTHREAD
# ifdef HAVE_NANOSLEEP
struct timespec ts;
# endif /* HAVE_NANOSLEEP */
#endif /* !HAVE_PTHREAD */
if (!mutex) return -1;
#ifdef HAVE_PTHREAD
return pthread_mutex_lock(&mutex->mutex);
#else
while (mutex->mutex) {
# if defined(HAVE_NANOSLEEP)
ts.tv_sec = RCC_MUTEX_SLEEP / 1000000;
ts.tv_nsec = (RCC_MUTEX_SLEEP % 1000000)*1000;
nanosleep(&ts, NULL);
# elif defined (HAVE_USLEEP)
usleep(RCC_MUTEX_SLEEP);
# elif defined (WIN32)
Sleep((RCC_MUTEX_SLEEP<1000)?1:RCC_MUTEX_SLEEP/1000);
# endif /* HAVE_NANOSLEEP */
}
mutex->mutex = 1;
return 0;
#endif /* HAVE_PTHREAD */
}
int rccMutexTryLock(rcc_mutex mutex) {
if (!mutex) return -1;
#ifdef HAVE_PTHREAD
return pthread_mutex_trylock(&mutex->mutex);
#else
if (mutex->mutex) return -1;
mutex->mutex = 1;
return 0;
#endif /* HAVE_PTHREAD */
}
void rccMutexUnLock(rcc_mutex mutex) {
if (!mutex) return;
#ifdef HAVE_PTHREAD
pthread_mutex_unlock(&mutex->mutex);
#else
mutex->mutex = 0;
#endif /* HAVE_PTHREAD */
}
|