]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
scsi: sr: Fix sr_probe() missing deallocate of device minor
authorSimon Arlott <simon@octiron.net>
Sat, 30 May 2020 17:59:44 +0000 (18:59 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 24 Jun 2020 15:48:31 +0000 (17:48 +0200)
[ Upstream commit 6555781b3fdec5e94e6914511496144241df7dee ]

If the cdrom fails to be registered then the device minor should be
deallocated.

Link: https://lore.kernel.org/r/072dac4b-8402-4de8-36bd-47e7588969cd@0882a8b5-c6c3-11e9-b005-00805fc181fe
Signed-off-by: Simon Arlott <simon@octiron.net>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/scsi/sr.c

index 8d062d4f3ce0b548cc9c7c957be4d4d33d5f0f72..1e13c6a0f0caf0d7e46f356a8d5627a95826f2d2 100644 (file)
@@ -797,7 +797,7 @@ static int sr_probe(struct device *dev)
        cd->cdi.disk = disk;
 
        if (register_cdrom(&cd->cdi))
-               goto fail_put;
+               goto fail_minor;
 
        /*
         * Initialize block layer runtime PM stuffs before the
@@ -815,6 +815,10 @@ static int sr_probe(struct device *dev)
 
        return 0;
 
+fail_minor:
+       spin_lock(&sr_index_lock);
+       clear_bit(minor, sr_index_bits);
+       spin_unlock(&sr_index_lock);
 fail_put:
        put_disk(disk);
        mutex_destroy(&cd->lock);