/* ************************************************************************* * * * Copyright 2000 Compaq Computer Corporation * * * * COMPAQ Registered in U.S. Patent and Trademark Office. * * * * Confidential computer software. Valid license from Compaq or * * authorized sublicensor required for possession, use or copying. * * Consistent with FAR 12.211 and 12.212, Commercial Computer Software, * * Computer Software Documentation, and Technical Data for Commercial * * Items are licensed to the U.S. Government under vendor's standard * * commercial license. * * * * Compaq shall not be liable for technical or editorial errors or * * omissions contained herein. The information in this document is * * subject to change without notice. * * * ************************************************************************* */ /* * @(#)$RCSfile: pthread_d4.h,v $ $Revision: 1.1.22.1 $ (DEC) $Date: 2000/10/19 03:24:22 $ */ /* * FACILITY: * * DECthreads core * * ABSTRACT: * * External definitions for DECthreads POSIX 1003.4a/D4 services * * AUTHORS: * * Dave Butenhof * * CREATION DATE: * * 20 February 1990 * * MODIFIED BY: * * J.L. Berg * Dave Butenhof * Paul Clark * Paul Curtin * Steve Johnson * Brian Keane * Peter Portante * Webb Scales * * LAST MODIFIED: * * 16 September 1998 */ #ifndef _PTHREAD_D4_ # define _PTHREAD_D4_ #ifdef __cplusplus extern "C" { #endif #if defined(vms) || defined(__vms) || defined(VMS) || defined(__VMS) # include # ifndef _TIMESPEC_T_ # define _TIMESPEC_T_ typedef struct timespec { unsigned long tv_sec; /* seconds */ long tv_nsec; /* nanoseconds */ } timespec_t; # endif #else # include # include #endif /* * We define the following macro to change the actual name of the routine to * have the _d4 appended to it. It is only used on routines which have a name * conflict with the new POSIX 1003.1c standard. */ #if _CMA_OS_ == _CMA__VMS # if _CMA_COMPILER_ == _CMA__VAXC # define _Draft4(_arg_) _arg_/**/_d4 # else # define _Draft4(_arg_) _arg_##_d4 # endif #else # define _Draft4(_arg_) _arg_ #endif /* * The implementation makes these basic decisions */ #ifndef _POSIX_THREADS # define _POSIX_THREADS 1 #endif #ifndef _POSIX_THREAD_ATTR_STACKSIZE # define _POSIX_THREAD_ATTR_STACKSIZE 1 #endif #if _CMA_POSIX_SCHED_ # define _POSIX_THREADS_REALTIME_SCHEDULING 1 #elif defined(_POSIX_THREADS_REALTIME_SCHEDULING) # undef _POSIX_THREADS_REALTIME_SCHEDULING #endif #ifndef _POSIX_THREADS_PER_PROCESS_SIGNALS_1 # define _POSIX_THREADS_PER_PROCESS_SIGNALS_1 1 #endif #if ((_CMA_COMPILER_ != _CMA__DECCPLUS) && (_CMS_OS_ == _CMA__UNIX)) /* * Implement push and pop for cancellation handlers, using the compiler's * native try/finally constructs. */ # define pthread_cleanup_push(_routine_,_arg_) \ { \ pthread_cleanup_t _XXX_proc = (pthread_cleanup_t)(_routine_); \ pthread_addr_t _XXX_arg = (pthread_addr_t)(_arg_); \ int _XXX_completed = 0; \ try { # define pthread_cleanup_pop(_execute_) \ _XXX_completed = 1;} \ finally { \ if ((! _XXX_completed) || (_execute_)) _XXX_proc (_XXX_arg);} \ } #else /* * Implement push and pop for cancellation handlers, using TRY and ENDTRY */ # define pthread_cleanup_push(_routine_,_arg_) \ { \ pthread_cleanup_t _XXX_proc = (pthread_cleanup_t)(_routine_); \ pthread_addr_t _XXX_arg = (pthread_addr_t)(_arg_); \ int _XXX_completed = 0; \ TRY { # define pthread_cleanup_pop(_execute_) \ _XXX_completed = 1;} \ FINALLY { \ if ((! _XXX_completed) || (_execute_)) _XXX_proc (_XXX_arg);} \ ENDTRY} #endif #define pthread_equal_np(__t1,__t2) pthread_equal(__t1,__t2) /* * Sample decisions for the environment types */ typedef cma_t_key pthread_key_t; typedef cma_t_address pthread_addr_t; typedef pthread_addr_t any_t; typedef cma_t_handle pthread_handle_t; typedef void (*pthread_cleanup_t) (pthread_addr_t arg); /* * Sample decision for a one-time initialization control block and its * initialization macro. * * Declare a one time initialization control block as: * * static pthread_once_t block = pthread_once_init; */ typedef cma_t_once pthread_once_t; #define pthread_once_init cma_once_init #define CANCEL_ON 1 #define CANCEL_OFF 0 /* * The following are the portable pthread definitions */ /* * Operations on attributes objects */ typedef cma_t_attr pthread_attr_t; /* * An attributes object is created to specify the attributes of other CMA * objects that will be created. */ int _CMA_CALL_ pthread_attr_create ( pthread_attr_t *attr); /* * An attributes object can be deleted when it is no longer needed. */ int _CMA_CALL_ pthread_attr_delete ( pthread_attr_t *attr); /* * Operations on threads */ typedef cma_t_start_routine pthread_startroutine_t; typedef cma_t_thread pthread_t; typedef pthread_startroutine_t pthread_func_t; #define PTHREAD_INHERIT_SCHED (int)cma_c_sched_inherit #define PTHREAD_DEFAULT_SCHED (int)cma_c_sched_use_default #define PTHREAD_CREATE_JOINABLE (int)cma_c_create_joinable #define PTHREAD_CREATE_DETACHED (int)cma_c_create_detached #if !_CMA_RT4_KTHREAD_ # define SCHED_FIFO cma_c_sched_fifo # define SCHED_RR cma_c_sched_rr # define SCHED_OTHER cma_c_sched_throughput # define SCHED_FG_NP cma_c_sched_throughput # define SCHED_BG_NP cma_c_sched_background #endif #define PRI_FIFO_MIN cma_c_prio_fifo_min #define PRI_FIFO_MAX cma_c_prio_fifo_max #define PRI_RR_MIN cma_c_prio_rr_min #define PRI_RR_MAX cma_c_prio_rr_max #define PRI_FG_MIN_NP cma_c_prio_through_min #define PRI_FG_MAX_NP cma_c_prio_through_max #define PRI_BG_MIN_NP cma_c_prio_back_min #define PRI_BG_MAX_NP cma_c_prio_back_max #define PRI_OTHER_MIN cma_c_prio_through_min #define PRI_OTHER_MAX cma_c_prio_through_max int _CMA_CALL_ _Draft4(pthread_equal) ( /* Compare two handles */ pthread_t handle1, pthread_t handle2); /* * This must come after the routine prototype declaration so that the * right name mangling can happen for the prototype on VMS platforms. */ #ifdef pthread_equal # undef pthread_equal #endif #define pthread_equal(_t1_,_t2_) \ (((_t1_).field1 == (_t2_).field1) \ && ((_t1_).field2 == (_t2_).field2)) /* * Operations to define thread creation attributes */ /* * Set or obtain the default thread priority. */ int _CMA_CALL_ pthread_attr_setprio ( pthread_attr_t *attr, int priority); int _CMA_CALL_ pthread_attr_getprio ( pthread_attr_t attr); /* * Set or obtain the default scheduling algorithm */ int _CMA_CALL_ pthread_attr_setsched ( pthread_attr_t *attr, int scheduler); int _CMA_CALL_ pthread_attr_getsched ( pthread_attr_t attr); /* * Set or obtain whether a thread will use the default scheduling attributes, * or inherit them from the creating thread. */ int _CMA_CALL_ _Draft4(pthread_attr_setinheritsched) ( pthread_attr_t *attr, int inherit); int _CMA_CALL_ _Draft4(pthread_attr_getinheritsched) ( pthread_attr_t attr); /* * Set or obtain the default stack size */ int _CMA_CALL_ _Draft4(pthread_attr_setstacksize) ( pthread_attr_t *attr, long stacksize); unsigned long _CMA_CALL_ _Draft4(pthread_attr_getstacksize) ( pthread_attr_t attr); /* * Set or obtain the default guard size */ int _CMA_CALL_ _Draft4(pthread_attr_setguardsize_np) ( pthread_attr_t *attr, long guardsize); unsigned long _CMA_CALL_ _Draft4(pthread_attr_getguardsize_np) ( pthread_attr_t attr); /* * Set or obtain the detach state */ int _CMA_CALL_ pthread_attr_setdetach_np ( pthread_attr_t *attr, int detachstate); int _CMA_CALL_ pthread_attr_getdetach_np ( pthread_attr_t attr); /* * The following procedures can be used to control thread creation, * termination and deletion. */ /* * To create a thread object and runnable thread, a routine must be specified * as the new thread's start routine. An argument may be passed to this * routine, as an untyped address; an untyped address may also be returned as * the routine's value. An attributes object may be used to specify details * about the kind of thread being created. */ int _CMA_CALL_ _Draft4(pthread_create) ( pthread_t *thread, pthread_attr_t attr, pthread_startroutine_t start_routine, pthread_addr_t arg); /* * A thread object may be "detached" to specify that the return value and * completion status will not be requested. */ int _CMA_CALL_ _Draft4(pthread_detach) ( pthread_t *thread); /* * A thread may terminate it's own execution. */ void _CMA_CALL_ _Draft4(pthread_exit) ( pthread_addr_t status); /* * A thread can await termination of another thread and retrieve the return * value of the thread. */ int _CMA_CALL_ _Draft4(pthread_join) ( pthread_t thread, pthread_addr_t *status); /* * Thread Scheduling Operations */ /* * The current user_assigned priority of a thread can be changed. */ int _CMA_CALL_ pthread_setprio ( pthread_t thread, int priority); /* * The current user_assigned scheduler algorithm of a thread can be changed. */ int _CMA_CALL_ pthread_setscheduler ( pthread_t thread, int scheduler, int priority); /* * A thread may tell the scheduler that its processor can be made available. */ void _CMA_CALL_ pthread_yield (void); /* * Bind a thread to a particular CPU on a multiprocessor system. */ int _CMA_CALL_ pthread_bind_to_cpu_np ( pthread_t thread, long cpu_mask); /* * Thread Information Operations */ /* * A thread may obtain a copy of its own thread handle. */ pthread_t _CMA_CALL_ _Draft4(pthread_self) (void); /* * Obtain a thread's sequence number. This will usually be a unique integer * across all threads within a process (until a large number of threads has * been created). */ long _CMA_CALL_ pthread_getunique_np ( pthread_t *thread); /* * The current user_assigned priority of a thread can be read. */ int _CMA_CALL_ pthread_getprio ( pthread_t thread); /* * The current user_assigned scheduler algorithm of a thread can be read. */ int _CMA_CALL_ pthread_getscheduler ( pthread_t thread); /* * Operations on Mutexes */ #define MUTEX_FAST_NP (int)cma_c_mutex_fast #define MUTEX_RECURSIVE_NP (int)cma_c_mutex_recursive #define MUTEX_NONRECURSIVE_NP (int)cma_c_mutex_nonrecursive typedef cma_t_attr pthread_mutexattr_t; typedef cma_t_mutex pthread_mutex_t; int _CMA_CALL_ pthread_mutexattr_create ( pthread_mutexattr_t *attr); int _CMA_CALL_ pthread_mutexattr_delete ( pthread_mutexattr_t *attr); int _CMA_CALL_ pthread_mutexattr_setkind_np ( pthread_mutexattr_t *attr, int kind); int _CMA_CALL_ pthread_mutexattr_getkind_np ( pthread_mutexattr_t attr); int _CMA_CALL_ pthread_mutexattr_setmetered_np ( pthread_mutexattr_t *attr, int meter); int _CMA_CALL_ pthread_mutexattr_getmetered_np ( pthread_mutexattr_t attr); /* * The following routines create, delete, lock and unlock mutexes. */ int _CMA_CALL_ _Draft4(pthread_mutex_init) ( pthread_mutex_t *mutex, pthread_mutexattr_t attr); int _CMA_CALL_ _Draft4(pthread_mutex_destroy) ( pthread_mutex_t *mutex); int _CMA_CALL_ _Draft4(pthread_mutex_lock) ( pthread_mutex_t *mutex); int _CMA_CALL_ _Draft4(pthread_mutex_trylock) ( pthread_mutex_t *mutex); int _CMA_CALL_ _Draft4(pthread_mutex_unlock) ( pthread_mutex_t *mutex); /* * Operations on condition variables */ typedef cma_t_attr pthread_condattr_t; typedef cma_t_cond pthread_cond_t; int _CMA_CALL_ pthread_condattr_create ( pthread_condattr_t *attr); int _CMA_CALL_ pthread_condattr_delete ( pthread_condattr_t *attr); /* * A thread can create and delete condition variables. */ int _CMA_CALL_ _Draft4(pthread_cond_init) ( pthread_cond_t *cond, pthread_condattr_t attr); int _CMA_CALL_ _Draft4(pthread_cond_destroy) ( pthread_cond_t *cond); /* * A thread can signal to and broadcast on a condition variable. */ int _CMA_CALL_ _Draft4(pthread_cond_broadcast) ( pthread_cond_t *cond); int _CMA_CALL_ _Draft4(pthread_cond_signal) ( pthread_cond_t *cond); int _CMA_CALL_ _Draft4(pthread_cond_signal_int_np) ( pthread_cond_t *cond); #if _CMA_OS_ == _CMA__UNIX int _CMA_CALL_ pthread_cond_sig_preempt_int_np ( pthread_cond_t *condition, pthread_addr_t scp); #else # if _CMA_OS_ == _CMA__VMS int _CMA_CALL_ pthread_cond_sigprmpt_int_np_d4 ( pthread_cond_t *condition); # else int _CMA_CALL_ pthread_cond_sig_preempt_int_np ( pthread_cond_t *condition); # endif #endif /* * A thread can wait for a condition variable to be signalled or broadcast. */ int _CMA_CALL_ _Draft4(pthread_cond_wait) ( pthread_cond_t *cond, pthread_mutex_t *mutex); /* * Operations for timed waiting */ /* * A thread can perform a timed wait on a condition variable. */ int _CMA_CALL_ _Draft4(pthread_cond_timedwait) ( pthread_cond_t *cond, pthread_mutex_t *mutex, struct timespec *abstime); /* * Operations for client initialization. */ typedef void (*pthread_initroutine_t) (void); int _CMA_CALL_ _Draft4(pthread_once) ( pthread_once_t *once_block, pthread_initroutine_t init_routine); /* * Operations for per-thread context */ typedef cma_t_destructor pthread_destructor_t; /* * A unique per-thread context key can be obtained for the process */ int _CMA_CALL_ pthread_keycreate ( pthread_key_t *key, pthread_destructor_t destructor); /* * A thread can set a per-thread context value identified by a key. */ int _CMA_CALL_ _Draft4(pthread_setspecific) ( pthread_key_t key, pthread_addr_t value); /* * A thread can retrieve a per-thread context value identified by a key. */ int _CMA_CALL_ _Draft4(pthread_getspecific) ( pthread_key_t key, pthread_addr_t *value); /* * Operations for alerts. */ /* * The current thread can request that a thread terminate it's execution. */ int _CMA_CALL_ _Draft4(pthread_cancel) ( pthread_t thread); /* * The current thread can poll for alert delivery. */ void _CMA_CALL_ _Draft4(pthread_testcancel) (void); /* * The current thread can enable or disable alert delivery (PTHREAD * "cancels"); it can control "general cancelability" (CMA "defer") or * just "asynchronous cancelability" (CMA "asynch disable"). */ int _CMA_CALL_ pthread_setasynccancel ( int state); int _CMA_CALL_ pthread_setcancel ( int state); #ifndef _CMA_SUPPRESS_EXTERNALS_ _CMA_IMPORT_ pthread_attr_t pthread_attr_default; _CMA_IMPORT_ pthread_mutexattr_t pthread_mutexattr_default; _CMA_IMPORT_ pthread_condattr_t pthread_condattr_default; #endif /* * Define nonportable extensions */ extern int _CMA_CALL_ _Draft4(pthread_get_expiration_np) ( struct timespec *delta, struct timespec *abstime); extern int _CMA_CALL_ _Draft4(pthread_delay_np) ( struct timespec *interval); extern int _CMA_CALL_ _Draft4(pthread_lock_global_np) (void); extern int _CMA_CALL_ _Draft4(pthread_unlock_global_np) (void); #if _CMA_OS_ != _CMA__VMS extern int _CMA_CALL_ pthread_sig_to_can_thread_np ( sigset_t *sigset, pthread_t *target, pthread_t *thread); extern int _CMA_CALL_ pthread_signal_to_cancel_np ( sigset_t *sigset, pthread_t *target); #endif /* * Now, since we are providing source migration capability, we need to make * sure old code, which was built against the POSIX 1003.4a interface, * references the new routine names which have _d4 on the end. */ #if _CMA_OS_ == _CMA__VMS # define pthread_attr_getguardsize_np(__attr) \ pthread_attr_getguardsize_np_d4 (__attr) # define pthread_attr_getinheritsched(__attr) \ pthread_attr_getinheritsched_d4 (__attr) # define pthread_attr_getstacksize(__attr) \ pthread_attr_getstacksize_d4 (__attr) # define pthread_attr_setguardsize_np(__attr,__guardsize) \ pthread_attr_setguardsize_np_d4 (__attr,__guardsize) # define pthread_attr_setinheritsched(__attr,__inherit) \ pthread_attr_setinheritsched_d4 (__attr,__inherit) # define pthread_attr_setstacksize(__attr,__stacksize) \ pthread_attr_setstacksize_d4 (__attr,__stacksize) # define pthread_cancel(__thread) \ pthread_cancel_d4 (__thread) # define pthread_cond_broadcast(__cond) \ pthread_cond_broadcast_d4 (__cond) # define pthread_cond_destroy(__cond) \ pthread_cond_destroy_d4 (__cond) # define pthread_cond_init(__cond,__attr) \ pthread_cond_init_d4 (__cond,__attr) # define pthread_cond_sig_preempt_int_np(__cond) \ pthread_cond_sigprmpt_int_np_d4 (__cond) # define pthread_cond_signal(__cond) \ pthread_cond_signal_d4 (__cond) # define pthread_cond_signal_int_np(__cond) \ pthread_cond_signal_int_np_d4 (__cond) # define pthread_cond_timedwait(__cond,__mutex,__abstime) \ pthread_cond_timedwait_d4 (__cond,__mutex,__abstime) # define pthread_cond_wait(__cond,__mutex) \ pthread_cond_wait_d4 (__cond,__mutex) # define pthread_create(__thread,__attr,__start_routine,__arg) \ pthread_create_d4 (__thread,__attr,__start_routine,__arg) # define pthread_delay_np(__interval) \ pthread_delay_np_d4 (__interval) # define pthread_detach(__thread) \ pthread_detach_d4 (__thread) # define pthread_exit(__status) \ pthread_exit_d4 (__status) # define pthread_get_expiration_np(__delta,__abstime) \ pthread_get_expiration_np_d4 (__delta,__abstime) # define pthread_getspecific(__key,__value) \ pthread_getspecific_d4 (__key,__value) # define pthread_join(__thread,__status) \ pthread_join_d4 (__thread,__status) # define pthread_lock_global_np() \ pthread_lock_global_np_d4 () # define pthread_mutex_destroy(__mutex) \ pthread_mutex_destroy_d4 (__mutex) # define pthread_mutex_init(__mutex,__attr) \ pthread_mutex_init_d4 (__mutex,__attr) # define pthread_mutex_lock(__mutex) \ pthread_mutex_lock_d4 (__mutex) # define pthread_mutex_trylock(__mutex) \ pthread_mutex_trylock_d4 (__mutex) # define pthread_mutex_unlock(__mutex) \ pthread_mutex_unlock_d4 (__mutex) # define pthread_once(__once_block,__init_routine) \ pthread_once_d4 (__once_block,__init_routine) # define pthread_self() \ pthread_self_d4 () # define pthread_setspecific(__key,__value) \ pthread_setspecific_d4 (__key,__value) # define pthread_testcancel() \ pthread_testcancel_d4 () # define pthread_unlock_global_np() \ pthread_unlock_global_np_d4 () #endif #ifdef __cplusplus } #endif #endif