X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fldap_pvt_thread.h;h=21b2dc69cdf3affcca2b2db47d5ed4404b06c3bc;hb=eea5e60bf0b2ec0cc5cfd4065cc188c786ed25b6;hp=ddc0302a83cf12cfdf58afb91760e6d024df3699;hpb=4a0d1a7dd1cd9f07e00a98c3e008905ebc52198e;p=openldap diff --git a/include/ldap_pvt_thread.h b/include/ldap_pvt_thread.h index ddc0302a83..21b2dc69cd 100644 --- a/include/ldap_pvt_thread.h +++ b/include/ldap_pvt_thread.h @@ -34,13 +34,9 @@ typedef ldap_int_thread_cond_t ldap_pvt_thread_cond_t; typedef ldap_int_thread_rdwr_t ldap_pvt_thread_rdwr_t; #endif typedef ldap_int_thread_rmutex_t ldap_pvt_thread_rmutex_t; +typedef ldap_int_thread_key_t ldap_pvt_thread_key_t; #endif /* !LDAP_PVT_THREAD_H_DONE */ -#if 0 && defined(LDAP_DEVEL) -/* must also be defined in slapd.h */ -#define LDAP_PVT_THREAD_POOL_SEM_LOAD_CONTROL -#endif - #define ldap_pvt_thread_equal ldap_int_thread_equal LDAP_F( int ) @@ -174,6 +170,18 @@ ldap_pvt_thread_rdwr_wtrylock LDAP_P((ldap_pvt_thread_rdwr_t *rdwrp)); LDAP_F( int ) ldap_pvt_thread_rdwr_wunlock LDAP_P((ldap_pvt_thread_rdwr_t *rdwrp)); +LDAP_F( int ) +ldap_pvt_thread_key_create LDAP_P((ldap_pvt_thread_key_t *keyp)); + +LDAP_F( int ) +ldap_pvt_thread_key_destroy LDAP_P((ldap_pvt_thread_key_t key)); + +LDAP_F( int ) +ldap_pvt_thread_key_setdata LDAP_P((ldap_pvt_thread_key_t key, void *data)); + +LDAP_F( int ) +ldap_pvt_thread_key_getdata LDAP_P((ldap_pvt_thread_key_t key, void **data)); + #ifdef LDAP_DEBUG LDAP_F( int ) ldap_pvt_thread_rdwr_readers LDAP_P((ldap_pvt_thread_rdwr_t *rdwrp)); @@ -220,6 +228,7 @@ typedef enum { LDAP_PVT_THREAD_POOL_PARAM_OPEN, LDAP_PVT_THREAD_POOL_PARAM_STARTING, LDAP_PVT_THREAD_POOL_PARAM_ACTIVE, + LDAP_PVT_THREAD_POOL_PARAM_PAUSING, LDAP_PVT_THREAD_POOL_PARAM_PENDING, LDAP_PVT_THREAD_POOL_PARAM_BACKLOAD, LDAP_PVT_THREAD_POOL_PARAM_ACTIVE_MAX,