aboutsummaryrefslogtreecommitdiff
path: root/src/pth.h
blob: 6a06579a26241bc3bb9ad820cb87af77420c94fb (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
#pragma once
#include <stdbool.h>

#include <pthsem.h>


struct prne_worker {
	void *ctx;
	void *(*entry)(void*);
	void (*fin)(void*);
	void (*free_ctx)(void*);
	pth_t pth;
	pth_attr_t attr;
};
typedef struct prne_worker prne_worker_t;

struct prne_pth_cv {
	pth_mutex_t *lock;
	pth_cond_t *cond;
	bool broadcast;
};
typedef struct prne_pth_cv prne_pth_cv_t;


void prne_init_worker (prne_worker_t *w);
void prne_free_worker (prne_worker_t *w);
void prne_fin_worker (prne_worker_t *w);

/* Workaround for bug in GNU Pth
* Calling pth_poll() with pollfd element whose fd is negative value results in
* undefined behaviour as stated in POSIX(FD_SET() with invalid value is
* undefined). GNU Pth uses FD_SET() with invalid values on purpose to achieve
* something.
*/
int prne_pth_poll (
	struct pollfd *pfd,
	const nfds_t nfs,
	const int timeout,
	pth_event_t ev);
void prne_pth_cv_notify (pth_mutex_t *lock, pth_cond_t *cond, bool broadcast);
pth_time_t prne_pth_tstimeout (const struct timespec ts);
void prne_pth_reset_timer (pth_event_t *ev, const struct timespec *ts);