2008-03-31 19:10:00 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2001-2008, Haiku Inc. All Rights Reserved.
|
|
|
|
* Distributed under the terms of the Haiku License.
|
|
|
|
*/
|
2004-10-12 20:25:07 +04:00
|
|
|
#ifndef _PTHREAD_H_
|
|
|
|
#define _PTHREAD_H_
|
2003-04-20 22:53:11 +04:00
|
|
|
|
2008-04-21 01:20:07 +04:00
|
|
|
|
2009-03-08 16:56:15 +03:00
|
|
|
#include <sched.h>
|
2008-05-12 17:56:11 +04:00
|
|
|
#include <stdint.h>
|
2003-04-20 22:53:11 +04:00
|
|
|
#include <time.h>
|
|
|
|
|
2008-04-21 01:20:07 +04:00
|
|
|
|
2008-05-21 00:43:28 +04:00
|
|
|
typedef struct _pthread_thread *pthread_t;
|
2006-04-20 18:47:58 +04:00
|
|
|
typedef struct _pthread_attr *pthread_attr_t;
|
2008-05-13 05:50:54 +04:00
|
|
|
typedef struct _pthread_mutex pthread_mutex_t;
|
2006-04-20 18:47:58 +04:00
|
|
|
typedef struct _pthread_mutexattr *pthread_mutexattr_t;
|
2008-05-21 00:43:28 +04:00
|
|
|
typedef struct _pthread_cond pthread_cond_t;
|
2007-09-22 20:30:22 +04:00
|
|
|
typedef struct _pthread_condattr *pthread_condattr_t;
|
2006-04-20 16:58:32 +04:00
|
|
|
typedef int pthread_key_t;
|
2006-04-20 18:47:58 +04:00
|
|
|
typedef struct _pthread_once pthread_once_t;
|
2008-05-12 17:56:11 +04:00
|
|
|
typedef struct _pthread_rwlock pthread_rwlock_t;
|
2008-05-21 00:43:28 +04:00
|
|
|
typedef struct _pthread_rwlockattr *pthread_rwlockattr_t;
|
|
|
|
/*
|
2008-03-31 19:10:00 +04:00
|
|
|
typedef struct _pthread_barrier *pthread_barrier_t;
|
|
|
|
typedef struct _pthread_barrierattr *pthread_barrierattr_t;
|
2006-04-20 18:47:58 +04:00
|
|
|
typedef struct _pthread_spinlock *pthread_spinlock_t;
|
2008-05-21 00:43:28 +04:00
|
|
|
*/
|
2006-04-20 16:58:32 +04:00
|
|
|
|
2008-05-13 05:50:54 +04:00
|
|
|
struct _pthread_mutex {
|
|
|
|
uint32_t flags;
|
|
|
|
int32_t count;
|
|
|
|
int32_t sem;
|
|
|
|
int32_t owner;
|
|
|
|
int32_t owner_count;
|
|
|
|
};
|
|
|
|
|
2008-05-21 00:43:28 +04:00
|
|
|
struct _pthread_cond {
|
|
|
|
uint32_t flags;
|
|
|
|
int32_t sem;
|
|
|
|
pthread_mutex_t *mutex;
|
|
|
|
int32_t waiter_count;
|
|
|
|
int32_t event_counter;
|
|
|
|
};
|
|
|
|
|
2007-12-07 22:30:34 +03:00
|
|
|
struct _pthread_once {
|
2008-05-13 05:50:54 +04:00
|
|
|
int32_t state;
|
2006-04-20 16:58:32 +04:00
|
|
|
};
|
|
|
|
|
2008-05-12 17:56:11 +04:00
|
|
|
struct _pthread_rwlock {
|
|
|
|
uint32_t flags;
|
|
|
|
int32_t owner;
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
int32_t sem;
|
|
|
|
} shared;
|
|
|
|
struct {
|
|
|
|
int32_t lock_sem;
|
|
|
|
int32_t lock_count;
|
|
|
|
int32_t reader_count;
|
|
|
|
int32_t writer_count;
|
|
|
|
void* waiters[2];
|
|
|
|
} local;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2003-04-20 22:53:11 +04:00
|
|
|
enum pthread_mutex_type {
|
|
|
|
PTHREAD_MUTEX_DEFAULT,
|
|
|
|
PTHREAD_MUTEX_NORMAL,
|
|
|
|
PTHREAD_MUTEX_ERRORCHECK,
|
2008-05-14 16:52:34 +04:00
|
|
|
PTHREAD_MUTEX_RECURSIVE
|
2003-04-20 22:53:11 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
enum pthread_process_shared {
|
|
|
|
PTHREAD_PROCESS_PRIVATE,
|
2008-05-14 16:52:34 +04:00
|
|
|
PTHREAD_PROCESS_SHARED
|
2003-04-20 22:53:11 +04:00
|
|
|
};
|
|
|
|
|
2006-04-20 16:58:32 +04:00
|
|
|
/*
|
|
|
|
* Flags for threads and thread attributes.
|
|
|
|
*/
|
2007-09-22 20:30:22 +04:00
|
|
|
#define PTHREAD_DETACHED 0x1
|
2006-04-20 16:58:32 +04:00
|
|
|
#define PTHREAD_SCOPE_SYSTEM 0x2
|
|
|
|
#define PTHREAD_INHERIT_SCHED 0x4
|
2007-09-22 20:30:22 +04:00
|
|
|
#define PTHREAD_NOFLOAT 0x8
|
2006-04-20 16:58:32 +04:00
|
|
|
|
|
|
|
#define PTHREAD_CREATE_DETACHED PTHREAD_DETACHED
|
|
|
|
#define PTHREAD_CREATE_JOINABLE 0
|
|
|
|
#define PTHREAD_SCOPE_PROCESS 0
|
|
|
|
#define PTHREAD_EXPLICIT_SCHED 0
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Flags for cancelling threads
|
|
|
|
*/
|
|
|
|
#define PTHREAD_CANCEL_ENABLE 0
|
|
|
|
#define PTHREAD_CANCEL_DISABLE 1
|
|
|
|
#define PTHREAD_CANCEL_DEFERRED 0
|
|
|
|
#define PTHREAD_CANCEL_ASYNCHRONOUS 2
|
2008-03-31 19:10:00 +04:00
|
|
|
#define PTHREAD_CANCELED ((void *) 1)
|
2006-04-20 16:58:32 +04:00
|
|
|
|
2008-05-13 05:50:54 +04:00
|
|
|
#define PTHREAD_ONCE_INIT { -1 }
|
2006-04-20 16:58:32 +04:00
|
|
|
|
2008-03-31 19:10:00 +04:00
|
|
|
#define PTHREAD_BARRIER_SERIAL_THREAD -1
|
2007-09-22 20:30:22 +04:00
|
|
|
#define PTHREAD_PRIO_NONE 0
|
2006-04-20 16:58:32 +04:00
|
|
|
#define PTHREAD_PRIO_INHERIT 1
|
|
|
|
#define PTHREAD_PRIO_PROTECT 2
|
2003-04-20 22:53:11 +04:00
|
|
|
|
2008-03-31 19:10:00 +04:00
|
|
|
/* private structure */
|
|
|
|
struct __pthread_cleanup_handler {
|
|
|
|
struct __pthread_cleanup_handler *previous;
|
|
|
|
void (*function)(void *argument);
|
|
|
|
void *argument;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define pthread_cleanup_push(func, arg) \
|
|
|
|
do { \
|
|
|
|
struct __pthread_cleanup_handler __handler; \
|
|
|
|
__handler.function = (func); \
|
|
|
|
__handler.argument = (arg); \
|
|
|
|
__pthread_cleanup_push_handler(&__handler);
|
|
|
|
|
|
|
|
#define pthread_cleanup_pop(execute) \
|
|
|
|
if (execute) \
|
|
|
|
__handler.function(__handler.argument); \
|
|
|
|
__pthread_cleanup_pop_handler(); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
|
2004-10-12 20:25:07 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2008-05-13 05:50:54 +04:00
|
|
|
#define PTHREAD_MUTEX_INITIALIZER \
|
|
|
|
{ PTHREAD_MUTEX_DEFAULT, 0, -42, -1, 0 }
|
2003-04-20 22:53:11 +04:00
|
|
|
#define PTHREAD_RECURSIVE_MUTEX_INITIALIZER \
|
2008-05-13 05:50:54 +04:00
|
|
|
{ PTHREAD_MUTEX_RECURSIVE, 0, -42, -1, 0 }
|
2008-05-21 00:43:28 +04:00
|
|
|
#define PTHREAD_COND_INITIALIZER \
|
|
|
|
{ 0, -42, NULL, 0, 0 }
|
2007-09-22 20:30:22 +04:00
|
|
|
|
2003-04-20 22:53:11 +04:00
|
|
|
/* mutex functions */
|
|
|
|
extern int pthread_mutex_destroy(pthread_mutex_t *mutex);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_mutex_getprioceiling(pthread_mutex_t *mutex,
|
|
|
|
int *_priorityCeiling);
|
|
|
|
extern int pthread_mutex_init(pthread_mutex_t *mutex,
|
|
|
|
const pthread_mutexattr_t *attr);
|
2003-04-20 22:53:11 +04:00
|
|
|
extern int pthread_mutex_lock(pthread_mutex_t *mutex);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_mutex_setprioceiling(pthread_mutex_t *mutex,
|
|
|
|
int newPriorityCeiling, int *_oldPriorityCeiling);
|
|
|
|
extern int pthread_mutex_timedlock(pthread_mutex_t *mutex,
|
|
|
|
const struct timespec *spec);
|
2003-04-20 22:53:11 +04:00
|
|
|
extern int pthread_mutex_trylock(pthread_mutex_t *mutex);
|
|
|
|
extern int pthread_mutex_unlock(pthread_mutex_t *mutex);
|
|
|
|
|
|
|
|
/* mutex attribute functions */
|
|
|
|
extern int pthread_mutexattr_destroy(pthread_mutexattr_t *mutexAttr);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_mutexattr_getprioceiling(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int *_priorityCeiling);
|
|
|
|
extern int pthread_mutexattr_getprotocol(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int *_protocol);
|
|
|
|
extern int pthread_mutexattr_getpshared(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int *_processShared);
|
|
|
|
extern int pthread_mutexattr_gettype(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int *_type);
|
2003-04-20 22:53:11 +04:00
|
|
|
extern int pthread_mutexattr_init(pthread_mutexattr_t *mutexAttr);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_mutexattr_setprioceiling(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int priorityCeiling);
|
|
|
|
extern int pthread_mutexattr_setprotocol(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int protocol);
|
|
|
|
extern int pthread_mutexattr_setpshared(pthread_mutexattr_t *mutexAttr,
|
|
|
|
int processShared);
|
2003-04-20 22:53:11 +04:00
|
|
|
extern int pthread_mutexattr_settype(pthread_mutexattr_t *mutexAttr, int type);
|
|
|
|
|
2007-09-22 20:30:22 +04:00
|
|
|
/* condition variable functions */
|
|
|
|
extern int pthread_cond_destroy(pthread_cond_t *cond);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_cond_init(pthread_cond_t *cond,
|
|
|
|
const pthread_condattr_t *attr);
|
2007-09-22 20:30:22 +04:00
|
|
|
extern int pthread_cond_broadcast(pthread_cond_t *cond);
|
|
|
|
extern int pthread_cond_signal(pthread_cond_t *cond);
|
|
|
|
extern int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex,
|
|
|
|
const struct timespec *abstime);
|
|
|
|
extern int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex);
|
|
|
|
|
|
|
|
/* condition variable attribute functions */
|
|
|
|
extern int pthread_condattr_destroy(pthread_condattr_t *condAttr);
|
|
|
|
extern int pthread_condattr_init(pthread_condattr_t *condAttr);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_condattr_getpshared(const pthread_condattr_t *condAttr,
|
|
|
|
int *processShared);
|
|
|
|
extern int pthread_condattr_setpshared(pthread_condattr_t *condAttr,
|
|
|
|
int processShared);
|
2007-09-22 20:30:22 +04:00
|
|
|
|
2008-05-12 17:56:11 +04:00
|
|
|
/* rwlock functions */
|
|
|
|
extern int pthread_rwlock_init(pthread_rwlock_t *lock,
|
|
|
|
const pthread_rwlockattr_t *attr);
|
|
|
|
extern int pthread_rwlock_destroy(pthread_rwlock_t *lock);
|
|
|
|
extern int pthread_rwlock_rdlock(pthread_rwlock_t *lock);
|
|
|
|
extern int pthread_rwlock_tryrdlock(pthread_rwlock_t *lock);
|
|
|
|
extern int pthread_rwlock_timedrdlock(pthread_rwlock_t *lock,
|
|
|
|
const struct timespec *timeout);
|
|
|
|
extern int pthread_rwlock_wrlock(pthread_rwlock_t *lock);
|
|
|
|
extern int pthread_rwlock_trywrlock(pthread_rwlock_t *lock);
|
|
|
|
extern int pthread_rwlock_timedwrlock(pthread_rwlock_t *lock,
|
|
|
|
const struct timespec *timeout);
|
|
|
|
extern int pthread_rwlock_unlock(pthread_rwlock_t *lock);
|
|
|
|
|
|
|
|
/* rwlock attribute functions */
|
|
|
|
extern int pthread_rwlockattr_init(pthread_rwlockattr_t *attr);
|
|
|
|
extern int pthread_rwlockattr_destroy(pthread_rwlockattr_t *attr);
|
|
|
|
extern int pthread_rwlockattr_getpshared(const pthread_rwlockattr_t *attr,
|
|
|
|
int *shared);
|
|
|
|
extern int pthread_rwlockattr_setpshared(pthread_rwlockattr_t *attr,
|
|
|
|
int shared);
|
|
|
|
|
2004-10-12 20:25:07 +04:00
|
|
|
/* misc. functions */
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_atfork(void (*prepare)(void), void (*parent)(void),
|
|
|
|
void (*child)(void));
|
2008-05-13 05:50:54 +04:00
|
|
|
extern int pthread_once(pthread_once_t *once_control,
|
|
|
|
void (*init_routine)(void));
|
2004-10-12 20:25:07 +04:00
|
|
|
|
2006-04-20 16:58:32 +04:00
|
|
|
/* thread attributes functions */
|
|
|
|
extern int pthread_attr_destroy(pthread_attr_t *attr);
|
|
|
|
extern int pthread_attr_init(pthread_attr_t *attr);
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_attr_getdetachstate(const pthread_attr_t *attr,
|
|
|
|
int *detachstate);
|
2006-04-20 16:58:32 +04:00
|
|
|
extern int pthread_attr_setdetachstate(pthread_attr_t *attr, int detachstate);
|
2008-05-09 05:36:49 +04:00
|
|
|
extern int pthread_attr_getstacksize(const pthread_attr_t *attr,
|
|
|
|
size_t *stacksize);
|
|
|
|
extern int pthread_attr_setstacksize(pthread_attr_t *attr, size_t stacksize);
|
2008-05-23 15:24:40 +04:00
|
|
|
extern int pthread_attr_getscope(const pthread_attr_t *attr,
|
|
|
|
int *contentionScope);
|
|
|
|
extern int pthread_attr_setscope(pthread_attr_t *attr, int contentionScope);
|
2008-05-09 05:36:49 +04:00
|
|
|
|
|
|
|
#if 0 /* Unimplemented attribute functions: */
|
|
|
|
|
2008-05-11 01:30:34 +04:00
|
|
|
/* mandatory! */
|
2008-05-09 05:36:49 +04:00
|
|
|
extern int pthread_attr_getschedparam(const pthread_attr_t *attr,
|
|
|
|
struct sched_param *param);
|
|
|
|
extern int pthread_attr_setschedparam(pthread_attr_t *attr,
|
|
|
|
const struct sched_param *param);
|
|
|
|
|
2008-05-11 01:30:34 +04:00
|
|
|
/* [TPS] */
|
2008-05-09 05:36:49 +04:00
|
|
|
extern int pthread_attr_getinheritsched(const pthread_attr_t *attr,
|
|
|
|
int *inheritsched);
|
|
|
|
extern int pthread_attr_setinheritsched(pthread_attr_t *attr, int inheritsched);
|
|
|
|
|
|
|
|
extern int pthread_attr_getschedpolicy(const pthread_attr_t *attr,
|
|
|
|
int *policy);
|
|
|
|
extern int pthread_attr_setschedpolicy(pthread_attr_t *attr, int policy);
|
|
|
|
|
2008-05-11 01:30:34 +04:00
|
|
|
/* [XSI] */
|
2008-05-09 05:36:49 +04:00
|
|
|
extern int pthread_attr_getguardsize(const pthread_attr_t *attr,
|
|
|
|
size_t *guardsize);
|
|
|
|
extern int pthread_attr_setguardsize(pthread_attr_t *attr, size_t guardsize);
|
|
|
|
|
2008-05-11 01:30:34 +04:00
|
|
|
/* [TSA] */
|
2008-05-09 05:36:49 +04:00
|
|
|
extern int pthread_attr_getstackaddr(const pthread_attr_t *attr,
|
|
|
|
void **stackaddr);
|
|
|
|
extern int pthread_attr_setstackaddr(pthread_attr_t *attr, void *stackaddr);
|
|
|
|
|
2008-05-11 01:30:34 +04:00
|
|
|
/* [TSA TSS] */
|
2008-05-09 05:36:49 +04:00
|
|
|
extern int pthread_attr_getstack(const pthread_attr_t *attr,
|
|
|
|
void **stackaddr, size_t *stacksize);
|
|
|
|
extern int pthread_attr_setstack(pthread_attr_t *attr, void *stackaddr, size_t stacksize);
|
|
|
|
|
|
|
|
#endif /* 0 */
|
|
|
|
|
2006-04-20 16:58:32 +04:00
|
|
|
|
2008-03-31 22:49:19 +04:00
|
|
|
/* thread functions */
|
2008-03-31 19:10:00 +04:00
|
|
|
extern int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
|
2006-04-20 16:58:32 +04:00
|
|
|
void *(*start_routine)(void*), void *arg);
|
|
|
|
extern int pthread_detach(pthread_t thread);
|
|
|
|
extern int pthread_equal(pthread_t t1, pthread_t t2);
|
|
|
|
extern void pthread_exit(void *value_ptr);
|
2008-03-31 22:49:19 +04:00
|
|
|
extern int pthread_join(pthread_t thread, void **_value);
|
2006-04-20 16:58:32 +04:00
|
|
|
extern pthread_t pthread_self(void);
|
2006-04-21 13:47:43 +04:00
|
|
|
extern int pthread_kill(pthread_t thread, int sig);
|
2008-04-07 14:57:01 +04:00
|
|
|
extern int pthread_getconcurrency(void);
|
|
|
|
extern int pthread_setconcurrency(int newLevel);
|
2006-04-21 13:47:43 +04:00
|
|
|
|
2008-03-31 22:49:19 +04:00
|
|
|
extern int pthread_cancel(pthread_t thread);
|
|
|
|
extern int pthread_setcancelstate(int state, int *_oldState);
|
|
|
|
extern int pthread_setcanceltype(int type, int *_oldType);
|
|
|
|
extern void pthread_testcancel(void);
|
|
|
|
|
2006-06-20 16:27:46 +04:00
|
|
|
/* thread specific data functions */
|
2008-04-21 01:20:07 +04:00
|
|
|
extern int pthread_key_create(pthread_key_t *key,
|
|
|
|
void (*destructorFunc)(void*));
|
2006-06-20 16:27:46 +04:00
|
|
|
extern int pthread_key_delete(pthread_key_t key);
|
|
|
|
extern void *pthread_getspecific(pthread_key_t key);
|
|
|
|
extern int pthread_setspecific(pthread_key_t key, const void *value);
|
|
|
|
|
2008-03-31 19:10:00 +04:00
|
|
|
/* private functions */
|
|
|
|
extern void __pthread_cleanup_push_handler(
|
|
|
|
struct __pthread_cleanup_handler *handler);
|
|
|
|
extern struct __pthread_cleanup_handler *__pthread_cleanup_pop_handler(void);
|
|
|
|
|
2004-10-12 20:25:07 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2003-04-20 22:53:11 +04:00
|
|
|
#endif /* _PTHREAD_ */
|