aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorAnand Jain <Anand.Jain@oracle.com>2014-06-02 23:36:01 -0400
committerChris Mason <clm@fb.com>2014-06-28 16:48:43 -0400
commit0d39376aa28eba6d63d0120ccc399735842abc8e (patch)
treed588573634e0af59e6fc330d32ead6d53a18ac2c /fs
parent99994cde9c59c2b8bb67d46d531b26cc73e39747 (diff)
btrfs: dev add should add its sysfs entry
we would need the device links to be created, when device is added. Signed-off-by: Anand Jain <Anand.Jain@oracle.com> Reviewed-by: David Sterba <dsterba@suse.cz> Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/btrfs/sysfs.c12
-rw-r--r--fs/btrfs/sysfs.h2
-rw-r--r--fs/btrfs/volumes.c5
3 files changed, 16 insertions, 3 deletions
diff --git a/fs/btrfs/sysfs.c b/fs/btrfs/sysfs.c
index 401677b11045..78699364f537 100644
--- a/fs/btrfs/sysfs.c
+++ b/fs/btrfs/sysfs.c
@@ -625,14 +625,17 @@ int btrfs_kobj_rm_device(struct btrfs_fs_info *fs_info,
625 return 0; 625 return 0;
626} 626}
627 627
628static int btrfs_kobj_add_device(struct btrfs_fs_info *fs_info) 628int btrfs_kobj_add_device(struct btrfs_fs_info *fs_info,
629 struct btrfs_device *one_device)
629{ 630{
630 int error = 0; 631 int error = 0;
631 struct btrfs_fs_devices *fs_devices = fs_info->fs_devices; 632 struct btrfs_fs_devices *fs_devices = fs_info->fs_devices;
632 struct btrfs_device *dev; 633 struct btrfs_device *dev;
633 634
634 fs_info->device_dir_kobj = kobject_create_and_add("devices", 635 if (!fs_info->device_dir_kobj)
636 fs_info->device_dir_kobj = kobject_create_and_add("devices",
635 &fs_info->super_kobj); 637 &fs_info->super_kobj);
638
636 if (!fs_info->device_dir_kobj) 639 if (!fs_info->device_dir_kobj)
637 return -ENOMEM; 640 return -ENOMEM;
638 641
@@ -643,6 +646,9 @@ static int btrfs_kobj_add_device(struct btrfs_fs_info *fs_info)
643 if (!dev->bdev) 646 if (!dev->bdev)
644 continue; 647 continue;
645 648
649 if (one_device && one_device != dev)
650 continue;
651
646 disk = dev->bdev->bd_part; 652 disk = dev->bdev->bd_part;
647 disk_kobj = &part_to_dev(disk)->kobj; 653 disk_kobj = &part_to_dev(disk)->kobj;
648 654
@@ -686,7 +692,7 @@ int btrfs_sysfs_add_one(struct btrfs_fs_info *fs_info)
686 if (error) 692 if (error)
687 goto failure; 693 goto failure;
688 694
689 error = btrfs_kobj_add_device(fs_info); 695 error = btrfs_kobj_add_device(fs_info, NULL);
690 if (error) 696 if (error)
691 goto failure; 697 goto failure;
692 698
diff --git a/fs/btrfs/sysfs.h b/fs/btrfs/sysfs.h
index 529554e5f9de..ac46df37504c 100644
--- a/fs/btrfs/sysfs.h
+++ b/fs/btrfs/sysfs.h
@@ -66,6 +66,8 @@ char *btrfs_printable_features(enum btrfs_feature_set set, u64 flags);
66extern const char * const btrfs_feature_set_names[3]; 66extern const char * const btrfs_feature_set_names[3];
67extern struct kobj_type space_info_ktype; 67extern struct kobj_type space_info_ktype;
68extern struct kobj_type btrfs_raid_ktype; 68extern struct kobj_type btrfs_raid_ktype;
69int btrfs_kobj_add_device(struct btrfs_fs_info *fs_info,
70 struct btrfs_device *one_device);
69int btrfs_kobj_rm_device(struct btrfs_fs_info *fs_info, 71int btrfs_kobj_rm_device(struct btrfs_fs_info *fs_info,
70 struct btrfs_device *one_device); 72 struct btrfs_device *one_device);
71#endif /* _BTRFS_SYSFS_H_ */ 73#endif /* _BTRFS_SYSFS_H_ */
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c
index be2c8e285afb..19b67e969b52 100644
--- a/fs/btrfs/volumes.c
+++ b/fs/btrfs/volumes.c
@@ -2147,6 +2147,10 @@ int btrfs_init_new_device(struct btrfs_root *root, char *device_path)
2147 total_bytes = btrfs_super_num_devices(root->fs_info->super_copy); 2147 total_bytes = btrfs_super_num_devices(root->fs_info->super_copy);
2148 btrfs_set_super_num_devices(root->fs_info->super_copy, 2148 btrfs_set_super_num_devices(root->fs_info->super_copy,
2149 total_bytes + 1); 2149 total_bytes + 1);
2150
2151 /* add sysfs device entry */
2152 btrfs_kobj_add_device(root->fs_info, device);
2153
2150 mutex_unlock(&root->fs_info->fs_devices->device_list_mutex); 2154 mutex_unlock(&root->fs_info->fs_devices->device_list_mutex);
2151 2155
2152 if (seeding_dev) { 2156 if (seeding_dev) {
@@ -2209,6 +2213,7 @@ error_trans:
2209 unlock_chunks(root); 2213 unlock_chunks(root);
2210 btrfs_end_transaction(trans, root); 2214 btrfs_end_transaction(trans, root);
2211 rcu_string_free(device->name); 2215 rcu_string_free(device->name);
2216 btrfs_kobj_rm_device(root->fs_info, device);
2212 kfree(device); 2217 kfree(device);
2213error: 2218error:
2214 blkdev_put(bdev, FMODE_EXCL); 2219 blkdev_put(bdev, FMODE_EXCL);