Skip to content

Commit 1e111c4

Browse files
Yang Xiuweimartinkpetersen
authored andcommitted
scsi: sd: fix missing put_disk() when device_add(&disk_dev) fails
If device_add(&sdkp->disk_dev) fails, put_device() runs scsi_disk_release(), which frees the scsi_disk but leaves the gendisk referenced. The device_add_disk() error path in sd_probe() calls put_disk(gd); call put_disk(gd) here to mirror that cleanup. Fixes: 265dfe8 ("scsi: sd: Free scsi_disk device via put_device()") Cc: stable@vger.kernel.org Reviewed-by: John Garry <john.g.garry@oracle.com> Signed-off-by: Yang Xiuwei <yangxiuwei@kylinos.cn> Link: https://patch.msgid.link/20260330014952.152776-1-yangxiuwei@kylinos.cn Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
1 parent 1a2f619 commit 1e111c4

1 file changed

Lines changed: 1 addition & 0 deletions

File tree

drivers/scsi/sd.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4061,6 +4061,7 @@ static int sd_probe(struct scsi_device *sdp)
40614061
error = device_add(&sdkp->disk_dev);
40624062
if (error) {
40634063
put_device(&sdkp->disk_dev);
4064+
put_disk(gd);
40644065
goto out;
40654066
}
40664067

0 commit comments

Comments
 (0)