diff options
Diffstat (limited to 'fs/super.c')
-rw-r--r-- | fs/super.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/fs/super.c b/fs/super.c index f31ef824d069..400a7608f15e 100644 --- a/fs/super.c +++ b/fs/super.c | |||
@@ -755,9 +755,13 @@ int get_sb_bdev(struct file_system_type *fs_type, | |||
755 | { | 755 | { |
756 | struct block_device *bdev; | 756 | struct block_device *bdev; |
757 | struct super_block *s; | 757 | struct super_block *s; |
758 | fmode_t mode = FMODE_READ; | ||
758 | int error = 0; | 759 | int error = 0; |
759 | 760 | ||
760 | bdev = open_bdev_excl(dev_name, flags, fs_type); | 761 | if (!(flags & MS_RDONLY)) |
762 | mode |= FMODE_WRITE; | ||
763 | |||
764 | bdev = open_bdev_exclusive(dev_name, mode, fs_type); | ||
761 | if (IS_ERR(bdev)) | 765 | if (IS_ERR(bdev)) |
762 | return PTR_ERR(bdev); | 766 | return PTR_ERR(bdev); |
763 | 767 | ||
@@ -780,11 +784,12 @@ int get_sb_bdev(struct file_system_type *fs_type, | |||
780 | goto error_bdev; | 784 | goto error_bdev; |
781 | } | 785 | } |
782 | 786 | ||
783 | close_bdev_excl(bdev); | 787 | close_bdev_exclusive(bdev, mode); |
784 | } else { | 788 | } else { |
785 | char b[BDEVNAME_SIZE]; | 789 | char b[BDEVNAME_SIZE]; |
786 | 790 | ||
787 | s->s_flags = flags; | 791 | s->s_flags = flags; |
792 | s->s_mode = mode; | ||
788 | strlcpy(s->s_id, bdevname(bdev, b), sizeof(s->s_id)); | 793 | strlcpy(s->s_id, bdevname(bdev, b), sizeof(s->s_id)); |
789 | sb_set_blocksize(s, block_size(bdev)); | 794 | sb_set_blocksize(s, block_size(bdev)); |
790 | error = fill_super(s, data, flags & MS_SILENT ? 1 : 0); | 795 | error = fill_super(s, data, flags & MS_SILENT ? 1 : 0); |
@@ -802,7 +807,7 @@ int get_sb_bdev(struct file_system_type *fs_type, | |||
802 | error_s: | 807 | error_s: |
803 | error = PTR_ERR(s); | 808 | error = PTR_ERR(s); |
804 | error_bdev: | 809 | error_bdev: |
805 | close_bdev_excl(bdev); | 810 | close_bdev_exclusive(bdev, mode); |
806 | error: | 811 | error: |
807 | return error; | 812 | return error; |
808 | } | 813 | } |
@@ -812,10 +817,11 @@ EXPORT_SYMBOL(get_sb_bdev); | |||
812 | void kill_block_super(struct super_block *sb) | 817 | void kill_block_super(struct super_block *sb) |
813 | { | 818 | { |
814 | struct block_device *bdev = sb->s_bdev; | 819 | struct block_device *bdev = sb->s_bdev; |
820 | fmode_t mode = sb->s_mode; | ||
815 | 821 | ||
816 | generic_shutdown_super(sb); | 822 | generic_shutdown_super(sb); |
817 | sync_blockdev(bdev); | 823 | sync_blockdev(bdev); |
818 | close_bdev_excl(bdev); | 824 | close_bdev_exclusive(bdev, mode); |
819 | } | 825 | } |
820 | 826 | ||
821 | EXPORT_SYMBOL(kill_block_super); | 827 | EXPORT_SYMBOL(kill_block_super); |