2015-03-31 23:05:24 +02:00
|
|
|
|
|
|
|
#ifndef __WORKER_H__
|
|
|
|
#define __WORKER_H__
|
|
|
|
|
2023-01-27 23:13:46 +01:00
|
|
|
#include <event2/event.h>
|
|
|
|
|
2015-03-31 23:05:24 +02:00
|
|
|
/* The worker thread is made for running asyncronous tasks from a real time
|
2023-01-27 23:13:46 +01:00
|
|
|
* thread.
|
2015-03-31 23:05:24 +02:00
|
|
|
|
|
|
|
* The worker_execute() function will trigger a callback from the worker thread.
|
|
|
|
* Before returning the function will copy the argument given, so the caller
|
|
|
|
* does not need to preserve them. However, if the argument contains pointers to
|
|
|
|
* data, the caller must either make sure that the data remains valid until the
|
|
|
|
* callback (which can free it), or make sure the callback does not refer to it.
|
|
|
|
*
|
|
|
|
* @param cb the function to call from the worker thread
|
|
|
|
* @param cb_arg arguments for callback
|
|
|
|
* @param arg_size size of the arguments given
|
|
|
|
* @param delay how much in seconds to delay the execution
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
worker_execute(void (*cb)(void *), void *cb_arg, size_t arg_size, int delay);
|
|
|
|
|
2023-01-27 23:13:46 +01:00
|
|
|
/* Can be called within a callback to get the worker thread's event base
|
|
|
|
*/
|
|
|
|
struct event_base *
|
|
|
|
worker_evbase_get(void);
|
|
|
|
|
2015-03-31 23:05:24 +02:00
|
|
|
int
|
|
|
|
worker_init(void);
|
|
|
|
|
|
|
|
void
|
|
|
|
worker_deinit(void);
|
|
|
|
|
|
|
|
#endif /* !__WORKER_H__ */
|