blob: 5d7324288089affa66d65f9a9c52d0ec85ad56ef [file] [log] [blame]
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +00001/***********************************************************
Guido van Rossumfd71b9e2000-06-30 23:50:40 +00002Copyright (c) 2000, BeOpen.com.
3Copyright (c) 1995-2000, Corporation for National Research Initiatives.
4Copyright (c) 1990-1995, Stichting Mathematisch Centrum.
5All rights reserved.
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +00006
Guido van Rossumfd71b9e2000-06-30 23:50:40 +00007See the file "Misc/COPYRIGHT" for information on usage and
8redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +00009******************************************************************/
10
11#include <stdlib.h>
12#include <lwp/lwp.h>
13#include <lwp/stackdep.h>
14
15#define STACKSIZE 1000 /* stacksize for a thread */
Thomas Wouters7e474022000-07-16 12:04:32 +000016#define NSTACKS 2 /* # stacks to be put in cache initially */
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000017
18struct lock {
19 int lock_locked;
20 cv_t lock_condvar;
21 mon_t lock_monitor;
22};
23
24
25/*
26 * Initialization.
27 */
Guido van Rossum65d5b571998-12-21 19:32:43 +000028static void PyThread__init_thread _P0()
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000029{
30 lwp_setstkcache(STACKSIZE, NSTACKS);
31}
32
33/*
34 * Thread support.
35 */
36
37
Guido van Rossum65d5b571998-12-21 19:32:43 +000038int PyThread_start_new_thread _P2(func, void (*func) _P((void *)), arg, void *arg)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000039{
40 thread_t tid;
Guido van Rossume944da81994-05-23 12:43:41 +000041 int success;
Guido van Rossum65d5b571998-12-21 19:32:43 +000042 dprintf(("PyThread_start_new_thread called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000043 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +000044 PyThread_init_thread();
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000045 success = lwp_create(&tid, func, MINPRIO, 0, lwp_newstk(), 1, arg);
46 return success < 0 ? 0 : 1;
47}
48
Guido van Rossum65d5b571998-12-21 19:32:43 +000049long PyThread_get_thread_ident _P0()
Guido van Rossume944da81994-05-23 12:43:41 +000050{
51 thread_t tid;
52 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +000053 PyThread_init_thread();
Guido van Rossume944da81994-05-23 12:43:41 +000054 if (lwp_self(&tid) < 0)
55 return -1;
56 return tid.thread_id;
57}
58
Guido van Rossum65d5b571998-12-21 19:32:43 +000059static void do_PyThread_exit_thread _P1(no_cleanup, int no_cleanup)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000060{
Guido van Rossum65d5b571998-12-21 19:32:43 +000061 dprintf(("PyThread_exit_thread called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000062 if (!initialized)
63 if (no_cleanup)
64 _exit(0);
65 else
66 exit(0);
67 lwp_destroy(SELF);
68}
69
Guido van Rossum65d5b571998-12-21 19:32:43 +000070void PyThread_exit_thread _P0()
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000071{
Guido van Rossum65d5b571998-12-21 19:32:43 +000072 do_PyThread_exit_thread(0);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000073}
74
Guido van Rossum65d5b571998-12-21 19:32:43 +000075void PyThread__exit_thread _P0()
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000076{
Guido van Rossum65d5b571998-12-21 19:32:43 +000077 do_PyThread_exit_thread(1);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000078}
79
80#ifndef NO_EXIT_PROG
Guido van Rossum65d5b571998-12-21 19:32:43 +000081static void do_PyThread_exit_prog _P2(status, int status, no_cleanup, int no_cleanup)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000082{
Guido van Rossum65d5b571998-12-21 19:32:43 +000083 dprintf(("PyThread_exit_prog(%d) called\n", status));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000084 if (!initialized)
85 if (no_cleanup)
86 _exit(status);
87 else
88 exit(status);
89 pod_exit(status);
90}
91
Guido van Rossum65d5b571998-12-21 19:32:43 +000092void PyThread_exit_prog _P1(status, int status)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000093{
Guido van Rossum65d5b571998-12-21 19:32:43 +000094 do_PyThread_exit_prog(status, 0);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000095}
96
Guido van Rossum65d5b571998-12-21 19:32:43 +000097void PyThread__exit_prog _P1(status, int status)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000098{
Guido van Rossum65d5b571998-12-21 19:32:43 +000099 do_PyThread_exit_prog(status, 1);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000100}
101#endif /* NO_EXIT_PROG */
102
103/*
104 * Lock support.
105 */
Guido van Rossum65d5b571998-12-21 19:32:43 +0000106PyThread_type_lock PyThread_allocate_lock _P0()
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000107{
108 struct lock *lock;
109 extern char *malloc();
110
Guido van Rossum65d5b571998-12-21 19:32:43 +0000111 dprintf(("PyThread_allocate_lock called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000112 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +0000113 PyThread_init_thread();
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000114
115 lock = (struct lock *) malloc(sizeof(struct lock));
116 lock->lock_locked = 0;
117 (void) mon_create(&lock->lock_monitor);
118 (void) cv_create(&lock->lock_condvar, lock->lock_monitor);
Fred Drakea44d3532000-06-30 15:01:00 +0000119 dprintf(("PyThread_allocate_lock() -> %p\n", lock));
Guido van Rossum65d5b571998-12-21 19:32:43 +0000120 return (PyThread_type_lock) lock;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000121}
122
Guido van Rossum65d5b571998-12-21 19:32:43 +0000123void PyThread_free_lock _P1(lock, PyThread_type_lock lock)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000124{
Fred Drakea44d3532000-06-30 15:01:00 +0000125 dprintf(("PyThread_free_lock(%p) called\n", lock));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000126 mon_destroy(((struct lock *) lock)->lock_monitor);
127 free((char *) lock);
128}
129
Guido van Rossum65d5b571998-12-21 19:32:43 +0000130int PyThread_acquire_lock _P2(lock, PyThread_type_lock lock, waitflag, int waitflag)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000131{
132 int success;
133
Fred Drakea44d3532000-06-30 15:01:00 +0000134 dprintf(("PyThread_acquire_lock(%p, %d) called\n", lock, waitflag));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000135 success = 0;
136
137 (void) mon_enter(((struct lock *) lock)->lock_monitor);
138 if (waitflag)
139 while (((struct lock *) lock)->lock_locked)
140 cv_wait(((struct lock *) lock)->lock_condvar);
141 if (!((struct lock *) lock)->lock_locked) {
142 success = 1;
143 ((struct lock *) lock)->lock_locked = 1;
144 }
145 cv_broadcast(((struct lock *) lock)->lock_condvar);
146 mon_exit(((struct lock *) lock)->lock_monitor);
Fred Drakea44d3532000-06-30 15:01:00 +0000147 dprintf(("PyThread_acquire_lock(%p, %d) -> %d\n", lock, waitflag, success));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000148 return success;
149}
150
Guido van Rossum65d5b571998-12-21 19:32:43 +0000151void PyThread_release_lock _P1(lock, PyThread_type_lock lock)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000152{
Fred Drakea44d3532000-06-30 15:01:00 +0000153 dprintf(("PyThread_release_lock(%p) called\n", lock));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000154 (void) mon_enter(((struct lock *) lock)->lock_monitor);
155 ((struct lock *) lock)->lock_locked = 0;
156 cv_broadcast(((struct lock *) lock)->lock_condvar);
157 mon_exit(((struct lock *) lock)->lock_monitor);
158}
159
160/*
161 * Semaphore support.
162 */
Guido van Rossum65d5b571998-12-21 19:32:43 +0000163PyThread_type_sema PyThread_allocate_sema _P1(value, int value)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000164{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000165 PyThread_type_sema sema = 0;
166 dprintf(("PyThread_allocate_sema called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000167 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +0000168 PyThread_init_thread();
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000169
Fred Drakea44d3532000-06-30 15:01:00 +0000170 dprintf(("PyThread_allocate_sema() -> %p\n", sema));
Guido van Rossum65d5b571998-12-21 19:32:43 +0000171 return (PyThread_type_sema) sema;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000172}
173
Guido van Rossum65d5b571998-12-21 19:32:43 +0000174void PyThread_free_sema _P1(sema, PyThread_type_sema sema)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000175{
Fred Drakea44d3532000-06-30 15:01:00 +0000176 dprintf(("PyThread_free_sema(%p) called\n", sema));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000177}
178
Guido van Rossum65d5b571998-12-21 19:32:43 +0000179int PyThread_down_sema _P2(sema, PyThread_type_sema sema, waitflag, int waitflag)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000180{
Fred Drakea44d3532000-06-30 15:01:00 +0000181 dprintf(("PyThread_down_sema(%p, %d) called\n", sema, waitflag));
182 dprintf(("PyThread_down_sema(%p) return\n", sema));
Guido van Rossumcf1474b1996-10-08 14:17:53 +0000183 return -1;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000184}
185
Guido van Rossum65d5b571998-12-21 19:32:43 +0000186void PyThread_up_sema _P1(sema, PyThread_type_sema sema)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000187{
Fred Drakea44d3532000-06-30 15:01:00 +0000188 dprintf(("PyThread_up_sema(%p)\n", sema));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000189}