2019-10-22 16:25:58 +00:00
|
|
|
#ifndef INTERNAL_IO_WQ_H
|
|
|
|
#define INTERNAL_IO_WQ_H
|
|
|
|
|
|
|
|
struct io_wq;
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IO_WQ_WORK_CANCEL = 1,
|
|
|
|
IO_WQ_WORK_HAS_MM = 2,
|
|
|
|
IO_WQ_WORK_HASHED = 4,
|
|
|
|
IO_WQ_WORK_NEEDS_USER = 8,
|
2019-10-24 18:39:47 +00:00
|
|
|
IO_WQ_WORK_NEEDS_FILES = 16,
|
2019-11-07 18:41:16 +00:00
|
|
|
IO_WQ_WORK_UNBOUND = 32,
|
2019-11-13 05:31:31 +00:00
|
|
|
IO_WQ_WORK_INTERNAL = 64,
|
2019-11-20 20:05:32 +00:00
|
|
|
IO_WQ_WORK_CB = 128,
|
2019-10-22 16:25:58 +00:00
|
|
|
|
|
|
|
IO_WQ_HASH_SHIFT = 24, /* upper 8 bits are used for hash key */
|
|
|
|
};
|
|
|
|
|
|
|
|
enum io_wq_cancel {
|
|
|
|
IO_WQ_CANCEL_OK, /* cancelled before started */
|
|
|
|
IO_WQ_CANCEL_RUNNING, /* found, running, and attempted cancelled */
|
|
|
|
IO_WQ_CANCEL_NOTFOUND, /* work not found */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct io_wq_work {
|
2019-11-20 20:05:32 +00:00
|
|
|
union {
|
|
|
|
struct list_head list;
|
|
|
|
void *data;
|
|
|
|
};
|
2019-10-22 16:25:58 +00:00
|
|
|
void (*func)(struct io_wq_work **);
|
|
|
|
unsigned flags;
|
2019-10-24 18:39:47 +00:00
|
|
|
struct files_struct *files;
|
2019-10-22 16:25:58 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#define INIT_IO_WORK(work, _func) \
|
|
|
|
do { \
|
|
|
|
(work)->func = _func; \
|
|
|
|
(work)->flags = 0; \
|
2019-10-24 18:39:47 +00:00
|
|
|
(work)->files = NULL; \
|
2019-10-22 16:25:58 +00:00
|
|
|
} while (0) \
|
|
|
|
|
2019-11-13 05:31:31 +00:00
|
|
|
typedef void (get_work_fn)(struct io_wq_work *);
|
|
|
|
typedef void (put_work_fn)(struct io_wq_work *);
|
|
|
|
|
2019-11-25 15:49:20 +00:00
|
|
|
struct io_wq_data {
|
|
|
|
struct mm_struct *mm;
|
|
|
|
struct user_struct *user;
|
2019-11-25 15:52:30 +00:00
|
|
|
struct cred *creds;
|
2019-11-25 15:49:20 +00:00
|
|
|
|
|
|
|
get_work_fn *get_work;
|
|
|
|
put_work_fn *put_work;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct io_wq *io_wq_create(unsigned bounded, struct io_wq_data *data);
|
2019-10-22 16:25:58 +00:00
|
|
|
void io_wq_destroy(struct io_wq *wq);
|
|
|
|
|
|
|
|
void io_wq_enqueue(struct io_wq *wq, struct io_wq_work *work);
|
|
|
|
void io_wq_enqueue_hashed(struct io_wq *wq, struct io_wq_work *work, void *val);
|
|
|
|
void io_wq_flush(struct io_wq *wq);
|
|
|
|
|
|
|
|
void io_wq_cancel_all(struct io_wq *wq);
|
|
|
|
enum io_wq_cancel io_wq_cancel_work(struct io_wq *wq, struct io_wq_work *cwork);
|
|
|
|
|
2019-10-29 03:49:21 +00:00
|
|
|
typedef bool (work_cancel_fn)(struct io_wq_work *, void *);
|
|
|
|
|
|
|
|
enum io_wq_cancel io_wq_cancel_cb(struct io_wq *wq, work_cancel_fn *cancel,
|
|
|
|
void *data);
|
|
|
|
|
2019-10-22 16:25:58 +00:00
|
|
|
#if defined(CONFIG_IO_WQ)
|
|
|
|
extern void io_wq_worker_sleeping(struct task_struct *);
|
|
|
|
extern void io_wq_worker_running(struct task_struct *);
|
|
|
|
#else
|
|
|
|
static inline void io_wq_worker_sleeping(struct task_struct *tsk)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
static inline void io_wq_worker_running(struct task_struct *tsk)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2019-11-12 14:56:39 +00:00
|
|
|
static inline bool io_wq_current_is_worker(void)
|
|
|
|
{
|
|
|
|
return in_task() && (current->flags & PF_IO_WORKER);
|
|
|
|
}
|
2019-10-22 16:25:58 +00:00
|
|
|
#endif
|