Blame workqueue.h

Packit Service 0e769b
#ifndef FIO_RATE_H
Packit Service 0e769b
#define FIO_RATE_H
Packit Service 0e769b
Packit Service 0e769b
#include <inttypes.h>
Packit Service 0e769b
#include <pthread.h>
Packit Service 0e769b
Packit Service 0e769b
#include "flist.h"
Packit Service 0e769b
#include "lib/types.h"
Packit Service 0e769b
Packit Service 0e769b
struct sk_out;
Packit Service 0e769b
struct thread_data;
Packit Service 0e769b
Packit Service 0e769b
struct workqueue_work {
Packit Service 0e769b
	struct flist_head list;
Packit Service 0e769b
};
Packit Service 0e769b
Packit Service 0e769b
struct submit_worker {
Packit Service 0e769b
	pthread_t thread;
Packit Service 0e769b
	pthread_mutex_t lock;
Packit Service 0e769b
	pthread_cond_t cond;
Packit Service 0e769b
	struct flist_head work_list;
Packit Service 0e769b
	unsigned int flags;
Packit Service 0e769b
	unsigned int index;
Packit Service 0e769b
	uint64_t seq;
Packit Service 0e769b
	struct workqueue *wq;
Packit Service 0e769b
	void *priv;
Packit Service 0e769b
	struct sk_out *sk_out;
Packit Service 0e769b
};
Packit Service 0e769b
Packit Service 0e769b
typedef int (workqueue_work_fn)(struct submit_worker *, struct workqueue_work *);
Packit Service 0e769b
typedef bool (workqueue_pre_sleep_flush_fn)(struct submit_worker *);
Packit Service 0e769b
typedef void (workqueue_pre_sleep_fn)(struct submit_worker *);
Packit Service 0e769b
typedef int (workqueue_alloc_worker_fn)(struct submit_worker *);
Packit Service 0e769b
typedef void (workqueue_free_worker_fn)(struct submit_worker *);
Packit Service 0e769b
typedef int (workqueue_init_worker_fn)(struct submit_worker *);
Packit Service 0e769b
typedef void (workqueue_exit_worker_fn)(struct submit_worker *, unsigned int *);
Packit Service 0e769b
typedef void (workqueue_update_acct_fn)(struct submit_worker *);
Packit Service 0e769b
Packit Service 0e769b
struct workqueue_ops {
Packit Service 0e769b
	workqueue_work_fn *fn;
Packit Service 0e769b
	workqueue_pre_sleep_flush_fn *pre_sleep_flush_fn;
Packit Service 0e769b
	workqueue_pre_sleep_fn *pre_sleep_fn;
Packit Service 0e769b
Packit Service 0e769b
	workqueue_update_acct_fn *update_acct_fn;
Packit Service 0e769b
Packit Service 0e769b
	workqueue_alloc_worker_fn *alloc_worker_fn;
Packit Service 0e769b
	workqueue_free_worker_fn *free_worker_fn;
Packit Service 0e769b
Packit Service 0e769b
	workqueue_init_worker_fn *init_worker_fn;
Packit Service 0e769b
	workqueue_exit_worker_fn *exit_worker_fn;
Packit Service 0e769b
Packit Service 0e769b
	unsigned int nice;
Packit Service 0e769b
};
Packit Service 0e769b
Packit Service 0e769b
struct workqueue {
Packit Service 0e769b
	unsigned int max_workers;
Packit Service 0e769b
Packit Service 0e769b
	struct thread_data *td;
Packit Service 0e769b
	struct workqueue_ops ops;
Packit Service 0e769b
Packit Service 0e769b
	uint64_t work_seq;
Packit Service 0e769b
	struct submit_worker *workers;
Packit Service 0e769b
	unsigned int next_free_worker;
Packit Service 0e769b
Packit Service 0e769b
	pthread_cond_t flush_cond;
Packit Service 0e769b
	pthread_mutex_t flush_lock;
Packit Service 0e769b
	pthread_mutex_t stat_lock;
Packit Service 0e769b
	volatile int wake_idle;
Packit Service 0e769b
};
Packit Service 0e769b
Packit Service 0e769b
int workqueue_init(struct thread_data *td, struct workqueue *wq, struct workqueue_ops *ops, unsigned int max_workers, struct sk_out *sk_out);
Packit Service 0e769b
void workqueue_exit(struct workqueue *wq);
Packit Service 0e769b
Packit Service 0e769b
void workqueue_enqueue(struct workqueue *wq, struct workqueue_work *work);
Packit Service 0e769b
void workqueue_flush(struct workqueue *wq);
Packit Service 0e769b
Packit Service 0e769b
static inline bool workqueue_pre_sleep_check(struct submit_worker *sw)
Packit Service 0e769b
{
Packit Service 0e769b
	struct workqueue *wq = sw->wq;
Packit Service 0e769b
Packit Service 0e769b
	if (!wq->ops.pre_sleep_flush_fn)
Packit Service 0e769b
		return false;
Packit Service 0e769b
Packit Service 0e769b
	return wq->ops.pre_sleep_flush_fn(sw);
Packit Service 0e769b
}
Packit Service 0e769b
Packit Service 0e769b
static inline void workqueue_pre_sleep(struct submit_worker *sw)
Packit Service 0e769b
{
Packit Service 0e769b
	struct workqueue *wq = sw->wq;
Packit Service 0e769b
Packit Service 0e769b
	if (wq->ops.pre_sleep_fn)
Packit Service 0e769b
		wq->ops.pre_sleep_fn(sw);
Packit Service 0e769b
}
Packit Service 0e769b
Packit Service 0e769b
static inline int workqueue_init_worker(struct submit_worker *sw)
Packit Service 0e769b
{
Packit Service 0e769b
	struct workqueue *wq = sw->wq;
Packit Service 0e769b
Packit Service 0e769b
	if (!wq->ops.init_worker_fn)
Packit Service 0e769b
		return 0;
Packit Service 0e769b
Packit Service 0e769b
	return wq->ops.init_worker_fn(sw);
Packit Service 0e769b
}
Packit Service 0e769b
Packit Service 0e769b
static inline void workqueue_exit_worker(struct submit_worker *sw,
Packit Service 0e769b
					 unsigned int *sum_cnt)
Packit Service 0e769b
{
Packit Service 0e769b
	struct workqueue *wq = sw->wq;
Packit Service 0e769b
	unsigned int tmp = 1;
Packit Service 0e769b
Packit Service 0e769b
	if (!wq->ops.exit_worker_fn)
Packit Service 0e769b
		return;
Packit Service 0e769b
Packit Service 0e769b
	if (!sum_cnt)
Packit Service 0e769b
		sum_cnt = &tm;;
Packit Service 0e769b
Packit Service 0e769b
	wq->ops.exit_worker_fn(sw, sum_cnt);
Packit Service 0e769b
}
Packit Service 0e769b
#endif