ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/BDB/xthread.h
Revision: 1.2
Committed: Sun Jul 8 09:16:19 2007 UTC (16 years, 10 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.1: +130 -32 lines
Log Message:
*** empty log message ***

File Contents

# Content
1 /* wether word reads are potentially non-atomic.
2 * this is conservatice, likely most arches this runs
3 * on have atomic word read/writes.
4 */
5 #ifndef WORDACCESS_UNSAFE
6 # if __i386 || __x86_64
7 # define WORDACCESS_UNSAFE 0
8 # else
9 # define WORDACCESS_UNSAFE 1
10 # endif
11 #endif
12
13 /////////////////////////////////////////////////////////////////////////////
14
15 #ifdef _WIN32
16 typedef int ssize_t;
17
18 #define NTDDI_VERSION NTDDI_WIN2K // needed to get win2000 api calls
19 #define _WIN32_WINNT 0x400
20 #include <stdio.h>//D
21 #include <fcntl.h>
22 #include <io.h>
23 #include <winsock2.h>
24 #include <process.h>
25 #include <windows.h>
26 #define sigset_t int
27 #define sigfillset(a)
28 #define pthread_sigmask(a,b,c)
29 #define sigaddset(a,b)
30 #define sigemptyset(s)
31 #define sigfillset(s)
32
33 #define pthread_kill(a,b)
34 #define pthread_self() 0
35
36 typedef HANDLE mutex_t;
37 #define X_MUTEX_INIT 0
38 #define X_MUTEX_CHECK(mutex) if (!(mutex)) (mutex) = CreateMutex (NULL, FALSE, NULL)
39 #define X_LOCK(mutex) WaitForSingleObject ((mutex), INFINITE)
40 #define X_UNLOCK(mutex) ReleaseMutex (mutex)
41
42 typedef HANDLE cond_t;
43 #define X_COND_INIT 0
44 #define X_COND_CHECK(cond) if (!(cond)) (cond) = CreateEvent (NULL, FALSE, FALSE, NULL)
45 #define X_COND_SIGNAL(cond) SetEvent (cond)
46 #define X_COND_WAIT(cond,mutex) do { SignalObjectAndWait ((mutex), (cond),INFINITE, FALSE); WaitForSingleObject ((mutex), INFINITE); } while (0)
47
48 #define ETIMEDOUT 1
49
50 struct timespec {
51 unsigned long tv_sec, tv_nsec;
52 };
53
54 static int
55 X_COND_TIMEDWAIT (mutex_t mutex, cond_t cond, struct timespec to)
56 {
57 unsigned long ms = to.tv_nsec / 1000 + to.tv_sec * 1000;
58
59 if (SignalObjectAndWait (mutex, cond, ms, FALSE) == WAIT_TIMEOUT)
60 return ETIMEDOUT;
61
62 if (WaitForSingleObject (mutex, ms) == WAIT_TIMEOUT)
63 return ETIMEDOUT;
64
65 return 0;
66 }
67
68 typedef DWORD thread_t;
69 #define X_THREAD_PROC(name) DWORD WINAPI name (LPVOID thr_arg)
70 #define X_THREAD_ATFORK(a,b,c)
71
72 static int
73 thread_create (thread_t *tid, LPTHREAD_START_ROUTINE proc, void *arg)
74 {
75 *tid = 0;
76 CreateThread (0, 4096, proc, arg, 0, tid);
77 return !!*tid;
78 }
79
80 int Perl_my_socketpair (int family, int type, int protocol, int fd[2]);
81
82 static int
83 create_pipe (int fd[2])
84 {
85 int arg = 1;
86 Perl_my_socketpair (AF_UNIX, SOCK_STREAM, 0, fd);
87 ioctlsocket (fd [0], FIONBIO, &arg);
88 ioctlsocket (fd [1], FIONBIO, &arg);
89
90 return 1;
91 }
92
93 #else
94 /////////////////////////////////////////////////////////////////////////////
95
96 /* solaris */
97 #define _POSIX_PTHREAD_SEMANTICS 1
98
99 #if __linux && !defined(_GNU_SOURCE)
100 # define _GNU_SOURCE
101 #endif
102
103 /* just in case */
104 #define _REENTRANT 1
105
106 #include <unistd.h>
107 #include <fcntl.h>
108 #include <signal.h>
109 #include <pthread.h>
110
111 #ifndef PTHREAD_STACK_MIN
112 /* care for broken platforms, e.g. windows */
113 # define PTHREAD_STACK_MIN 16384
114 #endif
115
116 typedef pthread_mutex_t mutex_t;
117 #if __linux && defined (PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP)
118 # define X_MUTEX_INIT PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP
119 #else
120 # define X_MUTEX_INIT PTHREAD_MUTEX_INITIALIZER
121 #endif
122 #define X_LOCK(mutex) pthread_mutex_lock (&(mutex))
123 #define X_UNLOCK(mutex) pthread_mutex_unlock (&(mutex))
124
125 typedef pthread_cond_t cond_t;
126 #define X_COND_INIT PTHREAD_COND_INITIALIZER
127 #define X_COND_SIGNAL(cond) pthread_cond_signal (&(cond))
128 #define X_COND_WAIT(cond,mutex) pthread_cond_wait (&(cond), &(mutex))
129 #define X_COND_TIMEDWAIT(cond,mutex,to) pthread_cond_timedwait (&(cond), &(mutex), &(to))
130
131 typedef pthread_t thread_t;
132 #define X_THREAD_PROC(name) static void *name (void *thr_arg)
133 #define X_THREAD_ATFORK(prepare,parent,child) pthread_atfork (prepare, parent, child)
134
135 static int
136 thread_create (thread_t *tid, void *(*proc)(void *), void *arg)
137 {
138 int retval;
139 sigset_t fullsigset, oldsigset;
140 pthread_attr_t attr;
141
142 pthread_attr_init (&attr);
143 pthread_attr_setdetachstate (&attr, PTHREAD_CREATE_DETACHED);
144 #ifdef PTHREAD_SCOPE_PROCESS
145 pthread_attr_setscope (&attr, PTHREAD_SCOPE_PROCESS);
146 #endif
147
148 sigfillset (&fullsigset);
149
150 pthread_sigmask (SIG_SETMASK, &fullsigset, &oldsigset);
151 retval = pthread_create (tid, &attr, proc, arg) == 0;
152 pthread_sigmask (SIG_SETMASK, &oldsigset, 0);
153
154 return retval;
155 }
156
157 static int
158 create_pipe (int fd[2])
159 {
160 if (pipe (fd)
161 || fcntl (fd [0], F_SETFL, O_NONBLOCK)
162 || fcntl (fd [1], F_SETFL, O_NONBLOCK))
163 return 0;
164
165 return 1;
166 }
167
168 #endif
169
170 #if __ia64
171 # define STACKSIZE 65536
172 #elif __i386 || __x86_64 /* 16k is unreasonably high :( */
173 # define STACKSIZE PTHREAD_STACK_MIN
174 #else
175 # define STACKSIZE 16384
176 #endif
177
178