2000-02-18 03:38:33 +08:00
|
|
|
/* pthread.h: POSIX pthread interface
|
|
|
|
|
2001-05-04 04:42:28 +08:00
|
|
|
Copyright 1996, 1997, 1998, 1999, 20000, 2001 Red Hat, Inc.
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
Written by Marco Fuykschot <marco@ddi.nl>
|
|
|
|
|
|
|
|
This file is part of Cygwin.
|
|
|
|
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
|
|
details. */
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <signal.h>
|
2001-04-12 12:04:53 +08:00
|
|
|
#include <sched.h>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
#ifndef _PTHREAD_H
|
|
|
|
#define _PTHREAD_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2001-03-17 09:14:58 +08:00
|
|
|
/* Defines. (These are correctly defined here as per
|
|
|
|
http://www.opengroup.org/onlinepubs/7908799/xsh/pthread.h.html */
|
|
|
|
|
|
|
|
/* FIXME: this should allocate a new cond variable, and return the value that
|
|
|
|
would normally be written to the passed parameter of pthread_cond_init(lvalue, NULL); */
|
2001-05-09 22:45:47 +08:00
|
|
|
/* #define PTHREAD_COND_INITIALIZER 0 */
|
2001-03-17 09:14:58 +08:00
|
|
|
|
2001-03-21 10:17:58 +08:00
|
|
|
#define PTHREAD_DESTRUCTOR_ITERATIONS 1
|
|
|
|
/* Tls has 64 items for pre win2000 - and we don't want to use them all :]
|
|
|
|
* Before committing discuss this with the list
|
|
|
|
*/
|
|
|
|
#define PTHREAD_KEYS_MAX 32
|
2001-04-12 12:04:53 +08:00
|
|
|
/* the default : joinable */
|
|
|
|
|
|
|
|
#define PTHREAD_CANCEL_ASYNCHRONOUS 1
|
|
|
|
/* defaults are enable, deferred */
|
|
|
|
#define PTHREAD_CANCEL_ENABLE 0
|
|
|
|
#define PTHREAD_CANCEL_DEFERRED 0
|
|
|
|
#define PTHREAD_CANCEL_DISABLE 1
|
2002-07-04 22:17:30 +08:00
|
|
|
#define PTHREAD_CANCELED ((void *)-1)
|
2001-11-15 19:10:38 +08:00
|
|
|
/* this should be a value that can never be a valid address */
|
|
|
|
#define PTHREAD_COND_INITIALIZER (void *)21
|
2001-03-21 10:17:58 +08:00
|
|
|
#define PTHREAD_CREATE_DETACHED 1
|
|
|
|
/* the default : joinable */
|
|
|
|
#define PTHREAD_CREATE_JOINABLE 0
|
2001-04-12 12:04:53 +08:00
|
|
|
#define PTHREAD_EXPLICIT_SCHED 1
|
|
|
|
#define PTHREAD_INHERIT_SCHED 0
|
|
|
|
#define PTHREAD_MUTEX_DEFAULT 0
|
|
|
|
#define PTHREAD_MUTEX_ERRORCHECK 1
|
|
|
|
#define PTHREAD_MUTEX_NORMAL 2
|
|
|
|
/* this should be too low to ever be a valid address */
|
|
|
|
#define PTHREAD_MUTEX_INITIALIZER (void *)20
|
|
|
|
#define PTHREAD_MUTEX_RECURSIVE 0
|
|
|
|
#define PTHREAD_ONCE_INIT { PTHREAD_MUTEX_INITIALIZER, 0 }
|
|
|
|
#define PTHREAD_PRIO_INHERIT
|
|
|
|
#define PTHREAD_PRIO_NONE
|
|
|
|
#define PTHREAD_PRIO_PROTECT
|
|
|
|
#define PTHREAD_PROCESS_SHARED 1
|
|
|
|
#define PTHREAD_PROCESS_PRIVATE 0
|
|
|
|
#define PTHREAD_RWLOCK_INITIALIZER
|
|
|
|
/* process is the default */
|
|
|
|
#define PTHREAD_SCOPE_PROCESS 0
|
|
|
|
#define PTHREAD_SCOPE_SYSTEM 1
|
|
|
|
|
|
|
|
|
|
|
|
/* Attributes */
|
|
|
|
int pthread_attr_destroy (pthread_attr_t *);
|
|
|
|
int pthread_attr_getdetachstate (const pthread_attr_t *, int *);
|
|
|
|
int pthread_attr_getinheritsched (const pthread_attr_t *, int *);
|
|
|
|
int pthread_attr_getschedparam (const pthread_attr_t *, struct sched_param *);
|
|
|
|
int pthread_attr_getschedpolicy (const pthread_attr_t *, int *);
|
|
|
|
int pthread_attr_getscope (const pthread_attr_t *, int *);
|
|
|
|
int pthread_attr_init (pthread_attr_t *);
|
|
|
|
int pthread_attr_setdetachstate (pthread_attr_t *, int);
|
|
|
|
int pthread_attr_setinheritsched (pthread_attr_t *, int);
|
|
|
|
int pthread_attr_setschedparam (pthread_attr_t *, const struct sched_param *);
|
|
|
|
int pthread_attr_setschedpolicy (pthread_attr_t *, int);
|
|
|
|
int pthread_attr_setscope (pthread_attr_t *, int);
|
|
|
|
|
|
|
|
#ifdef _POSIX_THREAD_ATTR_STACKADDR
|
|
|
|
/* These functions may be implementable via some low level trickery. For now they are
|
2001-11-05 14:09:15 +08:00
|
|
|
* Not supported or implemented. The prototypes are here so if someone greps the
|
2001-04-12 12:04:53 +08:00
|
|
|
* source they will see these comments
|
|
|
|
*/
|
|
|
|
int pthread_attr_getstackaddr (const pthread_attr_t *, void **);
|
|
|
|
int pthread_attr_setstackaddr (pthread_attr_t *, void *);
|
|
|
|
#endif
|
2001-03-21 10:17:58 +08:00
|
|
|
|
2001-04-12 12:04:53 +08:00
|
|
|
#ifdef _POSIX_THREAD_ATTR_STACKSIZE
|
|
|
|
int pthread_attr_getstacksize (const pthread_attr_t *, size_t *);
|
|
|
|
int pthread_attr_setstacksize (pthread_attr_t *, size_t);
|
|
|
|
#endif
|
2001-03-21 10:17:58 +08:00
|
|
|
|
2001-04-12 12:04:53 +08:00
|
|
|
int pthread_cancel (pthread_t);
|
2001-11-05 14:09:15 +08:00
|
|
|
/* Macros for cleanup_push and pop;
|
2001-04-12 12:04:53 +08:00
|
|
|
* The function definitions are
|
2001-05-04 04:42:28 +08:00
|
|
|
void pthread_cleanup_push (void (*routine)(void*), void *arg);
|
|
|
|
void pthread_cleanup_pop (int execute);
|
2001-04-12 12:04:53 +08:00
|
|
|
*/
|
2001-09-25 19:45:26 +08:00
|
|
|
typedef void (*__cleanup_routine_type) (void *);
|
2002-12-12 11:09:38 +08:00
|
|
|
typedef struct _pthread_cleanup_handler
|
2002-06-10 09:10:45 +08:00
|
|
|
{
|
|
|
|
__cleanup_routine_type function;
|
|
|
|
void *arg;
|
|
|
|
struct _pthread_cleanup_handler *next;
|
|
|
|
} __pthread_cleanup_handler;
|
|
|
|
|
|
|
|
void _pthread_cleanup_push (__pthread_cleanup_handler *handler);
|
|
|
|
void _pthread_cleanup_pop (int execute);
|
|
|
|
|
|
|
|
#define pthread_cleanup_push(_fn, _arg) { __pthread_cleanup_handler __cleanup_handler = \
|
|
|
|
{ _fn, _arg, NULL }; \
|
|
|
|
_pthread_cleanup_push( &__cleanup_handler );
|
|
|
|
#define pthread_cleanup_pop(_execute) _pthread_cleanup_pop( _execute ); }
|
2000-05-09 06:38:07 +08:00
|
|
|
|
2001-03-17 09:14:58 +08:00
|
|
|
/* Condition variables */
|
2001-04-12 12:04:53 +08:00
|
|
|
int pthread_cond_broadcast (pthread_cond_t *);
|
|
|
|
int pthread_cond_destroy (pthread_cond_t *);
|
|
|
|
int pthread_cond_init (pthread_cond_t *, const pthread_condattr_t *);
|
|
|
|
int pthread_cond_signal (pthread_cond_t *);
|
|
|
|
int pthread_cond_timedwait (pthread_cond_t *,
|
|
|
|
pthread_mutex_t *, const struct timespec *);
|
|
|
|
int pthread_cond_wait (pthread_cond_t *, pthread_mutex_t *);
|
|
|
|
int pthread_condattr_destroy (pthread_condattr_t *);
|
|
|
|
int pthread_condattr_getpshared (const pthread_condattr_t *, int *);
|
|
|
|
int pthread_condattr_init (pthread_condattr_t *);
|
|
|
|
int pthread_condattr_setpshared (pthread_condattr_t *, int);
|
|
|
|
|
|
|
|
int pthread_create (pthread_t *, const pthread_attr_t *,
|
|
|
|
void *(*)(void *), void *);
|
|
|
|
int pthread_detach (pthread_t);
|
|
|
|
int pthread_equal (pthread_t, pthread_t);
|
|
|
|
void pthread_exit (void *);
|
|
|
|
int pthread_getschedparam (pthread_t, int *, struct sched_param *);
|
|
|
|
void *pthread_getspecific (pthread_key_t);
|
|
|
|
int pthread_join (pthread_t, void **);
|
|
|
|
int pthread_key_create (pthread_key_t *, void (*)(void *));
|
|
|
|
int pthread_key_delete (pthread_key_t);
|
|
|
|
|
|
|
|
/* Mutex's */
|
|
|
|
int pthread_mutex_destroy (pthread_mutex_t *);
|
|
|
|
int pthread_mutex_getprioceiling (const pthread_mutex_t *, int *);
|
|
|
|
int pthread_mutex_init (pthread_mutex_t *, const pthread_mutexattr_t *);
|
|
|
|
int pthread_mutex_lock (pthread_mutex_t *);
|
|
|
|
int pthread_mutex_setprioceiling (pthread_mutex_t *, int, int *);
|
|
|
|
int pthread_mutex_trylock (pthread_mutex_t *);
|
|
|
|
int pthread_mutex_unlock (pthread_mutex_t *);
|
|
|
|
int pthread_mutexattr_destroy (pthread_mutexattr_t *);
|
|
|
|
int pthread_mutexattr_getprioceiling (const pthread_mutexattr_t *, int *);
|
|
|
|
int pthread_mutexattr_getprotocol (const pthread_mutexattr_t *, int *);
|
|
|
|
int pthread_mutexattr_getpshared (const pthread_mutexattr_t *, int *);
|
|
|
|
int pthread_mutexattr_gettype (const pthread_mutexattr_t *, int *);
|
|
|
|
int pthread_mutexattr_init (pthread_mutexattr_t *);
|
|
|
|
int pthread_mutexattr_setprioceiling (pthread_mutexattr_t *, int);
|
|
|
|
int pthread_mutexattr_setprotocol (pthread_mutexattr_t *, int);
|
|
|
|
int pthread_mutexattr_setpshared (pthread_mutexattr_t *, int);
|
|
|
|
int pthread_mutexattr_settype (pthread_mutexattr_t *, int);
|
|
|
|
|
|
|
|
int pthread_once (pthread_once_t *, void (*)(void));
|
|
|
|
|
|
|
|
/* Concurrency levels - X/Open interface */
|
|
|
|
int pthread_getconcurrency (void);
|
|
|
|
int pthread_setconcurrency (int);
|
|
|
|
|
|
|
|
|
|
|
|
pthread_t pthread_self (void);
|
|
|
|
int pthread_setcancelstate (int, int *);
|
|
|
|
int pthread_setcanceltype (int, int *);
|
|
|
|
int pthread_setschedparam (pthread_t, int, const struct sched_param *);
|
|
|
|
int pthread_setspecific (pthread_key_t, const void *);
|
|
|
|
void pthread_testcancel (void);
|
|
|
|
|
|
|
|
/* Non posix calls */
|
|
|
|
|
|
|
|
int pthread_suspend (pthread_t);
|
|
|
|
int pthread_continue (pthread_t);
|
|
|
|
|
2000-02-18 03:38:33 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2001-04-12 12:04:53 +08:00
|
|
|
#endif /* _PTHREAD_H */
|