mddev_dev_t dv;
int devs_found = 0;
int verbose = 0;
+ int quiet = 0;
int brief = 0;
int force = 0;
int test = 0;
int oneshot = 0;
struct supertype *ss = NULL;
int writemostly = 0;
+ int re_add = 0;
int copies;
short_options, long_options,
&option_index)) != -1) {
int newmode = mode;
- /* firstly, so mode-independant options */
+ /* firstly, some mode-independant options */
switch(opt) {
case 'h':
help_text = Help;
case 'v': verbose++;
continue;
+ case 'q': quiet++;
+ continue;
+
case 'b':
if (mode == ASSEMBLE || mode == BUILD || mode == CREATE || mode == GROW)
break; /* b means bitmap */
case 'a':
case 'r':
case 'f':
+ case 6: /* re-add */
if (!mode) newmode = MANAGE;
break;
dv->devname = optarg;
dv->disposition = devmode;
dv->writemostly = writemostly;
+ dv->re_add = re_add;
dv->next = NULL;
*devlistend = dv;
devlistend = &dv->next;
dv->devname = optarg;
dv->disposition = devmode;
dv->writemostly = writemostly;
+ dv->re_add = re_add;
dv->next = NULL;
*devlistend = dv;
devlistend = &dv->next;
case O(GROW,'a'):
case O(MANAGE,'a'): /* add a drive */
devmode = 'a';
+ re_add = 0;
+ continue;
+ case O(MANAGE,6):
+ devmode = 'a';
+ re_add = 1;
continue;
case O(MANAGE,'r'): /* remove a drive */
devmode = 'r';
rv = Manage_ro(devlist->devname, mdfd, readonly);
if (!rv && devs_found>1)
rv = Manage_subdevs(devlist->devname, mdfd,
- devlist->next);
+ devlist->next, verbose-quiet);
if (!rv && readonly < 0)
rv = Manage_ro(devlist->devname, mdfd, readonly);
if (!rv && runstop)
else {
rv |= Assemble(ss, devlist->devname, mdfd, array_ident, configfile,
NULL,
- readonly, runstop, update, verbose, force);
+ readonly, runstop, update, verbose-quiet, force);
close(mdfd);
}
}
} else if (!scan)
rv = Assemble(ss, devlist->devname, mdfd, &ident, configfile,
devlist->next,
- readonly, runstop, update, verbose, force);
+ readonly, runstop, update, verbose-quiet, force);
else if (devs_found>0) {
if (update && devs_found > 1) {
fprintf(stderr, Name ": can only update a single array at a time\n");
}
rv |= Assemble(ss, dv->devname, mdfd, array_ident, configfile,
NULL,
- readonly, runstop, update, verbose, force);
+ readonly, runstop, update, verbose-quiet, force);
close(mdfd);
}
} else {
rv |= Assemble(ss, array_list->devname, mdfd,
array_list, configfile,
NULL,
- readonly, runstop, NULL, verbose, force);
+ readonly, runstop, NULL, verbose-quiet, force);
close(mdfd);
}
}
rv |= 1;
break;
}
- bitmap_fd = open(bitmap_file, O_RDWR,0);
- if (bitmap_fd < 0 && errno != ENOENT) {
- perror(Name ": cannot create bitmap file");
- rv |= 1;
- break;
- }
- if (bitmap_fd < 0) {
- bitmap_fd = CreateBitmap(bitmap_file, force, NULL,
- bitmap_chunk, delay, write_behind, size);
- }
}
rv = Build(devlist->devname, mdfd, chunk, level, layout,
raiddisks, devlist->next, assume_clean,
- bitmap_file, bitmap_chunk, write_behind, delay);
+ bitmap_file, bitmap_chunk, write_behind, delay, verbose-quiet);
break;
case CREATE:
if (delay == 0) delay = DEFAULT_BITMAP_DELAY;
rv = Create(ss, devlist->devname, mdfd, chunk, level, layout, size<0 ? 0 : size,
raiddisks, sparedisks, ident.name,
- devs_found-1, devlist->next, runstop, verbose, force,
+ devs_found-1, devlist->next, runstop, verbose-quiet, force,
bitmap_file, bitmap_chunk, write_behind, delay);
break;
case MISC: