ref: 3b7e03a30ed29ee0666c00568bf67b8179c28d12
dir: /sys/src/cmd/python/Python/thread_plan9.h/
#define _PLAN9_SOURCE #include <u.h> #include <lib9.h> #include <qlock.h> /* * Initialization. */ static void PyThread__init_thread(void) { } /* * Thread support. */ long PyThread_start_new_thread(void (*func)(void *), void *arg) { dprintf(("PyThread_start_new_thread called\n")); if (!initialized) PyThread_init_thread(); switch(rfork(RFPROC|RFMEM)){ case -1: printf("rfork: %r\n"); return -1; case 0: _threadarg->fn = func; _threadarg->arg = arg; longjmp(_threadarg->jb, 1); default: return 0; } } long PyThread_get_thread_ident(void) { if (!initialized) PyThread_init_thread(); return getpid(); } void PyThread_exit_thread(void) { if(initialized) _exit(0); exit(0); } void PyThread__exit_thread(void) { _exit(0); } #ifndef NO_EXIT_PROG static void do_PyThread_exit_prog(int status, int no_cleanup) { /* * BUG BUG BUG */ dprintf(("PyThread_exit_prog(%d) called\n", status)); if (!initialized) if (no_cleanup) _exit(status); else exit(status); } void PyThread_exit_prog(int status) { do_PyThread_exit_prog(status, 0); } void PyThread__exit_prog(int status) { do_PyThread_exit_prog(status, 1); } #endif /* NO_EXIT_PROG */ /* * Lock support. */ PyThread_type_lock PyThread_allocate_lock(void) { QLock *lk; dprintf(("PyThread_allocate_lock called\n")); if (!initialized) PyThread_init_thread(); lk = malloc(sizeof(*lk)); memset(lk, 0, sizeof(*lk)); dprintf(("PyThread_allocate_lock() -> %p\n", lk)); return lk; } void PyThread_free_lock(PyThread_type_lock lock) { dprintf(("PyThread_free_lock(%p) called\n", lock)); free(lock); } int PyThread_acquire_lock(PyThread_type_lock lock, int waitflag) { int success; dprintf(("PyThread_acquire_lock(%p, %d) called\n", lock, waitflag)); if(lock == nil) success = 0; else if(waitflag){ qlock(lock); success = 1; }else success = canqlock(lock); dprintf(("PyThread_acquire_lock(%p, %d) -> %d\n", lock, waitflag, success)); return success; } void PyThread_release_lock(PyThread_type_lock lock) { dprintf(("PyThread_release_lock(%p) called\n", lock)); qunlock(lock); }