[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <200907211128.07252.knikanth@suse.de>
Date: Tue, 21 Jul 2009 11:28:07 +0530
From: Nikanth Karthikesan <knikanth@...e.de>
To: jens.axboe@...cle.com
Cc: Hannes Reinecke <hare@...e.de>, linux-kernel@...r.kernel.org,
Tejun Heo <tj@...nel.org>,
"device-mapper development" <dm-devel@...hat.com>
Subject: [RESEND][PATCH] Send uevents for disk write_protect changes
Hi
This patch is needed for the dm-multipath, so that the daemon can capture the
event and reload the dm table when the read-only setting of the disk changes.
Can this be merged?
Thanks
Nikanth
From: Hannes Reinecke <hare@...e.de>
Subject: Send uevents for write_protect changes
Whenever a block device changes it's read-only attribute
notify the userspace about it.
Signed-off-by: Hannes Reinecke <hare@...e.de>
Signed-off-by: Nikanth Karthikesan <knikanth@...e.de>
---
diff --git a/block/genhd.c b/block/genhd.c
index f4c64c2..b89328e 100644
--- a/block/genhd.c
+++ b/block/genhd.c
@@ -1215,6 +1215,16 @@ void put_disk(struct gendisk *disk)
EXPORT_SYMBOL(put_disk);
+static void set_disk_ro_uevent(struct gendisk *gd, int ro)
+{
+ char event[] = "DISK_RO=1";
+ char *envp[] = { event, NULL };
+
+ if (!ro)
+ event[8] = '0';
+ kobject_uevent_env(&disk_to_dev(gd)->kobj, KOBJ_CHANGE, envp);
+}
+
void set_device_ro(struct block_device *bdev, int flag)
{
bdev->bd_part->policy = flag;
@@ -1227,8 +1237,12 @@ void set_disk_ro(struct gendisk *disk, int flag)
struct disk_part_iter piter;
struct hd_struct *part;
- disk_part_iter_init(&piter, disk,
- DISK_PITER_INCL_EMPTY | DISK_PITER_INCL_PART0);
+ if (disk->part0.policy != flag) {
+ set_disk_ro_uevent(disk, flag);
+ disk->part0.policy = flag;
+ }
+
+ disk_part_iter_init(&piter, disk, DISK_PITER_INCL_EMPTY);
while ((part = disk_part_iter_next(&piter)))
part->policy = flag;
disk_part_iter_exit(&piter);
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists