#include <linux/kernel.h>
#include <linux/errno.h>
#include <linux/file.h>
#include <linux/mm.h>
#include <linux/slab.h>
#include <linux/audit.h>
#include <linux/security.h>
#include <linux/cpuset.h>
#include <linux/io_uring.h>
#include <uapi/linux/io_uring.h>
#include "io_uring.h"
#include "napi.h"
#include "sqpoll.h"
#define IORING_SQPOLL_CAP_ENTRIES_VALUE …
#define IORING_TW_CAP_ENTRIES_VALUE …
enum { … };
void io_sq_thread_unpark(struct io_sq_data *sqd)
__releases(&sqd->lock)
{ … }
void io_sq_thread_park(struct io_sq_data *sqd)
__acquires(&sqd->lock)
{ … }
void io_sq_thread_stop(struct io_sq_data *sqd)
{ … }
void io_put_sq_data(struct io_sq_data *sqd)
{ … }
static __cold void io_sqd_update_thread_idle(struct io_sq_data *sqd)
{ … }
void io_sq_thread_finish(struct io_ring_ctx *ctx)
{ … }
static struct io_sq_data *io_attach_sq_data(struct io_uring_params *p)
{ … }
static struct io_sq_data *io_get_sq_data(struct io_uring_params *p,
bool *attached)
{ … }
static inline bool io_sqd_events_pending(struct io_sq_data *sqd)
{ … }
static int __io_sq_thread(struct io_ring_ctx *ctx, bool cap_entries)
{ … }
static bool io_sqd_handle_event(struct io_sq_data *sqd)
{ … }
static unsigned int io_sq_tw(struct llist_node **retry_list, int max_entries)
{ … }
static bool io_sq_tw_pending(struct llist_node *retry_list)
{ … }
static void io_sq_update_worktime(struct io_sq_data *sqd, struct rusage *start)
{ … }
static int io_sq_thread(void *data)
{ … }
void io_sqpoll_wait_sq(struct io_ring_ctx *ctx)
{ … }
__cold int io_sq_offload_create(struct io_ring_ctx *ctx,
struct io_uring_params *p)
{ … }
__cold int io_sqpoll_wq_cpu_affinity(struct io_ring_ctx *ctx,
cpumask_var_t mask)
{ … }