summaryrefslogtreecommitdiff
path: root/block
diff options
context:
space:
mode:
authorDan Willemsen <dwillemsen@nvidia.com>2012-03-23 21:43:21 -0700
committerDan Willemsen <dwillemsen@nvidia.com>2012-03-23 21:43:21 -0700
commit9c6641224bdc2957f1d4ef692f027ff5e0fcc63b (patch)
tree589c55d8a24b79a5cfd2cb3379d1ce0cac9c7464 /block
parentc9134a33b3936ca9cae8bdc6dccd77e9c294f0ef (diff)
parent5275e74ae5e7e92b05bd1361e2573bb38d381358 (diff)
Merge commit '5275e74' into after-upstream-android
Conflicts: arch/arm/common/Kconfig arch/arm/mm/Makefile arch/arm/mm/cache-l2x0.c drivers/misc/Kconfig drivers/misc/Makefile drivers/mmc/core/core.c Signed-off-by: Dan Willemsen <dwillemsen@nvidia.com>
Diffstat (limited to 'block')
-rw-r--r--block/genhd.c17
-rw-r--r--block/partition-generic.c11
2 files changed, 28 insertions, 0 deletions
diff --git a/block/genhd.c b/block/genhd.c
index df9816ede75b..dba026281a3e 100644
--- a/block/genhd.c
+++ b/block/genhd.c
@@ -1107,6 +1107,22 @@ static void disk_release(struct device *dev)
blk_put_queue(disk->queue);
kfree(disk);
}
+
+static int disk_uevent(struct device *dev, struct kobj_uevent_env *env)
+{
+ struct gendisk *disk = dev_to_disk(dev);
+ struct disk_part_iter piter;
+ struct hd_struct *part;
+ int cnt = 0;
+
+ disk_part_iter_init(&piter, disk, 0);
+ while((part = disk_part_iter_next(&piter)))
+ cnt++;
+ disk_part_iter_exit(&piter);
+ add_uevent_var(env, "NPARTS=%u", cnt);
+ return 0;
+}
+
struct class block_class = {
.name = "block",
};
@@ -1125,6 +1141,7 @@ static struct device_type disk_type = {
.groups = disk_attr_groups,
.release = disk_release,
.devnode = block_devnode,
+ .uevent = disk_uevent,
};
#ifdef CONFIG_PROC_FS
diff --git a/block/partition-generic.c b/block/partition-generic.c
index 6df5d6928a44..803d1513f4c6 100644
--- a/block/partition-generic.c
+++ b/block/partition-generic.c
@@ -216,10 +216,21 @@ static void part_release(struct device *dev)
kfree(p);
}
+static int part_uevent(struct device *dev, struct kobj_uevent_env *env)
+{
+ struct hd_struct *part = dev_to_part(dev);
+
+ add_uevent_var(env, "PARTN=%u", part->partno);
+ if (part->info && part->info->volname[0])
+ add_uevent_var(env, "PARTNAME=%s", part->info->volname);
+ return 0;
+}
+
struct device_type part_type = {
.name = "partition",
.groups = part_attr_groups,
.release = part_release,
+ .uevent = part_uevent,
};
static void delete_partition_rcu_cb(struct rcu_head *head)