/* * thread-pool.h * * A thread pool implementation * * Copyright © 2012 Deutsches Elektronen-Synchrotron DESY, * a research centre of the Helmholtz Association. * * Authors: * 2009-2012 Thomas White * * This file is part of CrystFEL. * * CrystFEL is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * CrystFEL is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with CrystFEL. If not, see . * */ #ifndef THREAD_POOL_H #define THREAD_POOL_H #ifdef HAVE_CONFIG_H #include #endif #include extern pthread_mutex_t stderr_lock; extern signed int get_status_label(void); /** * TPGetTaskFunc: * @qargs: The queue_args pointer which was given to run_threads(). * Returns: A pointer which will be passed to the worker function. * * This function is called, non-reentrantly, to get a new work item to give to * your work function. The stuff you need to generate the new work item should * have been stored in @qargs which was passed to run_threads(). * **/ typedef void *(*TPGetTaskFunc)(void *qargs); /** * TPWorkFunc: * @work: The queue_args pointer which was given to run_threads(). * @cookie: A small integral number which is guaranteed to be unique among all * currently running threads. * * This function is called, reentrantly, for each work item. * **/ typedef void (*TPWorkFunc)(void *work, int cookie); /** * TPFinalFunc: * @qargs: The queue_args pointer which was given to run_threads(). * @work: The pointer which was returned by your get_task function. * * This function is called, non-reentrantly, after each work item has been * completed. A typical use might be to update some counters inside @qargs * according to fields withing @work which were filled by your 'work' function. * **/ typedef void (*TPFinalFunc)(void *qargs, void *work); extern int run_threads(int n_threads, TPWorkFunc work, TPGetTaskFunc get_task, TPFinalFunc final, void *queue_args, int max, int cpu_num, int cpu_groupsize, int cpu_offset); #endif /* THREAD_POOL_H */