summaryrefslogtreecommitdiffstats
path: root/Kill.c
diff options
context:
space:
mode:
authorNeil Brown <neilb@suse.de>2006-03-29 01:22:58 +0200
committerNeil Brown <neilb@suse.de>2006-03-29 01:22:58 +0200
commit6409687b554687b89700e7a907dc3fcbcf5171a2 (patch)
treeaec99649a9c006f96ae26ef7da6578bb24092b46 /Kill.c
parentReduce dependance on MD_SB_DISKS (diff)
downloadmdadm-6409687b554687b89700e7a907dc3fcbcf5171a2.tar.xz
mdadm-6409687b554687b89700e7a907dc3fcbcf5171a2.zip
Kill old superblocks on create.
Make sure old-version superblocks are not around to confuse anything when a new array is created. Signed-off-by: Neil Brown <neilb@suse.de>
Diffstat (limited to 'Kill.c')
-rw-r--r--Kill.c18
1 files changed, 11 insertions, 7 deletions
diff --git a/Kill.c b/Kill.c
index 95ab15ca..2f28b990 100644
--- a/Kill.c
+++ b/Kill.c
@@ -34,7 +34,7 @@
#include "md_u.h"
#include "md_p.h"
-int Kill(char *dev, int force)
+int Kill(char *dev, int force, int quiet)
{
/*
* Nothing fancy about Kill. It just zeroes out a superblock
@@ -47,13 +47,15 @@ int Kill(char *dev, int force)
fd = open(dev, O_RDWR|O_EXCL);
if (fd < 0) {
- fprintf(stderr, Name ": Couldn't open %s for write - not zeroing\n",
- dev);
+ if (!quiet)
+ fprintf(stderr, Name ": Couldn't open %s for write - not zeroing\n",
+ dev);
return 1;
}
st = guess_super(fd);
if (st == NULL) {
- fprintf(stderr, Name ": Unrecognised md component device - %s\n", dev);
+ if (!quiet)
+ fprintf(stderr, Name ": Unrecognised md component device - %s\n", dev);
return 1;
}
rv = st->ss->load_super(st, fd, &super, dev);
@@ -65,11 +67,13 @@ int Kill(char *dev, int force)
free(super);
st->ss->init_super(st, &super, &info, 0, "");
if (st->ss->store_super(st, fd, super)) {
- fprintf(stderr, Name ": Could not zero superblock on %s\n",
- dev);
+ if (!quiet)
+ fprintf(stderr, Name ": Could not zero superblock on %s\n",
+ dev);
rv = 1;
} else if (rv) {
- fprintf(stderr, Name ": superblock zeroed anyway\n");
+ if (!quiet)
+ fprintf(stderr, Name ": superblock zeroed anyway\n");
rv = 0;
}
}