summaryrefslogtreecommitdiff
path: root/fs
diff options
context:
space:
mode:
authorZilin Guan <zilin@seu.edu.cn>2025-12-25 08:45:26 +0000
committerTrond Myklebust <trond.myklebust@hammerspace.com>2026-01-04 23:03:25 -0500
commit5a74af51c3a6f4cd22c128b0c1c019f68fa90011 (patch)
treeca2679c845bff754bb06e4ab1f017b2c3b7771a6 /fs
parent0c728083654f0066f5e10a1d2b0bd0907af19a58 (diff)
pnfs/blocklayout: Fix memory leak in bl_parse_scsi()
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>
Diffstat (limited to 'fs')
-rw-r--r--fs/nfs/blocklayout/dev.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/fs/nfs/blocklayout/dev.c b/fs/nfs/blocklayout/dev.c
index ab76120705e2..134d7f760a33 100644
--- a/fs/nfs/blocklayout/dev.c
+++ b/fs/nfs/blocklayout/dev.c
@@ -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) {