|
@@ -696,6 +696,27 @@ struct seq_operations diskstats_op = {
|
|
.show = diskstats_show
|
|
.show = diskstats_show
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static void media_change_notify_thread(struct work_struct *work)
|
|
|
|
+{
|
|
|
|
+ struct gendisk *gd = container_of(work, struct gendisk, async_notify);
|
|
|
|
+ char event[] = "MEDIA_CHANGE=1";
|
|
|
|
+ char *envp[] = { event, NULL };
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * set enviroment vars to indicate which event this is for
|
|
|
|
+ * so that user space will know to go check the media status.
|
|
|
|
+ */
|
|
|
|
+ kobject_uevent_env(&gd->kobj, KOBJ_CHANGE, envp);
|
|
|
|
+ put_device(gd->driverfs_dev);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void genhd_media_change_notify(struct gendisk *disk)
|
|
|
|
+{
|
|
|
|
+ get_device(disk->driverfs_dev);
|
|
|
|
+ schedule_work(&disk->async_notify);
|
|
|
|
+}
|
|
|
|
+EXPORT_SYMBOL_GPL(genhd_media_change_notify);
|
|
|
|
+
|
|
struct gendisk *alloc_disk(int minors)
|
|
struct gendisk *alloc_disk(int minors)
|
|
{
|
|
{
|
|
return alloc_disk_node(minors, -1);
|
|
return alloc_disk_node(minors, -1);
|
|
@@ -725,6 +746,8 @@ struct gendisk *alloc_disk_node(int minors, int node_id)
|
|
kobj_set_kset_s(disk,block_subsys);
|
|
kobj_set_kset_s(disk,block_subsys);
|
|
kobject_init(&disk->kobj);
|
|
kobject_init(&disk->kobj);
|
|
rand_initialize_disk(disk);
|
|
rand_initialize_disk(disk);
|
|
|
|
+ INIT_WORK(&disk->async_notify,
|
|
|
|
+ media_change_notify_thread);
|
|
}
|
|
}
|
|
return disk;
|
|
return disk;
|
|
}
|
|
}
|