mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-15 11:20:03 +00:00
153 lines
3 KiB
C
153 lines
3 KiB
C
#include "u.h"
|
|
#include <errno.h>
|
|
#include <sys/time.h>
|
|
#include <sys/types.h>
|
|
#include <sys/wait.h>
|
|
#include <sched.h>
|
|
#include <signal.h>
|
|
#if !defined(__OpenBSD__)
|
|
# include <ucontext.h>
|
|
#endif
|
|
#include <sys/utsname.h>
|
|
#include "libc.h"
|
|
#include "thread.h"
|
|
|
|
#if defined(__FreeBSD__) && __FreeBSD__ < 5
|
|
extern int getcontext(ucontext_t*);
|
|
extern void setcontext(ucontext_t*);
|
|
extern int swapcontext(ucontext_t*, ucontext_t*);
|
|
extern void makecontext(ucontext_t*, void(*)(), int, ...);
|
|
#endif
|
|
|
|
#if defined(__APPLE__)
|
|
# define mcontext libthread_mcontext
|
|
# define mcontext_t libthread_mcontext_t
|
|
# define ucontext libthread_ucontext
|
|
# define ucontext_t libthread_ucontext_t
|
|
# include "power-ucontext.h"
|
|
#endif
|
|
|
|
#if defined(__OpenBSD__)
|
|
# define mcontext libthread_mcontext
|
|
# define mcontext_t libthread_mcontext_t
|
|
# define ucontext libthread_ucontext
|
|
# define ucontext_t libthread_ucontext_t
|
|
# if defined __i386__
|
|
# include "386-ucontext.h"
|
|
# else
|
|
# include "power-ucontext.h"
|
|
# endif
|
|
extern pid_t rfork_thread(int, void*, int(*)(void*), void*);
|
|
#endif
|
|
|
|
typedef struct Context Context;
|
|
typedef struct Execjob Execjob;
|
|
typedef struct Proc Proc;
|
|
typedef struct _Procrendez _Procrendez;
|
|
|
|
typedef struct Jmp Jmp;
|
|
struct Jmp
|
|
{
|
|
p9jmp_buf b;
|
|
};
|
|
|
|
enum
|
|
{
|
|
STACK = 8192
|
|
};
|
|
|
|
struct Context
|
|
{
|
|
ucontext_t uc;
|
|
};
|
|
|
|
struct Execjob
|
|
{
|
|
int *fd;
|
|
char *cmd;
|
|
char **argv;
|
|
Channel *c;
|
|
};
|
|
|
|
struct _Thread
|
|
{
|
|
_Thread *next;
|
|
_Thread *prev;
|
|
_Thread *allnext;
|
|
_Thread *allprev;
|
|
Context context;
|
|
uint id;
|
|
uchar *stk;
|
|
uint stksize;
|
|
int exiting;
|
|
void (*startfn)(void*);
|
|
void *startarg;
|
|
Proc *proc;
|
|
char name[256];
|
|
char state[256];
|
|
void *udata;
|
|
};
|
|
|
|
struct _Procrendez
|
|
{
|
|
Lock *l;
|
|
int asleep;
|
|
#ifdef PLAN9PORT_USING_PTHREADS
|
|
pthread_cond_t cond;
|
|
#else
|
|
int pid;
|
|
#endif
|
|
};
|
|
|
|
extern void _procsleep(_Procrendez*);
|
|
extern void _procwakeup(_Procrendez*);
|
|
extern void _procwakeupandunlock(_Procrendez*);
|
|
|
|
struct Proc
|
|
{
|
|
Proc *next;
|
|
Proc *prev;
|
|
char msg[128];
|
|
#ifdef PLAN9PORT_USING_PTHREADS
|
|
pthread_t osprocid;
|
|
#else
|
|
int osprocid;
|
|
#endif
|
|
Lock lock;
|
|
int nswitch;
|
|
_Thread *thread;
|
|
_Threadlist runqueue;
|
|
_Threadlist allthreads;
|
|
uint nthread;
|
|
uint sysproc;
|
|
_Procrendez runrend;
|
|
Context schedcontext;
|
|
void *udata;
|
|
Jmp sigjmp;
|
|
int mainproc;
|
|
};
|
|
|
|
#define proc() _threadproc()
|
|
#define setproc(p) _threadsetproc(p)
|
|
|
|
extern Proc *_threadprocs;
|
|
extern Lock _threadprocslock;
|
|
extern Proc *_threadexecproc;
|
|
extern Channel *_threadexecchan;
|
|
extern QLock _threadexeclock;
|
|
extern Channel *_dowaitchan;
|
|
|
|
extern void _procstart(Proc*, void (*fn)(Proc*));
|
|
extern _Thread *_threadcreate(Proc*, void(*fn)(void*), void*, uint);
|
|
extern void _threadexit(void);
|
|
extern Proc *_threadproc(void);
|
|
extern void _threadsetproc(Proc*);
|
|
extern int _threadlock(Lock*, int, ulong);
|
|
extern void _threadunlock(Lock*, ulong);
|
|
extern void _pthreadinit(void);
|
|
extern int _threadspawn(int*, char*, char**);
|
|
extern int _runthreadspawn(int*, char*, char**);
|
|
extern void _threadsetupdaemonize(void);
|
|
extern void _threaddodaemonize(char*);
|
|
extern void _threadpexit(void);
|
|
extern void _threaddaemonize(void);
|