diff options
author | Lars Ellenberg <lars.ellenberg@linbit.com> | 2010-07-19 17:41:04 +0200 |
---|---|---|
committer | Philipp Reisner <philipp.reisner@linbit.com> | 2010-10-14 18:38:31 +0200 |
commit | 1090c056c5eb6d5335cceb381683e77ac24c71ab (patch) | |
tree | 66c38894d55a57797a27569ec77dd5090a9b08f3 /drivers/block | |
parent | ee15b038164fcf19b798021762dee3cf5cbc6433 (diff) | |
download | op-kernel-dev-1090c056c5eb6d5335cceb381683e77ac24c71ab.zip op-kernel-dev-1090c056c5eb6d5335cceb381683e77ac24c71ab.tar.gz |
drbd: drbd_md_sync before calling user space helpers
Just in case we have some pending meta data changes to sync, do it
before we call our userland helper, as that may take some time,
or even cause a hard reboot.
Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
Diffstat (limited to 'drivers/block')
-rw-r--r-- | drivers/block/drbd/drbd_nl.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/block/drbd/drbd_nl.c b/drivers/block/drbd/drbd_nl.c index e0061a9..5b30f90 100644 --- a/drivers/block/drbd/drbd_nl.c +++ b/drivers/block/drbd/drbd_nl.c @@ -172,6 +172,10 @@ int drbd_khelper(struct drbd_conf *mdev, char *cmd) put_net_conf(mdev); } + /* The helper may take some time. + * write out any unsynced meta data changes now */ + drbd_md_sync(mdev); + dev_info(DEV, "helper command: %s %s %s\n", usermode_helper, cmd, mb); drbd_bcast_ev_helper(mdev, cmd); |