nginx-quic/src/os/unix/ngx_thread.h

119 lines
2.3 KiB
C
Raw Normal View History

2004-02-23 17:57:12 -03:00
#ifndef _NGX_THREAD_H_INCLUDED_
#define _NGX_THREAD_H_INCLUDED_
#include <ngx_config.h>
#include <ngx_core.h>
#if (NGX_THREADS)
2004-03-02 12:40:59 -03:00
#define ngx_thread_volatile volatile
2004-02-25 17:16:15 -03:00
#if (NGX_USE_RFORK)
2004-02-23 17:57:12 -03:00
#include <sys/ipc.h>
#include <sys/sem.h>
#include <sched.h>
typedef pid_t ngx_tid_t;
#undef ngx_log_pid
#define ngx_log_pid ngx_thread_self()
2004-02-29 18:03:02 -03:00
#define ngx_log_tid 0
#define TID_T_FMT PID_T_FMT
2004-02-23 17:57:12 -03:00
#define NGX_MUTEX_LIGHT 1
#define NGX_MUTEX_CV 2
#define NGX_MUTEX_LOCK_BUSY 0x80000000
2004-02-24 14:31:46 -03:00
typedef volatile struct {
2004-02-23 17:57:12 -03:00
ngx_atomic_t lock;
ngx_log_t *log;
int semid;
} ngx_mutex_t;
2004-03-04 13:34:23 -03:00
#define ngx_thread_sigmask(how, set, oset) \
(sigprocmask(how, set, oset) == -1) ? ngx_errno : 0
#define ngx_thread_sigmask_n "sigprocmask()"
2004-02-29 18:03:02 -03:00
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;
}
2004-02-23 17:57:12 -03:00
#else /* use pthreads */
#include <pthread.h>
typedef pthread_t ngx_tid_t;
2004-02-29 18:03:02 -03:00
#define ngx_gettid() ((ngx_int_t) pthread_getspecific(0))
2004-02-23 17:57:12 -03:00
#define ngx_log_tid ngx_thread_self()
2004-03-04 13:34:23 -03:00
#define ngx_thread_sigmask pthread_sigmask
#define ngx_thread_sigmask_n "pthread_sigmask()"
2004-02-23 17:57:12 -03:00
#endif
2004-02-25 17:16:15 -03:00
ngx_int_t ngx_init_threads(int n, size_t size, ngx_cycle_t *cycle);
2004-02-23 17:57:12 -03:00
int ngx_create_thread(ngx_tid_t *tid, int (*func)(void *arg), void *arg,
ngx_log_t *log);
ngx_tid_t ngx_thread_self();
2004-02-29 18:03:02 -03:00
2004-02-23 17:57:12 -03:00
ngx_mutex_t *ngx_mutex_init(ngx_log_t *log, uint flags);
void ngx_mutex_done(ngx_mutex_t *m);
2004-02-29 18:03:02 -03:00
#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);
2004-02-23 17:57:12 -03:00
ngx_int_t ngx_mutex_unlock(ngx_mutex_t *m);
#else /* !NGX_THREADS */
2004-03-02 12:40:59 -03:00
#define ngx_thread_volatile
2004-02-23 17:57:12 -03:00
#define ngx_log_tid 0
#define TID_T_FMT "%d"
2004-03-03 13:14:15 -03:00
#define ngx_mutex_lock(m) NGX_OK
2004-02-23 17:57:12 -03:00
#define ngx_mutex_unlock(m)
#endif
#endif /* _NGX_THREAD_H_INCLUDED_ */