]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
fuse: Set *nbytesp=0 in fuse_get_user_pages on allocation failure
authorBernd Schubert <bschubert@ddn.com>
Mon, 2 Dec 2024 23:01:10 +0000 (00:01 +0100)
committerMiklos Szeredi <mszeredi@redhat.com>
Fri, 13 Dec 2024 15:43:36 +0000 (16:43 +0100)
In fuse_get_user_pages(), set *nbytesp to 0 when struct page **pages
allocation fails. This prevents the caller (fuse_direct_io) from making
incorrect assumptions that could lead to NULL pointer dereferences
when processing the request reply.

Previously, *nbytesp was left unmodified on allocation failure, which
could cause issues if the caller assumed pages had been added to
ap->descs[] when they hadn't.

Reported-by: syzbot+87b8e6ed25dbc41759f7@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=87b8e6ed25dbc41759f7
Fixes: 3b97c3652d91 ("fuse: convert direct io to use folios")
Signed-off-by: Bernd Schubert <bschubert@ddn.com>
Reviewed-by: Joanne Koong <joannelkoong@gmail.com>
Tested-by: Dmitry Antipov <dmantipov@yandex.ru>
Tested-by: David Howells <dhowells@redhat.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
fs/fuse/file.c

index 15b08d6a57398fd14e06878fde2f8245d835c2f3..7d92a547999858404cd7c38d423dbe2c7674fa66 100644 (file)
@@ -1541,8 +1541,10 @@ static int fuse_get_user_pages(struct fuse_args_pages *ap, struct iov_iter *ii,
         */
        struct page **pages = kzalloc(max_pages * sizeof(struct page *),
                                      GFP_KERNEL);
-       if (!pages)
-               return -ENOMEM;
+       if (!pages) {
+               ret = -ENOMEM;
+               goto out;
+       }
 
        while (nbytes < *nbytesp && nr_pages < max_pages) {
                unsigned nfolios, i;
@@ -1588,6 +1590,7 @@ static int fuse_get_user_pages(struct fuse_args_pages *ap, struct iov_iter *ii,
        else
                ap->args.out_pages = true;
 
+out:
        *nbytesp = nbytes;
 
        return ret < 0 ? ret : 0;