Commit 5bb53c0f authored by Andrey Ryabinin's avatar Andrey Ryabinin Committed by Jens Axboe

fs/block_dev: fix potential NULL ptr deref in freeze_bdev()

Calling freeze_bdev() twice on the same block device without mounted
filesystem get_super() will return NULL, which will lead to NULL-ptr
dereference later in drop_super().

Check get_super() result to fix that.

Note, that this is a purely theoretical issue. We have only 3
freeze_bdev() callers. 2 of them are in filesystem code and used on a
device with mounted fs. The third one in lock_fs() has protection in
upper-layer code against freezing block device the second time without
thawing it first.
Signed-off-by: default avatarAndrey Ryabinin <aryabinin@virtuozzo.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarJens Axboe <axboe@fb.com>
parent 0e87e58b
...@@ -249,6 +249,7 @@ struct super_block *freeze_bdev(struct block_device *bdev) ...@@ -249,6 +249,7 @@ struct super_block *freeze_bdev(struct block_device *bdev)
* thaw_bdev drops it. * thaw_bdev drops it.
*/ */
sb = get_super(bdev); sb = get_super(bdev);
if (sb)
drop_super(sb); drop_super(sb);
mutex_unlock(&bdev->bd_fsfreeze_mutex); mutex_unlock(&bdev->bd_fsfreeze_mutex);
return sb; return sb;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment