From: NeilBrown Date: Thu, 14 May 2015 04:50:42 +0000 (+1000) Subject: Grow: retry when writing 'reshape' to 'sync_action' is EBUSY. X-Git-Tag: mdadm-3.3.3~50 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ada38ebbcb9b28c4f865e77c736a7a467d0fb967;p=thirdparty%2Fmdadm.git Grow: retry when writing 'reshape' to 'sync_action' is EBUSY. EBUSY can be returned if something has recently happened to cause md to want to check if recovery is needed, but hasn't had a chance yet. This can easily happen in testing. So retry a few times in that case. Signed-off-by: NeilBrown --- diff --git a/Grow.c b/Grow.c index 99f34973..fe42b2b0 100644 --- a/Grow.c +++ b/Grow.c @@ -718,9 +718,14 @@ int start_reshape(struct mdinfo *sra, int already_running, if (!already_running) sysfs_set_num(sra, NULL, "sync_min", sync_max_to_set); err = err ?: sysfs_set_num(sra, NULL, "sync_max", sync_max_to_set); - if (!already_running) - err = err ?: sysfs_set_str(sra, NULL, "sync_action", "reshape"); - + if (!already_running && err == 0) { + int cnt = 5; + do { + err = sysfs_set_str(sra, NULL, "sync_action", "reshape"); + if (err) + sleep(1); + } while (err && errno == EBUSY && cnt-- > 0); + } return err; }