diff options
author | Christopher Faylor <me@cgf.cx> | 2001-03-21 02:17:58 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2001-03-21 02:17:58 +0000 |
commit | 9a08b2c02eea0c955c5fef0b0287803947fef0b6 (patch) | |
tree | 5ba4bc2c409482b4530eb8e1c2befd557170009e /winsup/cygwin/include/pthread.h | |
parent | a1299ba54b1a4977da361a037d6c3392005cbd25 (diff) | |
download | cygnal-9a08b2c02eea0c955c5fef0b0287803947fef0b6.tar.gz cygnal-9a08b2c02eea0c955c5fef0b0287803947fef0b6.tar.bz2 cygnal-9a08b2c02eea0c955c5fef0b0287803947fef0b6.zip |
* sched.cc: New file. Implement sched*.
* include/sched.h: New file. User land includes for sched*.
* Makefile.in: Add sched.o
* cygwin.din: Add exports for sched*.
Diffstat (limited to 'winsup/cygwin/include/pthread.h')
-rw-r--r-- | winsup/cygwin/include/pthread.h | 132 |
1 files changed, 61 insertions, 71 deletions
diff --git a/winsup/cygwin/include/pthread.h b/winsup/cygwin/include/pthread.h index 1a96e7286..d4b73de82 100644 --- a/winsup/cygwin/include/pthread.h +++ b/winsup/cygwin/include/pthread.h @@ -21,7 +21,6 @@ extern "C" { #endif -#define TFD(n) void*(*n)(void*) /* Defines. (These are correctly defined here as per http://www.opengroup.org/onlinepubs/7908799/xsh/pthread.h.html */ @@ -32,94 +31,85 @@ extern "C" #define PTHREAD_PROCESS_PRIVATE 0 #define PTHREAD_PROCESS_SHARED 1 - -typedef int pthread_t; -typedef int pthread_mutex_t; -typedef int sem_t; - -typedef struct pthread_key - { - } -pthread_key_t; - -typedef struct pthread_attr - { - size_t stacksize; - } -pthread_attr_t; - -typedef struct pthread_mutexattr - { - } -pthread_mutexattr_t; - -typedef struct pthread_condattr - { - int shared; - int valid; - } -pthread_condattr_t; - -typedef int pthread_cond_t; +#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 +#define PTHREAD_CREATE_DETACHED 1 +/* the default : joinable */ +#define PTHREAD_CREATE_JOINABLE 0 + + +/* these shouldn't be defined here but in sys/types. + * defining in sys/types mught also allow us to override them for the internal functions + * more easily (internal sys/types vs external sys/type - dev thoughts on this? + */ + typedef void *pthread_t; + typedef void *pthread_mutex_t; + + typedef void *pthread_key_t; + typedef void *pthread_attr_t; + typedef void *pthread_mutexattr_t; + typedef void *pthread_condattr_t; + typedef void *pthread_cond_t; /* ThreadCreation */ -int pthread_create (pthread_t * thread, const pthread_attr_t * attr, TFD (function), void *arg); -int pthread_attr_init (pthread_attr_t * attr); -int pthread_attr_destroy (pthread_attr_t * attr); -int pthread_attr_setstacksize (pthread_attr_t * attr, size_t size); -int pthread_attr_getstacksize (pthread_attr_t * attr, size_t * size); + int pthread_create (pthread_t * thread, const pthread_attr_t * attr, + void *(*)(void *), void *arg); + int pthread_attr_init (pthread_attr_t * attr); + int pthread_attr_destroy (pthread_attr_t * attr); + int pthread_attr_setdetachstate (pthread_attr_t *, int); + int pthread_attr_getdetachstate (const pthread_attr_t *, int *); + int pthread_attr_setstacksize (pthread_attr_t * attr, size_t size); + int pthread_attr_getstacksize (pthread_attr_t * attr, size_t * size); /* Condition variables */ -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_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); /* Thread Control */ -int pthread_detach (pthread_t thread); -int pthread_join (pthread_t thread, void **value_ptr); + int pthread_detach (pthread_t thread); + int pthread_join (pthread_t thread, void **value_ptr); /* Thread Exit */ -int pthread_exit (void *value_ptr); + void pthread_exit (void *value_ptr); /* Thread SpecificData */ -int pthread_key_create (pthread_key_t * key); -int pthread_key_delete (pthread_key_t * key); -int pthread_setspecific (pthread_key_t * key, const void *value); -void *pthread_getspecific (pthread_key_t * key); + int pthread_key_create (pthread_key_t *, void (*)(void *)); + int pthread_key_delete (pthread_key_t * key); + int pthread_setspecific (pthread_key_t key, const void *value); + void *pthread_getspecific (pthread_key_t key); -/* Thread signal */ -int pthread_kill (pthread_t * thread, int sig); -int pthread_sigmask (int operation, const sigset_t * set, sigset_t * old_set); +/* Thread signal (should be in signal.h) */ + int pthread_kill (pthread_t * thread, int sig); + int pthread_sigmask (int operation, const sigset_t * set, + sigset_t * old_set); /* ID */ -pthread_t pthread_self (); -int pthread_equal (pthread_t t1, pthread_t t2); + pthread_t pthread_self (); + int pthread_equal (pthread_t t1, pthread_t t2); /* Mutexes */ -int pthread_mutex_init (pthread_mutex_t * mutex, const pthread_mutexattr_t *); -int pthread_mutex_lock (pthread_mutex_t * mutext); -int pthread_mutex_trylock (pthread_mutex_t * mutext); -int pthread_mutex_unlock (pthread_mutex_t * mutext); -int pthread_mutex_destroy (pthread_mutex_t * mutext); - -/* Solaris Semaphores */ -int sem_init (sem_t * sem, int pshared, unsigned int value); -int sem_destroy (sem_t * sem); -int sem_wait (sem_t * sem); -int sem_trywait (sem_t * sem); -int sem_post (sem_t * sem); + int pthread_mutex_init (pthread_mutex_t * mutex, + const pthread_mutexattr_t *); + int pthread_mutex_lock (pthread_mutex_t * mutext); + int pthread_mutex_trylock (pthread_mutex_t * mutext); + int pthread_mutex_unlock (pthread_mutex_t * mutext); + int pthread_mutex_destroy (pthread_mutex_t * mutext); #ifdef __cplusplus } #endif -#endif /* _PTHREAD_H */ +#endif /* _PTHREAD_H */ |