diff options
Diffstat (limited to 'src/thrd/pool.h')
| -rwxr-xr-x | src/thrd/pool.h | 82 |
1 files changed, 30 insertions, 52 deletions
diff --git a/src/thrd/pool.h b/src/thrd/pool.h index a744133..3a5f7b6 100755 --- a/src/thrd/pool.h +++ b/src/thrd/pool.h @@ -3,74 +3,52 @@ #ifndef POOL_H #define POOL_H +#include <queue> + using namespace std; class pool { private: - typedef struct tpool_work - { - void (*routine)(void*); /// - void *arg; - struct tpool_work *next; - } - tpool_work_t; - - typedef struct tpool - { - // pool characteristics: - int num_threads; - int max_queue_size; - int do_not_block_when_full; - - // pool state - pthread_t *threads; - int cur_queue_size; + friend class thro; - tpool_work_t *queue_head; - tpool_work_t *queue_tail; + struct task + { + void(*p_func)(void*); + void *p_void; - pthread_mutex_t queue_lock; - pthread_cond_t queue_not_empty; - pthread_cond_t queue_not_full; - pthread_cond_t queue_empty; - - int queue_closed; - int shutdown; + task(void(*p_func)(void*), void *p_void) + { + this->p_func = p_func; + this->p_void = p_void; } - *tpool_t; + }; - int i_thrd_pool_size; - int i_thrd_pool_queue; + pthread_mutex_t mut_threads; + pthread_mutex_t mut_queue_tasks; + pthread_mutex_t mut_num_avail_threads; + pthread_cond_t cond_new_task; - tpool_t thread_pool; + int i_num_avail_threads; + int i_num_total_threads; - void - tpool_init( tpool_t *tpoolp, int num_worker_threads, int max_queue_size, int do_not_block_when_full ); + queue<task*> queue_tasks; - int - tpool_add_work( tpool_t tpool, void(*routine)(void*), void* arg ); + int increase_pool(int i_num); + void add_task( void(*p_func)(void*), void* p_void ); + static void* wait_for_task(void *p_void); + static void run_func(void *p_void); - // virtual void - // tpool_destroy( tpool_t tpoolp, int finish ); - - static void* - tpool_thread( void* arg); - - static void - run_func( void *v_pointer ); - - // public methods: public: - pool( ); + pool(); + ~pool(); + + void run(void* p_void); + bool allow_user_login(); - // inline (speed)! - void run( void *arg ) - { - tpool_add_work( thread_pool, run_func, arg ); - } #ifdef NCURSES - void print_pool_size(); + + void print_pool_size(); #endif }; |
