2003-12-26 Guilhem Lavaux <guilhem@kaffe.org>
[official-gcc.git] / libjava / include / win32-threads.h
blobfdd21c541b4b22f8eccb34d50a3d7541c55e6292
1 // -*- c++ -*-
2 // win32-threads.h - Defines for using Win32 threads.
4 /* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Free Software
5 Foundation
7 This file is part of libgcj.
9 This software is copyrighted work licensed under the terms of the
10 Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
11 details. */
13 #ifndef __JV_WIN32_THREADS__
14 #define __JV_WIN32_THREADS__
16 #include <windows.h>
19 // Typedefs.
22 typedef struct
24 // ev[0] (signal) is a Win32 auto-reset event for _Jv_CondNotify
25 // ev[1] (broadcast) is a Win32 manual-reset event for _Jv_CondNotifyAll
26 HANDLE ev[2];
28 // Number of threads waiting on this condition variable
29 int blocked_count;
31 // Protects access to the blocked_count variable
32 CRITICAL_SECTION count_mutex;
34 } _Jv_ConditionVariable_t;
36 typedef struct
38 // The thread-id of the owner thread if any, 0 otherwise
39 DWORD owner;
41 // Track nested mutex acquisitions by the same thread
42 int refcount;
44 // The actual Windows construct used to implement this mutex
45 CRITICAL_SECTION cs;
47 } _Jv_Mutex_t;
49 typedef struct
51 int flags; // Flags are defined in implementation.
52 HANDLE handle; // Actual handle to the thread
54 // Protects access to the thread's interrupt_flag and
55 // interrupt_event variables within this module.
56 CRITICAL_SECTION interrupt_mutex;
58 // A Win32 auto-reset event for thread interruption
59 HANDLE interrupt_event;
61 java::lang::Thread *thread_obj;
62 } _Jv_Thread_t;
64 typedef DWORD _Jv_ThreadId_t;
66 inline _Jv_ThreadId_t
67 _Jv_ThreadSelf (void)
69 return GetCurrentThreadId();
72 typedef void _Jv_ThreadStartFunc (java::lang::Thread *);
75 // Condition variables.
78 int _Jv_CondWait (_Jv_ConditionVariable_t *cv, _Jv_Mutex_t *mu, jlong millis, jint nanos);
79 void _Jv_CondInit (_Jv_ConditionVariable_t *cv);
80 void _Jv_CondDestroy (_Jv_ConditionVariable_t *cv);
81 int _Jv_CondNotify (_Jv_ConditionVariable_t *cv, _Jv_Mutex_t *);
82 int _Jv_CondNotifyAll (_Jv_ConditionVariable_t *cv, _Jv_Mutex_t *);
85 // Mutexes.
86 // We use CRITICAL_SECTIONs instead of CreateMutex() for better performance
89 // Returns 0 if the mutex lock is held by the current thread, and 1 otherwise.
90 inline int _Jv_MutexCheckMonitor (_Jv_Mutex_t *mu)
92 return (mu->owner != GetCurrentThreadId ( ));
95 inline void _Jv_MutexInit (_Jv_Mutex_t *mu)
97 mu->owner = 0UL;
98 mu->refcount = 0;
99 InitializeCriticalSection (&(mu->cs));
102 #define _Jv_HaveMutexDestroy
103 inline void _Jv_MutexDestroy (_Jv_Mutex_t *mu)
105 mu->owner = 0UL;
106 mu->refcount = 0;
107 DeleteCriticalSection (&(mu->cs));
108 mu = NULL;
111 inline int _Jv_MutexUnlock (_Jv_Mutex_t *mu)
113 if (mu->owner == GetCurrentThreadId ( ))
115 mu->refcount--;
116 if (mu->refcount == 0)
117 mu->owner = 0UL;
118 LeaveCriticalSection (&(mu->cs));
119 return 0;
121 else
122 return 1;
125 inline int _Jv_MutexLock (_Jv_Mutex_t *mu)
127 EnterCriticalSection (&(mu->cs));
128 mu->owner = GetCurrentThreadId ( );
129 mu->refcount++;
130 return 0;
134 // Thread creation and manipulation.
137 void _Jv_InitThreads (void);
138 _Jv_Thread_t *_Jv_ThreadInitData (java::lang::Thread *thread);
139 void _Jv_ThreadDestroyData (_Jv_Thread_t *data);
141 inline java::lang::Thread* _Jv_ThreadCurrent (void)
143 extern DWORD _Jv_ThreadKey;
144 return (java::lang::Thread *) TlsGetValue(_Jv_ThreadKey);
147 inline _Jv_Thread_t *_Jv_ThreadCurrentData(void)
149 extern DWORD _Jv_ThreadDataKey;
150 return (_Jv_Thread_t *) TlsGetValue(_Jv_ThreadDataKey);
153 inline void _Jv_ThreadYield (void)
155 Sleep (0);
158 void _Jv_ThreadRegister (_Jv_Thread_t *data);
159 void _Jv_ThreadUnRegister ();
161 void _Jv_ThreadSetPriority (_Jv_Thread_t *data, jint prio);
162 void _Jv_ThreadStart (java::lang::Thread *thread, _Jv_Thread_t *data,
163 _Jv_ThreadStartFunc *meth);
164 void _Jv_ThreadWait (void);
165 void _Jv_ThreadInterrupt (_Jv_Thread_t *data);
168 // Thread interruption support
171 // Gets the auto-reset event for the current thread which is
172 // signalled by _Jv_ThreadInterrupt. The caller can wait on this
173 // event in addition to other waitable objects.
175 // NOTE: After waiting on this event with WaitForMultipleObjects,
176 // you should ALWAYS use the return value of WaitForMultipleObjects
177 // to test whether this event was signalled and whether thread
178 // interruption has occurred. You should do this instead of checking
179 // the thread's interrupted_flag, because someone could have reset
180 // this flag in the interval of time between the return of
181 // WaitForMultipleObjects and the time you query interrupted_flag.
182 // See java/lang/natWin32Process.cc (waitFor) for an example.
183 HANDLE _Jv_Win32GetInterruptEvent (void);
185 // Remove defines from <windows.h> that conflict with various things in libgcj code
187 #undef TRUE
188 #undef FALSE
189 #undef MAX_PRIORITY
190 #undef MIN_PRIORITY
191 #undef min
192 #undef max
193 #undef interface
194 #undef STRICT
195 #undef VOID
197 #endif /* __JV_WIN32_THREADS__ */