#ifndef _NGX_THREAD_H_INCLUDED_ #define _NGX_THREAD_H_INCLUDED_ #include #include #if (NGX_THREADS) #define ngx_thread_volatile volatile #if (NGX_USE_RFORK) #include #include #include typedef pid_t ngx_tid_t; #undef ngx_log_pid #define ngx_log_pid ngx_thread_self() #define ngx_log_tid 0 #define TID_T_FMT PID_T_FMT #define NGX_MUTEX_LIGHT 1 #define NGX_MUTEX_CV 2 #define NGX_MUTEX_LOCK_BUSY 0x80000000 typedef volatile struct { ngx_atomic_t lock; ngx_log_t *log; int semid; } ngx_mutex_t; #define ngx_thread_sigmask(how, set, oset) \ (sigprocmask(how, set, oset) == -1) ? ngx_errno : 0 #define ngx_thread_sigmask_n "sigprocmask()" extern char *ngx_freebsd_kern_usrstack; extern size_t ngx_thread_stack_size; static inline int ngx_gettid() { char *sp; if (ngx_thread_stack_size == 0) { return 0; } #if ( __i386__ ) __asm__ volatile ("mov %%esp, %0" : "=q" (sp)); #elif ( __amd64__ ) __asm__ volatile ("mov %%rsp, %0" : "=q" (sp)); #else #error "rfork()ed threads are not supported on this platform" #endif return (ngx_freebsd_kern_usrstack - sp) / ngx_thread_stack_size; } #else /* use pthreads */ #include typedef pthread_t ngx_tid_t; #define ngx_gettid() ((ngx_int_t) pthread_getspecific(0)) #define ngx_log_tid ngx_thread_self() #define ngx_thread_sigmask pthread_sigmask #define ngx_thread_sigmask_n "pthread_sigmask()" #endif ngx_int_t ngx_init_threads(int n, size_t size, ngx_cycle_t *cycle); int ngx_create_thread(ngx_tid_t *tid, int (*func)(void *arg), void *arg, ngx_log_t *log); ngx_tid_t ngx_thread_self(); ngx_mutex_t *ngx_mutex_init(ngx_log_t *log, uint flags); void ngx_mutex_done(ngx_mutex_t *m); #define ngx_mutex_trylock(m) ngx_mutex_dolock(m, 1) #define ngx_mutex_lock(m) ngx_mutex_dolock(m, 0) ngx_int_t ngx_mutex_dolock(ngx_mutex_t *m, ngx_int_t try); ngx_int_t ngx_mutex_unlock(ngx_mutex_t *m); #else /* !NGX_THREADS */ #define ngx_thread_volatile #define ngx_log_tid 0 #define TID_T_FMT "%d" #define ngx_mutex_lock(m) NGX_OK #define ngx_mutex_unlock(m) #endif #endif /* _NGX_THREAD_H_INCLUDED_ */