| // SPDX-License-Identifier: GPL-2.0 |
| |
| struct io_tctx_node { |
| struct list_head ctx_node; |
| struct task_struct *task; |
| struct io_ring_ctx *ctx; |
| }; |
| |
| int io_uring_alloc_task_context(struct task_struct *task, |
| struct io_ring_ctx *ctx); |
| void io_uring_del_tctx_node(unsigned long index); |
| int __io_uring_add_tctx_node(struct io_ring_ctx *ctx); |
| int __io_uring_add_tctx_node_from_submit(struct io_ring_ctx *ctx); |
| void io_uring_clean_tctx(struct io_uring_task *tctx); |
| |
| void io_uring_unreg_ringfd(void); |
| int io_ringfd_register(struct io_ring_ctx *ctx, void __user *__arg, |
| unsigned nr_args); |
| int io_ringfd_unregister(struct io_ring_ctx *ctx, void __user *__arg, |
| unsigned nr_args); |
| |
| /* |
| * Note that this task has used io_uring. We use it for cancelation purposes. |
| */ |
| static inline int io_uring_add_tctx_node(struct io_ring_ctx *ctx) |
| { |
| struct io_uring_task *tctx = current->io_uring; |
| |
| if (likely(tctx && tctx->last == ctx)) |
| return 0; |
| |
| return __io_uring_add_tctx_node_from_submit(ctx); |
| } |