blob: 608e96de70a2c6f8fec3e644733daf4a09742e21 [file] [log] [blame]
Jens Axboec9f06aa2022-05-25 11:01:04 -06001// SPDX-License-Identifier: GPL-2.0
2
Jens Axboec9f06aa2022-05-25 11:01:04 -06003struct io_tctx_node {
4 struct list_head ctx_node;
5 struct task_struct *task;
6 struct io_ring_ctx *ctx;
7};
8
9int io_uring_alloc_task_context(struct task_struct *task,
10 struct io_ring_ctx *ctx);
11void io_uring_del_tctx_node(unsigned long index);
Dylan Yudaken97c96e92022-09-26 10:09:26 -070012int __io_uring_add_tctx_node(struct io_ring_ctx *ctx);
13int __io_uring_add_tctx_node_from_submit(struct io_ring_ctx *ctx);
Jens Axboec9f06aa2022-05-25 11:01:04 -060014void io_uring_clean_tctx(struct io_uring_task *tctx);
15
16void io_uring_unreg_ringfd(void);
17int io_ringfd_register(struct io_ring_ctx *ctx, void __user *__arg,
18 unsigned nr_args);
19int io_ringfd_unregister(struct io_ring_ctx *ctx, void __user *__arg,
20 unsigned nr_args);
21
22/*
23 * Note that this task has used io_uring. We use it for cancelation purposes.
24 */
25static inline int io_uring_add_tctx_node(struct io_ring_ctx *ctx)
26{
27 struct io_uring_task *tctx = current->io_uring;
28
29 if (likely(tctx && tctx->last == ctx))
30 return 0;
Dylan Yudaken97c96e92022-09-26 10:09:26 -070031
32 return __io_uring_add_tctx_node_from_submit(ctx);
Jens Axboec9f06aa2022-05-25 11:01:04 -060033}