mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
loop: Push loop_ctl_mutex down to loop_set_fd()
Push lo_ctl_mutex down to loop_set_fd(). We will need this to be able to call loop_reread_partitions() without lo_ctl_mutex. Signed-off-by: Jan Kara <jack@suse.cz> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
550df5fdac
commit
757ecf40b7
@ -918,13 +918,17 @@ static int loop_set_fd(struct loop_device *lo, fmode_t mode,
|
|||||||
if (!file)
|
if (!file)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
error = mutex_lock_killable_nested(&loop_ctl_mutex, 1);
|
||||||
|
if (error)
|
||||||
|
goto out_putf;
|
||||||
|
|
||||||
error = -EBUSY;
|
error = -EBUSY;
|
||||||
if (lo->lo_state != Lo_unbound)
|
if (lo->lo_state != Lo_unbound)
|
||||||
goto out_putf;
|
goto out_unlock;
|
||||||
|
|
||||||
error = loop_validate_file(file, bdev);
|
error = loop_validate_file(file, bdev);
|
||||||
if (error)
|
if (error)
|
||||||
goto out_putf;
|
goto out_unlock;
|
||||||
|
|
||||||
mapping = file->f_mapping;
|
mapping = file->f_mapping;
|
||||||
inode = mapping->host;
|
inode = mapping->host;
|
||||||
@ -936,10 +940,10 @@ static int loop_set_fd(struct loop_device *lo, fmode_t mode,
|
|||||||
error = -EFBIG;
|
error = -EFBIG;
|
||||||
size = get_loop_size(lo, file);
|
size = get_loop_size(lo, file);
|
||||||
if ((loff_t)(sector_t)size != size)
|
if ((loff_t)(sector_t)size != size)
|
||||||
goto out_putf;
|
goto out_unlock;
|
||||||
error = loop_prepare_queue(lo);
|
error = loop_prepare_queue(lo);
|
||||||
if (error)
|
if (error)
|
||||||
goto out_putf;
|
goto out_unlock;
|
||||||
|
|
||||||
error = 0;
|
error = 0;
|
||||||
|
|
||||||
@ -978,11 +982,14 @@ static int loop_set_fd(struct loop_device *lo, fmode_t mode,
|
|||||||
* put /dev/loopXX inode. Later in __loop_clr_fd() we bdput(bdev).
|
* put /dev/loopXX inode. Later in __loop_clr_fd() we bdput(bdev).
|
||||||
*/
|
*/
|
||||||
bdgrab(bdev);
|
bdgrab(bdev);
|
||||||
|
mutex_unlock(&loop_ctl_mutex);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
out_putf:
|
out_unlock:
|
||||||
|
mutex_unlock(&loop_ctl_mutex);
|
||||||
|
out_putf:
|
||||||
fput(file);
|
fput(file);
|
||||||
out:
|
out:
|
||||||
/* This is safe: open() is still holding a reference. */
|
/* This is safe: open() is still holding a reference. */
|
||||||
module_put(THIS_MODULE);
|
module_put(THIS_MODULE);
|
||||||
return error;
|
return error;
|
||||||
@ -1460,12 +1467,7 @@ static int lo_ioctl(struct block_device *bdev, fmode_t mode,
|
|||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case LOOP_SET_FD:
|
case LOOP_SET_FD:
|
||||||
err = mutex_lock_killable_nested(&loop_ctl_mutex, 1);
|
return loop_set_fd(lo, mode, bdev, arg);
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
err = loop_set_fd(lo, mode, bdev, arg);
|
|
||||||
mutex_unlock(&loop_ctl_mutex);
|
|
||||||
break;
|
|
||||||
case LOOP_CHANGE_FD:
|
case LOOP_CHANGE_FD:
|
||||||
err = mutex_lock_killable_nested(&loop_ctl_mutex, 1);
|
err = mutex_lock_killable_nested(&loop_ctl_mutex, 1);
|
||||||
if (err)
|
if (err)
|
||||||
|
Loading…
Reference in New Issue
Block a user