blob: 93d82955561588dd73d6b2c07724a3318324f3a5 [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
6#define STACKSIZE 1000 /* stacksize for a thread */
Thomas Wouters7e474022000-07-16 12:04:32 +00007#define NSTACKS 2 /* # stacks to be put in cache initially */
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +00008
9struct lock {
10 int lock_locked;
11 cv_t lock_condvar;
12 mon_t lock_monitor;
13};
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{
21 lwp_setstkcache(STACKSIZE, NSTACKS);
22}
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{
31 thread_t tid;
Guido van Rossume944da81994-05-23 12:43:41 +000032 int success;
Guido van Rossum65d5b571998-12-21 19:32:43 +000033 dprintf(("PyThread_start_new_thread called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000034 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +000035 PyThread_init_thread();
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000036 success = lwp_create(&tid, func, MINPRIO, 0, lwp_newstk(), 1, arg);
Guido van Rossum3c288632001-10-16 21:13:49 +000037 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{
42 thread_t tid;
43 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +000044 PyThread_init_thread();
Guido van Rossume944da81994-05-23 12:43:41 +000045 if (lwp_self(&tid) < 0)
46 return -1;
47 return tid.thread_id;
48}
49
Amaury Forgeot d'Arc72aee3d2010-02-24 00:10:48 +000050void PyThread_exit_thread(void)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000051{
Guido van Rossum65d5b571998-12-21 19:32:43 +000052 dprintf(("PyThread_exit_thread called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000053 if (!initialized)
Amaury Forgeot d'Arc72aee3d2010-02-24 00:10:48 +000054 exit(0);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000055 lwp_destroy(SELF);
56}
57
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000058/*
59 * Lock support.
60 */
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000061PyThread_type_lock PyThread_allocate_lock(void)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000062{
63 struct lock *lock;
Thomas Woutersb4bd21c2000-07-22 23:38:01 +000064 extern char *malloc(size_t);
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000065
Guido van Rossum65d5b571998-12-21 19:32:43 +000066 dprintf(("PyThread_allocate_lock called\n"));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000067 if (!initialized)
Guido van Rossum65d5b571998-12-21 19:32:43 +000068 PyThread_init_thread();
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000069
70 lock = (struct lock *) malloc(sizeof(struct lock));
71 lock->lock_locked = 0;
72 (void) mon_create(&lock->lock_monitor);
73 (void) cv_create(&lock->lock_condvar, lock->lock_monitor);
Fred Drakea44d3532000-06-30 15:01:00 +000074 dprintf(("PyThread_allocate_lock() -> %p\n", lock));
Guido van Rossum65d5b571998-12-21 19:32:43 +000075 return (PyThread_type_lock) lock;
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000076}
77
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000078void PyThread_free_lock(PyThread_type_lock lock)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000079{
Fred Drakea44d3532000-06-30 15:01:00 +000080 dprintf(("PyThread_free_lock(%p) called\n", lock));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000081 mon_destroy(((struct lock *) lock)->lock_monitor);
82 free((char *) lock);
83}
84
Thomas Woutersf70ef4f2000-07-22 18:47:25 +000085int PyThread_acquire_lock(PyThread_type_lock lock, int waitflag)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000086{
87 int success;
88
Fred Drakea44d3532000-06-30 15:01:00 +000089 dprintf(("PyThread_acquire_lock(%p, %d) called\n", lock, waitflag));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +000090 success = 0;
91
92 (void) mon_enter(((struct lock *) lock)->lock_monitor);
93 if (waitflag)
94 while (((struct lock *) lock)->lock_locked)
95 cv_wait(((struct lock *) lock)->lock_condvar);
96 if (!((struct lock *) lock)->lock_locked) {
97 success = 1;
98 ((struct lock *) lock)->lock_locked = 1;
99 }
100 cv_broadcast(((struct lock *) lock)->lock_condvar);
101 mon_exit(((struct lock *) lock)->lock_monitor);
Fred Drakea44d3532000-06-30 15:01:00 +0000102 dprintf(("PyThread_acquire_lock(%p, %d) -> %d\n", lock, waitflag, success));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000103 return success;
104}
105
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000106void PyThread_release_lock(PyThread_type_lock lock)
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000107{
Fred Drakea44d3532000-06-30 15:01:00 +0000108 dprintf(("PyThread_release_lock(%p) called\n", lock));
Guido van Rossum2c8cb9f1994-05-09 15:12:46 +0000109 (void) mon_enter(((struct lock *) lock)->lock_monitor);
110 ((struct lock *) lock)->lock_locked = 0;
111 cv_broadcast(((struct lock *) lock)->lock_condvar);
112 mon_exit(((struct lock *) lock)->lock_monitor);
113}