diff options
Diffstat (limited to 'fs/btrfs/super.c')
-rw-r--r-- | fs/btrfs/super.c | 41 |
1 files changed, 15 insertions, 26 deletions
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c index 1866dff0538e..f2393b390318 100644 --- a/fs/btrfs/super.c +++ b/fs/btrfs/super.c | |||
@@ -360,6 +360,8 @@ static struct dentry *get_default_root(struct super_block *sb, | |||
360 | */ | 360 | */ |
361 | dir_id = btrfs_super_root_dir(&root->fs_info->super_copy); | 361 | dir_id = btrfs_super_root_dir(&root->fs_info->super_copy); |
362 | di = btrfs_lookup_dir_item(NULL, root, path, dir_id, "default", 7, 0); | 362 | di = btrfs_lookup_dir_item(NULL, root, path, dir_id, "default", 7, 0); |
363 | if (IS_ERR(di)) | ||
364 | return ERR_CAST(di); | ||
363 | if (!di) { | 365 | if (!di) { |
364 | /* | 366 | /* |
365 | * Ok the default dir item isn't there. This is weird since | 367 | * Ok the default dir item isn't there. This is weird since |
@@ -390,8 +392,8 @@ setup_root: | |||
390 | location.offset = 0; | 392 | location.offset = 0; |
391 | 393 | ||
392 | inode = btrfs_iget(sb, &location, new_root, &new); | 394 | inode = btrfs_iget(sb, &location, new_root, &new); |
393 | if (!inode) | 395 | if (IS_ERR(inode)) |
394 | return ERR_PTR(-ENOMEM); | 396 | return ERR_CAST(inode); |
395 | 397 | ||
396 | /* | 398 | /* |
397 | * If we're just mounting the root most subvol put the inode and return | 399 | * If we're just mounting the root most subvol put the inode and return |
@@ -498,7 +500,7 @@ int btrfs_sync_fs(struct super_block *sb, int wait) | |||
498 | btrfs_start_delalloc_inodes(root, 0); | 500 | btrfs_start_delalloc_inodes(root, 0); |
499 | btrfs_wait_ordered_extents(root, 0, 0); | 501 | btrfs_wait_ordered_extents(root, 0, 0); |
500 | 502 | ||
501 | trans = btrfs_start_transaction(root, 1); | 503 | trans = btrfs_start_transaction(root, 0); |
502 | ret = btrfs_commit_transaction(trans, root); | 504 | ret = btrfs_commit_transaction(trans, root); |
503 | return ret; | 505 | return ret; |
504 | } | 506 | } |
@@ -694,11 +696,11 @@ static int btrfs_remount(struct super_block *sb, int *flags, char *data) | |||
694 | if (btrfs_super_log_root(&root->fs_info->super_copy) != 0) | 696 | if (btrfs_super_log_root(&root->fs_info->super_copy) != 0) |
695 | return -EINVAL; | 697 | return -EINVAL; |
696 | 698 | ||
697 | /* recover relocation */ | 699 | ret = btrfs_cleanup_fs_roots(root->fs_info); |
698 | ret = btrfs_recover_relocation(root); | ||
699 | WARN_ON(ret); | 700 | WARN_ON(ret); |
700 | 701 | ||
701 | ret = btrfs_cleanup_fs_roots(root->fs_info); | 702 | /* recover relocation */ |
703 | ret = btrfs_recover_relocation(root); | ||
702 | WARN_ON(ret); | 704 | WARN_ON(ret); |
703 | 705 | ||
704 | sb->s_flags &= ~MS_RDONLY; | 706 | sb->s_flags &= ~MS_RDONLY; |
@@ -714,34 +716,18 @@ static int btrfs_statfs(struct dentry *dentry, struct kstatfs *buf) | |||
714 | struct list_head *head = &root->fs_info->space_info; | 716 | struct list_head *head = &root->fs_info->space_info; |
715 | struct btrfs_space_info *found; | 717 | struct btrfs_space_info *found; |
716 | u64 total_used = 0; | 718 | u64 total_used = 0; |
717 | u64 data_used = 0; | ||
718 | int bits = dentry->d_sb->s_blocksize_bits; | 719 | int bits = dentry->d_sb->s_blocksize_bits; |
719 | __be32 *fsid = (__be32 *)root->fs_info->fsid; | 720 | __be32 *fsid = (__be32 *)root->fs_info->fsid; |
720 | 721 | ||
721 | rcu_read_lock(); | 722 | rcu_read_lock(); |
722 | list_for_each_entry_rcu(found, head, list) { | 723 | list_for_each_entry_rcu(found, head, list) |
723 | if (found->flags & (BTRFS_BLOCK_GROUP_DUP| | 724 | total_used += found->disk_used; |
724 | BTRFS_BLOCK_GROUP_RAID10| | ||
725 | BTRFS_BLOCK_GROUP_RAID1)) { | ||
726 | total_used += found->bytes_used; | ||
727 | if (found->flags & BTRFS_BLOCK_GROUP_DATA) | ||
728 | data_used += found->bytes_used; | ||
729 | else | ||
730 | data_used += found->total_bytes; | ||
731 | } | ||
732 | |||
733 | total_used += found->bytes_used; | ||
734 | if (found->flags & BTRFS_BLOCK_GROUP_DATA) | ||
735 | data_used += found->bytes_used; | ||
736 | else | ||
737 | data_used += found->total_bytes; | ||
738 | } | ||
739 | rcu_read_unlock(); | 725 | rcu_read_unlock(); |
740 | 726 | ||
741 | buf->f_namelen = BTRFS_NAME_LEN; | 727 | buf->f_namelen = BTRFS_NAME_LEN; |
742 | buf->f_blocks = btrfs_super_total_bytes(disk_super) >> bits; | 728 | buf->f_blocks = btrfs_super_total_bytes(disk_super) >> bits; |
743 | buf->f_bfree = buf->f_blocks - (total_used >> bits); | 729 | buf->f_bfree = buf->f_blocks - (total_used >> bits); |
744 | buf->f_bavail = buf->f_blocks - (data_used >> bits); | 730 | buf->f_bavail = buf->f_bfree; |
745 | buf->f_bsize = dentry->d_sb->s_blocksize; | 731 | buf->f_bsize = dentry->d_sb->s_blocksize; |
746 | buf->f_type = BTRFS_SUPER_MAGIC; | 732 | buf->f_type = BTRFS_SUPER_MAGIC; |
747 | 733 | ||
@@ -832,11 +818,14 @@ static const struct file_operations btrfs_ctl_fops = { | |||
832 | }; | 818 | }; |
833 | 819 | ||
834 | static struct miscdevice btrfs_misc = { | 820 | static struct miscdevice btrfs_misc = { |
835 | .minor = MISC_DYNAMIC_MINOR, | 821 | .minor = BTRFS_MINOR, |
836 | .name = "btrfs-control", | 822 | .name = "btrfs-control", |
837 | .fops = &btrfs_ctl_fops | 823 | .fops = &btrfs_ctl_fops |
838 | }; | 824 | }; |
839 | 825 | ||
826 | MODULE_ALIAS_MISCDEV(BTRFS_MINOR); | ||
827 | MODULE_ALIAS("devname:btrfs-control"); | ||
828 | |||
840 | static int btrfs_interface_init(void) | 829 | static int btrfs_interface_init(void) |
841 | { | 830 | { |
842 | return misc_register(&btrfs_misc); | 831 | return misc_register(&btrfs_misc); |