blob: cfd0834249bd86954778b5ead72fcf5153cdd498 [file] [log] [blame]
Guido van Rossum62332931995-04-10 11:36:14 +00001/* This code implemented by cvale@netcom.com */
2
3#define INCL_DOSPROCESS
4#define INCL_DOSSEMAPHORES
5#include "os2.h"
6#include "limits.h"
7
8#include "process.h"
9
Guido van Rossum65d5b571998-12-21 19:32:43 +000010long PyThread_get_thread_ident(void);
Guido van Rossum62332931995-04-10 11:36:14 +000011
12
13/*
14 * Initialization of the C package, should not be needed.
15 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000016static void
17PyThread__init_thread(void)
Guido van Rossum62332931995-04-10 11:36:14 +000018{
19}
20
21/*
22 * Thread support.
23 */
Guido van Rossum3c288632001-10-16 21:13:49 +000024long
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000025PyThread_start_new_thread(void (*func)(void *), void *arg)
Guido van Rossum62332931995-04-10 11:36:14 +000026{
27 int aThread;
Guido van Rossum3c288632001-10-16 21:13:49 +000028 int success = 0;
Guido van Rossum62332931995-04-10 11:36:14 +000029
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +000030 aThread = _beginthread(func,NULL,65536,arg);
Guido van Rossum62332931995-04-10 11:36:14 +000031
32 if( aThread == -1 ) {
Guido van Rossum3c288632001-10-16 21:13:49 +000033 success = -1;
Guido van Rossum62332931995-04-10 11:36:14 +000034 fprintf(stderr,"aThread failed == %d",aThread);
35 dprintf(("_beginthread failed. return %ld\n", errno));
36 }
37
38 return success;
39}
40
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000041long
42PyThread_get_thread_ident(void)
Guido van Rossum62332931995-04-10 11:36:14 +000043{
44 PPIB pib;
45 PTIB tib;
46
47 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +000048 PyThread_init_thread();
Guido van Rossum62332931995-04-10 11:36:14 +000049
50 DosGetInfoBlocks(&tib,&pib);
51 return tib->tib_ptib2->tib2_ultid;
52}
53
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000054static void
55do_PyThread_exit_thread(int no_cleanup)
Guido van Rossum62332931995-04-10 11:36:14 +000056{
Guido van Rossum65d5b571998-12-21 19:32:43 +000057 dprintf(("%ld: PyThread_exit_thread called\n", PyThread_get_thread_ident()));
Guido van Rossum62332931995-04-10 11:36:14 +000058 if (!initialized)
59 if (no_cleanup)
60 _exit(0);
61 else
62 exit(0);
63 _endthread();
64}
65
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000066void
67PyThread_exit_thread(void)
Guido van Rossum62332931995-04-10 11:36:14 +000068{
Guido van Rossum65d5b571998-12-21 19:32:43 +000069 do_PyThread_exit_thread(0);
Guido van Rossum62332931995-04-10 11:36:14 +000070}
71
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000072void
73PyThread__exit_thread(void)
Guido van Rossum62332931995-04-10 11:36:14 +000074{
Guido van Rossum65d5b571998-12-21 19:32:43 +000075 do_PyThread_exit_thread(1);
Guido van Rossum62332931995-04-10 11:36:14 +000076}
77
78#ifndef NO_EXIT_PROG
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000079static void
80do_PyThread_exit_prog(int status, int no_cleanup)
Guido van Rossum62332931995-04-10 11:36:14 +000081{
Guido van Rossum65d5b571998-12-21 19:32:43 +000082 dprintf(("PyThread_exit_prog(%d) called\n", status));
Guido van Rossum62332931995-04-10 11:36:14 +000083 if (!initialized)
84 if (no_cleanup)
85 _exit(status);
86 else
87 exit(status);
88}
89
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000090void
91PyThread_exit_prog(int status)
Guido van Rossum62332931995-04-10 11:36:14 +000092{
Guido van Rossum65d5b571998-12-21 19:32:43 +000093 do_PyThread_exit_prog(status, 0);
Guido van Rossum62332931995-04-10 11:36:14 +000094}
95
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000096void
97PyThread__exit_prog(int status)
Guido van Rossum62332931995-04-10 11:36:14 +000098{
Guido van Rossum65d5b571998-12-21 19:32:43 +000099 do_PyThread_exit_prog(status, 1);
Guido van Rossum62332931995-04-10 11:36:14 +0000100}
101#endif /* NO_EXIT_PROG */
102
103/*
Tim Petersa6ca4f42001-10-31 03:50:45 +0000104 * Lock support. This is implemented with an event semaphore and critical
105 * sections to make it behave more like a posix mutex than its OS/2
106 # counterparts.
Guido van Rossum62332931995-04-10 11:36:14 +0000107 */
Tim Petersa6ca4f42001-10-31 03:50:45 +0000108
109typedef struct os2_lock_t {
110 int is_set;
111 HEV changed;
112} *type_os2_lock;
113
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000114PyThread_type_lock
115PyThread_allocate_lock(void)
Guido van Rossum62332931995-04-10 11:36:14 +0000116{
Guido van Rossum62332931995-04-10 11:36:14 +0000117 APIRET rc;
Tim Petersa6ca4f42001-10-31 03:50:45 +0000118 type_os2_lock lock = (type_os2_lock)malloc(sizeof(struct os2_lock_t));
Guido van Rossum62332931995-04-10 11:36:14 +0000119
Guido van Rossum65d5b571998-12-21 19:32:43 +0000120 dprintf(("PyThread_allocate_lock called\n"));
Guido van Rossum62332931995-04-10 11:36:14 +0000121 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +0000122 PyThread_init_thread();
Guido van Rossum62332931995-04-10 11:36:14 +0000123
Tim Petersa6ca4f42001-10-31 03:50:45 +0000124 lock->is_set = 0;
Guido van Rossum62332931995-04-10 11:36:14 +0000125
Tim Petersa6ca4f42001-10-31 03:50:45 +0000126 DosCreateEventSem(NULL, &lock->changed, 0, 0);
Guido van Rossum62332931995-04-10 11:36:14 +0000127
Tim Petersa6ca4f42001-10-31 03:50:45 +0000128 dprintf(("%ld: PyThread_allocate_lock() -> %p\n",
129 PyThread_get_thread_ident(),
130 lock->changed));
131
132 return (PyThread_type_lock) lock;
Guido van Rossum62332931995-04-10 11:36:14 +0000133}
134
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000135void
136PyThread_free_lock(PyThread_type_lock aLock)
Guido van Rossum62332931995-04-10 11:36:14 +0000137{
Tim Petersa6ca4f42001-10-31 03:50:45 +0000138 type_os2_lock lock = (type_os2_lock)aLock;
Fred Drakea44d3532000-06-30 15:01:00 +0000139 dprintf(("%ld: PyThread_free_lock(%p) called\n", PyThread_get_thread_ident(),aLock));
Guido van Rossum62332931995-04-10 11:36:14 +0000140
Tim Petersa6ca4f42001-10-31 03:50:45 +0000141 DosCloseEventSem(lock->changed);
142 free(aLock);
Guido van Rossum62332931995-04-10 11:36:14 +0000143}
144
145/*
146 * Return 1 on success if the lock was acquired
147 *
Tim Petersa6ca4f42001-10-31 03:50:45 +0000148 * and 0 if the lock was not acquired.
Guido van Rossum62332931995-04-10 11:36:14 +0000149 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000150int
151PyThread_acquire_lock(PyThread_type_lock aLock, int waitflag)
Guido van Rossum62332931995-04-10 11:36:14 +0000152{
Tim Petersa6ca4f42001-10-31 03:50:45 +0000153 int done = 0;
154 ULONG count;
Guido van Rossum62332931995-04-10 11:36:14 +0000155 PID pid = 0;
156 TID tid = 0;
Tim Petersa6ca4f42001-10-31 03:50:45 +0000157 type_os2_lock lock = (type_os2_lock)aLock;
Guido van Rossum62332931995-04-10 11:36:14 +0000158
Fred Drakea44d3532000-06-30 15:01:00 +0000159 dprintf(("%ld: PyThread_acquire_lock(%p, %d) called\n", PyThread_get_thread_ident(),
160 aLock, waitflag));
Guido van Rossum62332931995-04-10 11:36:14 +0000161
Tim Petersa6ca4f42001-10-31 03:50:45 +0000162 while (!done) {
163 /* if the lock is currently set, we have to wait for the state to change */
164 if (lock->is_set) {
165 if (!waitflag)
166 return 0;
167 DosWaitEventSem(lock->changed, SEM_INDEFINITE_WAIT);
Guido van Rossum62332931995-04-10 11:36:14 +0000168 }
Tim Petersa6ca4f42001-10-31 03:50:45 +0000169
170 /*
171 * enter a critical section and try to get the semaphore. If
172 * it is still locked, we will try again.
173 */
174 if (DosEnterCritSec())
175 return 0;
176
177 if (!lock->is_set) {
178 lock->is_set = 1;
179 DosResetEventSem(lock->changed, &count);
180 done = 1;
181 }
182
183 DosExitCritSec();
Guido van Rossum62332931995-04-10 11:36:14 +0000184 }
185
Tim Petersa6ca4f42001-10-31 03:50:45 +0000186 return 1;
Guido van Rossum62332931995-04-10 11:36:14 +0000187}
188
Tim Petersa6ca4f42001-10-31 03:50:45 +0000189void PyThread_release_lock(PyThread_type_lock aLock)
Guido van Rossum62332931995-04-10 11:36:14 +0000190{
Tim Petersa6ca4f42001-10-31 03:50:45 +0000191 type_os2_lock lock = (type_os2_lock)aLock;
Fred Drakea44d3532000-06-30 15:01:00 +0000192 dprintf(("%ld: PyThread_release_lock(%p) called\n", PyThread_get_thread_ident(),aLock));
Guido van Rossum62332931995-04-10 11:36:14 +0000193
Tim Petersa6ca4f42001-10-31 03:50:45 +0000194 if (!lock->is_set) {
Fred Drakea44d3532000-06-30 15:01:00 +0000195 dprintf(("%ld: Could not PyThread_release_lock(%p) error: %l\n",
196 PyThread_get_thread_ident(), aLock, GetLastError()));
Tim Petersa6ca4f42001-10-31 03:50:45 +0000197 return;
Guido van Rossum62332931995-04-10 11:36:14 +0000198 }
Tim Petersa6ca4f42001-10-31 03:50:45 +0000199
200
201 if (DosEnterCritSec()) {
202 dprintf(("%ld: Could not PyThread_release_lock(%p) error: %l\n",
203 PyThread_get_thread_ident(), aLock, GetLastError()));
204 return;
205 }
206
207 lock->is_set = 0;
208 DosPostEventSem(lock->changed);
209
210 DosExitCritSec();
Guido van Rossum62332931995-04-10 11:36:14 +0000211}
212
213/*
214 * Semaphore support.
215 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000216PyThread_type_sema
217PyThread_allocate_sema(int value)
Guido van Rossum62332931995-04-10 11:36:14 +0000218{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000219 return (PyThread_type_sema) 0;
Guido van Rossum62332931995-04-10 11:36:14 +0000220}
221
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000222void
223PyThread_free_sema(PyThread_type_sema aSemaphore)
Guido van Rossum62332931995-04-10 11:36:14 +0000224{
225
226}
227
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000228int
229PyThread_down_sema(PyThread_type_sema aSemaphore, int waitflag)
Guido van Rossum62332931995-04-10 11:36:14 +0000230{
Guido van Rossumcf1474b1996-10-08 14:17:53 +0000231 return -1;
Guido van Rossum62332931995-04-10 11:36:14 +0000232}
233
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000234void
235PyThread_up_sema(PyThread_type_sema aSemaphore)
Guido van Rossum62332931995-04-10 11:36:14 +0000236{
Fred Drakea44d3532000-06-30 15:01:00 +0000237 dprintf(("%ld: PyThread_up_sema(%p)\n", PyThread_get_thread_ident(), aSemaphore));
Guido van Rossum62332931995-04-10 11:36:14 +0000238}