aboutsummaryrefslogtreecommitdiff
path: root/src/thread-pool.h
blob: fefcef4ace130ddaf19b99f2c050961f426be2d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/*
 * thread-pool.h
 *
 * A thread pool implementation
 *
 * (c) 2006-2010 Thomas White <taw@physics.org>
 *
 * Part of CrystFEL - crystallography with a FEL
 *
 */


#ifndef THREAD_POOL_H
#define THREAD_POOL_H

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif


#include <pthread.h>

extern pthread_mutex_t stderr_lock;
extern signed int get_status_label(void);


/* work() will be called with a number and work_args.  The number will be
 * unique and in the range 0..n_tasks.  A progress bar will be shown using
 * "text" and the progress through the tasks, unless "text" is NULL. */
extern void run_thread_range(int n_tasks, int n_threads, const char *text,
                             void (*work)(int, void *), void *work_args);


/* get_task() will be called every time a worker is idle.  It returns either
 * NULL, indicating that no further work is available, or a pointer which will
 * be passed to work().  Work will stop after 'max' tasks have been processed.
 * final() will be called once per image, and will be given both queue_args
 * and the last task pointer.
 * get_task() and final() do NOT need to be re-entrant.
 * If "max" is zero, all tasks will be processed.
 * Returns: the number of tasks processed. */
extern int run_threads(int n_threads, void (*work)(void *, int),
                       void *(*get_task)(void *), void (*final)(void *, void *),
                       void *queue_args, int max);


#endif	/* THREAD_POOL_H */