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, 25 Apr 2025 08:45:50 +0000 (10:45 +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 d84dacbdce2c9de254e286685e9746679537bbff..a6814bea0e0ad80c638405e8c5865550f34b78ee 100644 (file)
@@ -1430,6 +1430,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.