summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeil Brown <neilb@suse.de>2006-03-20 04:26:42 +0100
committerNeil Brown <neilb@suse.de>2006-03-20 04:26:42 +0100
commit206c5eaedfa3d8d9d645874bb0f5be808ff06843 (patch)
tree96b6325c06787f04faf4954283979e4b0823d9ef
parentSupport restarting of a reshape on --assemble (diff)
downloadmdadm-206c5eaedfa3d8d9d645874bb0f5be808ff06843.tar.xz
mdadm-206c5eaedfa3d8d9d645874bb0f5be808ff06843.zip
Fix a few issues with the reshape patches.
Signed-off-by: Neil Brown <neilb@suse.de>
-rw-r--r--Grow.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/Grow.c b/Grow.c
index 6d09dc68..736afa57 100644
--- a/Grow.c
+++ b/Grow.c
@@ -737,9 +737,12 @@ int Grow_reshape(char *devname, int fd, int quiet,
for (i=odisks; i<d ; i++) {
bsb.devstart = __cpu_to_le64(offsets[i]);
bsb.sb_csum = bsb_csum((char*)&bsb, ((char*)&bsb.sb_csum)-((char*)&bsb));
- lseek64(fdlist[i], (offsets[i]+last_block)<<9, 0);
- write(fdlist[i], &bsb, sizeof(bsb));
- /* FIXME error check */
+ if (lseek64(fdlist[i], (offsets[i]+last_block)<<9, 0) < 0 ||
+ write(fdlist[i], &bsb, sizeof(bsb)) != sizeof(bsb)) {
+ fprintf(stderr, Name ": %s: fail to save metadata for critical region backups.\n",
+ devname);
+ goto abort_resume;
+ }
}
/* start the reshape happening */
@@ -751,8 +754,10 @@ int Grow_reshape(char *devname, int fd, int quiet,
/* wait for reshape to pass the critical region */
while(1) {
unsigned long long comp;
- if (sysfs_get_ll(sra, NULL, "sync_completed", &comp)<0)
+ if (sysfs_get_ll(sra, NULL, "sync_completed", &comp)<0) {
+ sleep(5);
break;
+ }
if (comp >= nstripe)
break;
sleep(1);
@@ -774,7 +779,7 @@ int Grow_reshape(char *devname, int fd, int quiet,
free(fdlist);
free(offsets);
- printf("mdadm: ... critical section passed.\n");
+ printf(Name ": ... critical section passed.\n");
break;
}
return 0;
@@ -824,7 +829,7 @@ int Grow_restart(struct supertype *st, struct mdinfo *info, int *fdlist, int cnt
* backup_super_block.
* If either fail, go on to next device.
* If the backup contains no new info, just return
- * Else retore data and update all superblocks
+ * else restore data and update all superblocks
*/
if (fdlist[i] < 0)
continue;
@@ -881,7 +886,7 @@ int Grow_restart(struct supertype *st, struct mdinfo *info, int *fdlist, int cnt
fdlist[i], __le64_to_cpu(bsb.devstart)*512,
0, __le64_to_cpu(bsb.length)*512)) {
/* didn't succeed, so giveup */
- return 0;
+ return -1;
}
/* Ok, so the data is restored. Let's update those superblocks. */