]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
pnfs/blocklayout: Fix memory leak in bl_parse_scsi()
authorZilin Guan <zilin@seu.edu.cn>
Thu, 25 Dec 2025 08:45:26 +0000 (08:45 +0000)
committerTrond Myklebust <trond.myklebust@hammerspace.com>
Mon, 5 Jan 2026 04:03:25 +0000 (23:03 -0500)
In bl_parse_scsi(), if the block device length is zero, the function
returns immediately without releasing the file reference obtained via
bl_open_path(), leading to a memory leak.

Fix this by jumping to the out_blkdev_put label to ensure the file
reference is properly released.

Fixes: d76c769c8db4c ("pnfs/blocklayout: Don't add zero-length pnfs_block_dev")
Signed-off-by: Zilin Guan <zilin@seu.edu.cn>
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
fs/nfs/blocklayout/dev.c

index ab76120705e206c2b079bcbb9678e9f0e3511cb1..134d7f760a33a6220838753232639954228e44bc 100644 (file)
@@ -417,8 +417,10 @@ bl_parse_scsi(struct nfs_server *server, struct pnfs_block_dev *d,
        d->map = bl_map_simple;
        d->pr_key = v->scsi.pr_key;
 
-       if (d->len == 0)
-               return -ENODEV;
+       if (d->len == 0) {
+               error = -ENODEV;
+               goto out_blkdev_put;
+       }
 
        ops = bdev->bd_disk->fops->pr_ops;
        if (!ops) {