blob: 31800d6c26465cdf3065fb1e02dc492662bd8efd [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/*
104 * Lock support. It has too be implemented as semaphores.
105 * I [Dag] tried to implement it with mutex but I could find a way to
106 * tell whether a thread already own the lock or not.
107 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000108PyThread_type_lock
109PyThread_allocate_lock(void)
Guido van Rossum62332931995-04-10 11:36:14 +0000110{
111 HMTX aLock;
112 APIRET rc;
113
Guido van Rossum65d5b571998-12-21 19:32:43 +0000114 dprintf(("PyThread_allocate_lock called\n"));
Guido van Rossum62332931995-04-10 11:36:14 +0000115 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +0000116 PyThread_init_thread();
Guido van Rossum62332931995-04-10 11:36:14 +0000117
118 DosCreateMutexSem(NULL, /* Sem name */
Thomas Wouters7e474022000-07-16 12:04:32 +0000119 &aLock, /* the semaphore */
Guido van Rossum62332931995-04-10 11:36:14 +0000120 0, /* shared ? */
121 0); /* initial state */
122
Fred Drakea44d3532000-06-30 15:01:00 +0000123 dprintf(("%ld: PyThread_allocate_lock() -> %p\n", PyThread_get_thread_ident(), aLock));
Guido van Rossum62332931995-04-10 11:36:14 +0000124
Guido van Rossum65d5b571998-12-21 19:32:43 +0000125 return (PyThread_type_lock) aLock;
Guido van Rossum62332931995-04-10 11:36:14 +0000126}
127
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000128void
129PyThread_free_lock(PyThread_type_lock aLock)
Guido van Rossum62332931995-04-10 11:36:14 +0000130{
Fred Drakea44d3532000-06-30 15:01:00 +0000131 dprintf(("%ld: PyThread_free_lock(%p) called\n", PyThread_get_thread_ident(),aLock));
Guido van Rossum62332931995-04-10 11:36:14 +0000132
133 DosCloseMutexSem((HMTX)aLock);
134}
135
136/*
137 * Return 1 on success if the lock was acquired
138 *
139 * and 0 if the lock was not acquired. This means a 0 is returned
140 * if the lock has already been acquired by this thread!
141 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000142int
143PyThread_acquire_lock(PyThread_type_lock aLock, int waitflag)
Guido van Rossum62332931995-04-10 11:36:14 +0000144{
145 int success = 1;
146 ULONG rc, count;
147 PID pid = 0;
148 TID tid = 0;
149
Fred Drakea44d3532000-06-30 15:01:00 +0000150 dprintf(("%ld: PyThread_acquire_lock(%p, %d) called\n", PyThread_get_thread_ident(),
151 aLock, waitflag));
Guido van Rossum62332931995-04-10 11:36:14 +0000152
153 DosQueryMutexSem((HMTX)aLock,&pid,&tid,&count);
Guido van Rossum65d5b571998-12-21 19:32:43 +0000154 if( tid == PyThread_get_thread_ident() ) { /* if we own this lock */
Guido van Rossum62332931995-04-10 11:36:14 +0000155 success = 0;
156 } else {
157 rc = DosRequestMutexSem((HMTX) aLock,
158 (waitflag == 1 ? SEM_INDEFINITE_WAIT : 0));
159
160 if( rc != 0) {
161 success = 0; /* We failed */
162 }
163 }
164
Fred Drakea44d3532000-06-30 15:01:00 +0000165 dprintf(("%ld: PyThread_acquire_lock(%p, %d) -> %d\n",
166 PyThread_get_thread_ident(),aLock, waitflag, success));
Guido van Rossum62332931995-04-10 11:36:14 +0000167
168 return success;
169}
170
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000171void
172PyThread_release_lock(PyThread_type_lock aLock)
Guido van Rossum62332931995-04-10 11:36:14 +0000173{
Fred Drakea44d3532000-06-30 15:01:00 +0000174 dprintf(("%ld: PyThread_release_lock(%p) called\n", PyThread_get_thread_ident(),aLock));
Guido van Rossum62332931995-04-10 11:36:14 +0000175
176 if ( DosReleaseMutexSem( (HMTX) aLock ) != 0 ) {
Fred Drakea44d3532000-06-30 15:01:00 +0000177 dprintf(("%ld: Could not PyThread_release_lock(%p) error: %l\n",
178 PyThread_get_thread_ident(), aLock, GetLastError()));
Guido van Rossum62332931995-04-10 11:36:14 +0000179 }
180}
181
182/*
183 * Semaphore support.
184 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000185PyThread_type_sema
186PyThread_allocate_sema(int value)
Guido van Rossum62332931995-04-10 11:36:14 +0000187{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000188 return (PyThread_type_sema) 0;
Guido van Rossum62332931995-04-10 11:36:14 +0000189}
190
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000191void
192PyThread_free_sema(PyThread_type_sema aSemaphore)
Guido van Rossum62332931995-04-10 11:36:14 +0000193{
194
195}
196
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000197int
198PyThread_down_sema(PyThread_type_sema aSemaphore, int waitflag)
Guido van Rossum62332931995-04-10 11:36:14 +0000199{
Guido van Rossumcf1474b1996-10-08 14:17:53 +0000200 return -1;
Guido van Rossum62332931995-04-10 11:36:14 +0000201}
202
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000203void
204PyThread_up_sema(PyThread_type_sema aSemaphore)
Guido van Rossum62332931995-04-10 11:36:14 +0000205{
Fred Drakea44d3532000-06-30 15:01:00 +0000206 dprintf(("%ld: PyThread_up_sema(%p)\n", PyThread_get_thread_ident(), aSemaphore));
Guido van Rossum62332931995-04-10 11:36:14 +0000207}