diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2009-05-08 13:36:58 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2009-06-11 21:36:08 -0400 |
commit | 4aa98cf768b6f2ea4b204620d949a665959214f6 (patch) | |
tree | dd6f5be97396b9e1f24a9697524da19463e7a8da | |
parent | 7f78d4cd4c5d01864943c22b79df1b6bde923129 (diff) |
Push BKL down into do_remount_sb()
[folded fix from Jiri Slaby]
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | fs/namespace.c | 10 | ||||
-rw-r--r-- | fs/super.c | 16 |
2 files changed, 13 insertions, 13 deletions
diff --git a/fs/namespace.c b/fs/namespace.c index b94325f00c5a..2dd333b0fe7f 100644 --- a/fs/namespace.c +++ b/fs/namespace.c | |||
@@ -1060,11 +1060,8 @@ static int do_umount(struct vfsmount *mnt, int flags) | |||
1060 | * we just try to remount it readonly. | 1060 | * we just try to remount it readonly. |
1061 | */ | 1061 | */ |
1062 | down_write(&sb->s_umount); | 1062 | down_write(&sb->s_umount); |
1063 | if (!(sb->s_flags & MS_RDONLY)) { | 1063 | if (!(sb->s_flags & MS_RDONLY)) |
1064 | lock_kernel(); | ||
1065 | retval = do_remount_sb(sb, MS_RDONLY, NULL, 0); | 1064 | retval = do_remount_sb(sb, MS_RDONLY, NULL, 0); |
1066 | unlock_kernel(); | ||
1067 | } | ||
1068 | up_write(&sb->s_umount); | 1065 | up_write(&sb->s_umount); |
1069 | return retval; | 1066 | return retval; |
1070 | } | 1067 | } |
@@ -1515,11 +1512,8 @@ static int do_remount(struct path *path, int flags, int mnt_flags, | |||
1515 | down_write(&sb->s_umount); | 1512 | down_write(&sb->s_umount); |
1516 | if (flags & MS_BIND) | 1513 | if (flags & MS_BIND) |
1517 | err = change_mount_flags(path->mnt, flags); | 1514 | err = change_mount_flags(path->mnt, flags); |
1518 | else { | 1515 | else |
1519 | lock_kernel(); | ||
1520 | err = do_remount_sb(sb, flags, data, 0); | 1516 | err = do_remount_sb(sb, flags, data, 0); |
1521 | unlock_kernel(); | ||
1522 | } | ||
1523 | if (!err) | 1517 | if (!err) |
1524 | path->mnt->mnt_flags = mnt_flags; | 1518 | path->mnt->mnt_flags = mnt_flags; |
1525 | up_write(&sb->s_umount); | 1519 | up_write(&sb->s_umount); |
diff --git a/fs/super.c b/fs/super.c index 2a49fed77453..a64f36208797 100644 --- a/fs/super.c +++ b/fs/super.c | |||
@@ -542,25 +542,33 @@ int do_remount_sb(struct super_block *sb, int flags, void *data, int force) | |||
542 | shrink_dcache_sb(sb); | 542 | shrink_dcache_sb(sb); |
543 | sync_filesystem(sb); | 543 | sync_filesystem(sb); |
544 | 544 | ||
545 | lock_kernel(); | ||
545 | /* If we are remounting RDONLY and current sb is read/write, | 546 | /* If we are remounting RDONLY and current sb is read/write, |
546 | make sure there are no rw files opened */ | 547 | make sure there are no rw files opened */ |
547 | if ((flags & MS_RDONLY) && !(sb->s_flags & MS_RDONLY)) { | 548 | if ((flags & MS_RDONLY) && !(sb->s_flags & MS_RDONLY)) { |
548 | if (force) | 549 | if (force) |
549 | mark_files_ro(sb); | 550 | mark_files_ro(sb); |
550 | else if (!fs_may_remount_ro(sb)) | 551 | else if (!fs_may_remount_ro(sb)) { |
552 | unlock_kernel(); | ||
551 | return -EBUSY; | 553 | return -EBUSY; |
554 | } | ||
552 | retval = vfs_dq_off(sb, 1); | 555 | retval = vfs_dq_off(sb, 1); |
553 | if (retval < 0 && retval != -ENOSYS) | 556 | if (retval < 0 && retval != -ENOSYS) { |
557 | unlock_kernel(); | ||
554 | return -EBUSY; | 558 | return -EBUSY; |
559 | } | ||
555 | } | 560 | } |
556 | remount_rw = !(flags & MS_RDONLY) && (sb->s_flags & MS_RDONLY); | 561 | remount_rw = !(flags & MS_RDONLY) && (sb->s_flags & MS_RDONLY); |
557 | 562 | ||
558 | if (sb->s_op->remount_fs) { | 563 | if (sb->s_op->remount_fs) { |
559 | retval = sb->s_op->remount_fs(sb, &flags, data); | 564 | retval = sb->s_op->remount_fs(sb, &flags, data); |
560 | if (retval) | 565 | if (retval) { |
566 | unlock_kernel(); | ||
561 | return retval; | 567 | return retval; |
568 | } | ||
562 | } | 569 | } |
563 | sb->s_flags = (sb->s_flags & ~MS_RMT_MASK) | (flags & MS_RMT_MASK); | 570 | sb->s_flags = (sb->s_flags & ~MS_RMT_MASK) | (flags & MS_RMT_MASK); |
571 | unlock_kernel(); | ||
564 | if (remount_rw) | 572 | if (remount_rw) |
565 | vfs_dq_quota_on_remount(sb); | 573 | vfs_dq_quota_on_remount(sb); |
566 | return 0; | 574 | return 0; |
@@ -581,9 +589,7 @@ static void do_emergency_remount(struct work_struct *work) | |||
581 | * | 589 | * |
582 | * What lock protects sb->s_flags?? | 590 | * What lock protects sb->s_flags?? |
583 | */ | 591 | */ |
584 | lock_kernel(); | ||
585 | do_remount_sb(sb, MS_RDONLY, NULL, 1); | 592 | do_remount_sb(sb, MS_RDONLY, NULL, 1); |
586 | unlock_kernel(); | ||
587 | } | 593 | } |
588 | up_write(&sb->s_umount); | 594 | up_write(&sb->s_umount); |
589 | put_super(sb); | 595 | put_super(sb); |