blob: 7519cd454e7f8707dab53f1232493de156290d36 [file] [log] [blame]
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +00001
2#include <stdlib.h>
3#include <lwp/lwp.h>
4#include <lwp/stackdep.h>
5
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +00006#define STACKSIZE 1000 /* stacksize for a thread */
7#define NSTACKS 2 /* # stacks to be put in cache initially */
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +00008
9struct lock {
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000010 int lock_locked;
11 cv_t lock_condvar;
12 mon_t lock_monitor;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000013};
14
15
16/*
17 * Initialization.
18 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000019static void PyThread__init_thread(void)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000020{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000021 lwp_setstkcache(STACKSIZE, NSTACKS);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000022}
23
24/*
25 * Thread support.
26 */
27
28
Guido van Rossum3c288632001-10-16 21:13:49 +000029long PyThread_start_new_thread(void (*func)(void *), void *arg)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000030{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000031 thread_t tid;
32 int success;
33 dprintf(("PyThread_start_new_thread called\n"));
34 if (!initialized)
35 PyThread_init_thread();
36 success = lwp_create(&tid, func, MINPRIO, 0, lwp_newstk(), 1, arg);
37 return success < 0 ? -1 : 0;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000038}
39
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000040long PyThread_get_thread_ident(void)
Guido van Rossume944da81994-05-23 12:43:41 +000041{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000042 thread_t tid;
43 if (!initialized)
44 PyThread_init_thread();
45 if (lwp_self(&tid) < 0)
46 return -1;
47 return tid.thread_id;
Guido van Rossume944da81994-05-23 12:43:41 +000048}
49
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000050static void do_PyThread_exit_thread(int no_cleanup)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000051{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000052 dprintf(("PyThread_exit_thread called\n"));
53 if (!initialized)
54 if (no_cleanup)
55 _exit(0);
56 else
57 exit(0);
58 lwp_destroy(SELF);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000059}
60
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000061void PyThread_exit_thread(void)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000062{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000063 do_PyThread_exit_thread(0);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000064}
65
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000066void PyThread__exit_thread(void)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000067{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000068 do_PyThread_exit_thread(1);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000069}
70
71#ifndef NO_EXIT_PROG
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000072static void do_PyThread_exit_prog(int status, int no_cleanup)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000073{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000074 dprintf(("PyThread_exit_prog(%d) called\n", status));
75 if (!initialized)
76 if (no_cleanup)
77 _exit(status);
78 else
79 exit(status);
80 pod_exit(status);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000081}
82
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000083void PyThread_exit_prog(int status)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000084{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000085 do_PyThread_exit_prog(status, 0);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000086}
87
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000088void PyThread__exit_prog(int status)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000089{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000090 do_PyThread_exit_prog(status, 1);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000091}
92#endif /* NO_EXIT_PROG */
93
94/*
95 * Lock support.
96 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000097PyThread_type_lock PyThread_allocate_lock(void)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000098{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +000099 struct lock *lock;
100 extern char *malloc(size_t);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000101
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000102 dprintf(("PyThread_allocate_lock called\n"));
103 if (!initialized)
104 PyThread_init_thread();
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000105
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000106 lock = (struct lock *) malloc(sizeof(struct lock));
107 lock->lock_locked = 0;
108 (void) mon_create(&lock->lock_monitor);
109 (void) cv_create(&lock->lock_condvar, lock->lock_monitor);
110 dprintf(("PyThread_allocate_lock() -> %p\n", lock));
111 return (PyThread_type_lock) lock;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000112}
113
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000114void PyThread_free_lock(PyThread_type_lock lock)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000115{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000116 dprintf(("PyThread_free_lock(%p) called\n", lock));
117 mon_destroy(((struct lock *) lock)->lock_monitor);
118 free((char *) lock);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000119}
120
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000121int PyThread_acquire_lock(PyThread_type_lock lock, int waitflag)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000122{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000123 int success;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000124
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000125 dprintf(("PyThread_acquire_lock(%p, %d) called\n", lock, waitflag));
126 success = 0;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000127
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000128 (void) mon_enter(((struct lock *) lock)->lock_monitor);
129 if (waitflag)
130 while (((struct lock *) lock)->lock_locked)
131 cv_wait(((struct lock *) lock)->lock_condvar);
132 if (!((struct lock *) lock)->lock_locked) {
133 success = 1;
134 ((struct lock *) lock)->lock_locked = 1;
135 }
136 cv_broadcast(((struct lock *) lock)->lock_condvar);
137 mon_exit(((struct lock *) lock)->lock_monitor);
138 dprintf(("PyThread_acquire_lock(%p, %d) -> %d\n", lock, waitflag, success));
139 return success;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000140}
141
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000142void PyThread_release_lock(PyThread_type_lock lock)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000143{
Antoine Pitrou7f14f0d2010-05-09 16:14:21 +0000144 dprintf(("PyThread_release_lock(%p) called\n", lock));
145 (void) mon_enter(((struct lock *) lock)->lock_monitor);
146 ((struct lock *) lock)->lock_locked = 0;
147 cv_broadcast(((struct lock *) lock)->lock_condvar);
148 mon_exit(((struct lock *) lock)->lock_monitor);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000149}