|
@@ -245,6 +245,25 @@ void nvme_mpath_add_disk(struct nvme_ns_head *head)
|
|
|
head->disk->disk_name);
|
|
|
}
|
|
|
|
|
|
+void nvme_mpath_add_disk_links(struct nvme_ns *ns)
|
|
|
+{
|
|
|
+ struct kobject *slave_disk_kobj, *holder_disk_kobj;
|
|
|
+
|
|
|
+ if (!ns->head->disk)
|
|
|
+ return;
|
|
|
+
|
|
|
+ slave_disk_kobj = &disk_to_dev(ns->disk)->kobj;
|
|
|
+ if (sysfs_create_link(ns->head->disk->slave_dir, slave_disk_kobj,
|
|
|
+ kobject_name(slave_disk_kobj)))
|
|
|
+ return;
|
|
|
+
|
|
|
+ holder_disk_kobj = &disk_to_dev(ns->head->disk)->kobj;
|
|
|
+ if (sysfs_create_link(ns->disk->part0.holder_dir, holder_disk_kobj,
|
|
|
+ kobject_name(holder_disk_kobj)))
|
|
|
+ sysfs_remove_link(ns->head->disk->slave_dir,
|
|
|
+ kobject_name(slave_disk_kobj));
|
|
|
+}
|
|
|
+
|
|
|
void nvme_mpath_remove_disk(struct nvme_ns_head *head)
|
|
|
{
|
|
|
if (!head->disk)
|
|
@@ -259,3 +278,14 @@ void nvme_mpath_remove_disk(struct nvme_ns_head *head)
|
|
|
blk_cleanup_queue(head->disk->queue);
|
|
|
put_disk(head->disk);
|
|
|
}
|
|
|
+
|
|
|
+void nvme_mpath_remove_disk_links(struct nvme_ns *ns)
|
|
|
+{
|
|
|
+ if (!ns->head->disk)
|
|
|
+ return;
|
|
|
+
|
|
|
+ sysfs_remove_link(ns->disk->part0.holder_dir,
|
|
|
+ kobject_name(&disk_to_dev(ns->head->disk)->kobj));
|
|
|
+ sysfs_remove_link(ns->head->disk->slave_dir,
|
|
|
+ kobject_name(&disk_to_dev(ns->disk)->kobj));
|
|
|
+}
|