|  | // 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); | 
|  | } |