]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
virtiofs: add filesystem context source name check
authorXiangsheng Hou <xiangsheng.hou@mediatek.com>
Mon, 7 Apr 2025 11:50:49 +0000 (19:50 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 2 May 2025 05:41:02 +0000 (07:41 +0200)
commit a94fd938df2b1628da66b498aa0eeb89593bc7a2 upstream.

In certain scenarios, for example, during fuzz testing, the source
name may be NULL, which could lead to a kernel panic. Therefore, an
extra check for the source name should be added.

Fixes: a62a8ef9d97d ("virtio-fs: add virtiofs filesystem")
Cc: <stable@vger.kernel.org> # all LTS kernels
Signed-off-by: Xiangsheng Hou <xiangsheng.hou@mediatek.com>
Link: https://lore.kernel.org/20250407115111.25535-1-xiangsheng.hou@mediatek.com
Signed-off-by: Christian Brauner <brauner@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/fuse/virtio_fs.c

index c50999ad9f7abaadc121fc8344fc9ae8c4fa8a45..d405cdf36247c5bc20718cb7984045e7c228b8d3 100644 (file)
@@ -1447,6 +1447,9 @@ static int virtio_fs_get_tree(struct fs_context *fsc)
        unsigned int virtqueue_size;
        int err = -EIO;
 
+       if (!fsc->source)
+               return invalf(fsc, "No source specified");
+
        /* This gets a reference on virtio_fs object. This ptr gets installed
         * in fc->iq->priv. Once fuse_conn is going away, it calls ->put()
         * to drop the reference to this object.