Commit c899a5d7 authored by Pavel Begunkov's avatar Pavel Begunkov Committed by Jens Axboe

io_uring/rsrc: refactor io_queue_rsrc_removal

We can queue up a rsrc into a list in io_queue_rsrc_removal() while
allocating io_rsrc_put and so simplify the function.
Signed-off-by: default avatarPavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/36bd708ee25c0e2e7992dc19b17db166eea9ac40.1681395792.git.asml.silence@gmail.comSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent c87fd583
...@@ -685,7 +685,6 @@ int io_queue_rsrc_removal(struct io_rsrc_data *data, unsigned idx, ...@@ -685,7 +685,6 @@ int io_queue_rsrc_removal(struct io_rsrc_data *data, unsigned idx,
{ {
u64 *tag_slot = io_get_tag_slot(data, idx); u64 *tag_slot = io_get_tag_slot(data, idx);
struct io_rsrc_put *prsrc; struct io_rsrc_put *prsrc;
bool inline_item = true;
if (!node->inline_items) { if (!node->inline_items) {
prsrc = &node->item; prsrc = &node->item;
...@@ -694,14 +693,12 @@ int io_queue_rsrc_removal(struct io_rsrc_data *data, unsigned idx, ...@@ -694,14 +693,12 @@ int io_queue_rsrc_removal(struct io_rsrc_data *data, unsigned idx,
prsrc = kzalloc(sizeof(*prsrc), GFP_KERNEL); prsrc = kzalloc(sizeof(*prsrc), GFP_KERNEL);
if (!prsrc) if (!prsrc)
return -ENOMEM; return -ENOMEM;
inline_item = false; list_add(&prsrc->list, &node->item_list);
} }
prsrc->tag = *tag_slot; prsrc->tag = *tag_slot;
*tag_slot = 0; *tag_slot = 0;
prsrc->rsrc = rsrc; prsrc->rsrc = rsrc;
if (!inline_item)
list_add(&prsrc->list, &node->item_list);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment