Commit d356b3cd authored by Sandeep Dhavale's avatar Sandeep Dhavale Committed by Greg Kroah-Hartman

usb: gadget: f_fs: Fix ffs_epfile_read_iter to handle ITER_UBUF

iov_iter for ffs_epfile_read_iter can be ITER_UBUF with io_uring.
In that case dup_iter() does not have to allocate anything and it
can return NULL. ffs_epfile_read_iter treats this as a failure and
returns -ENOMEM. Fix it by checking if iter_is_ubuf().

Fixes: 1e23db45 ("io_uring: use iter_ubuf for single range imports")
Signed-off-by: default avatarSandeep Dhavale <dhavale@google.com>
Acked-by: default avatarJens Axboe <axboe@kernel.dk>
Link: https://lore.kernel.org/r/20230401060509.3608259-2-dhavale@google.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent eddebe39
...@@ -1251,7 +1251,7 @@ static ssize_t ffs_epfile_read_iter(struct kiocb *kiocb, struct iov_iter *to) ...@@ -1251,7 +1251,7 @@ static ssize_t ffs_epfile_read_iter(struct kiocb *kiocb, struct iov_iter *to)
p->kiocb = kiocb; p->kiocb = kiocb;
if (p->aio) { if (p->aio) {
p->to_free = dup_iter(&p->data, to, GFP_KERNEL); p->to_free = dup_iter(&p->data, to, GFP_KERNEL);
if (!p->to_free) { if (!iter_is_ubuf(&p->data) && !p->to_free) {
kfree(p); kfree(p);
return -ENOMEM; return -ENOMEM;
} }
......
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