Resume ioctls may result in no changes to the device and thus they should not generate change uevents. For example, if a device is not suspended when a resume ioctl occurs, we should not send a uevent. Signed-off-by: Dave Wysochanski <dwysocha@xxxxxxxxxx> --- drivers/md/dm-ioctl.c | 12 ++++++++---- 1 files changed, 8 insertions(+), 4 deletions(-) diff --git a/drivers/md/dm-ioctl.c b/drivers/md/dm-ioctl.c index 1d66932..0c1cf53 100644 --- a/drivers/md/dm-ioctl.c +++ b/drivers/md/dm-ioctl.c @@ -851,6 +851,7 @@ static int do_suspend(struct dm_ioctl *param) static int do_resume(struct dm_ioctl *param) { + int send_uevent = 0; int r = 0; unsigned suspend_flags = DM_SUSPEND_LOCKFS_FLAG; struct hash_cell *hc; @@ -895,18 +896,21 @@ static int do_resume(struct dm_ioctl *param) set_disk_ro(dm_disk(md), 0); else set_disk_ro(dm_disk(md), 1); + send_uevent = 1; } - - if (dm_suspended_md(md)) + if (dm_suspended_md(md)) { r = dm_resume(md); + send_uevent = 1; + } if (old_map) dm_table_destroy(old_map); - if (!r) { + if (send_uevent) dm_kobject_uevent(md, KOBJ_CHANGE, param->event_nr); + + if (!r) r = __dev_status(md, param); - } dm_put(md); return r; -- 1.6.5.3 -- dm-devel mailing list dm-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/dm-devel