1
0
mirror of git://sourceware.org/git/lvm2.git synced 2024-12-21 13:34:40 +03:00

Change the pvcreate swap/md logic

pvcreate detects MD and swap signature.

The logic hidden there is not only documented but it is also
user unfriendly. Who invented this logic should run pvcreate
on its own critical MD device to see why;-)

This patch
 - creates one function instead of duplication code
 - asks if user want to overwrite signature
 - allows aborting (!)
 (Please note that writing LVM signatute without wiping old
 is wrong, it confuses blkid, MD will not work anyway and
 swap and LUKS is broken too.)
This commit is contained in:
Milan Broz 2010-08-19 23:03:34 +00:00
parent 7dbfd06d99
commit 2d5e2b52ca
2 changed files with 37 additions and 34 deletions

View File

@ -1,5 +1,6 @@
Version 2.02.74 -
==================================
Simplify MD/swap signature detection in pvcreate and allow aborting.
Version 2.02.73 - 18th August 2010
==================================

View File

@ -1526,6 +1526,40 @@ int vg_split_mdas(struct cmd_context *cmd __attribute__((unused)),
return 1;
}
static int _wipe_sb(struct device *dev, const char *type, const char *name,
int wipe_len, struct pvcreate_params *pp,
int (*func)(struct device *dev, uint64_t *signature))
{
int wipe;
uint64_t superblock;
wipe = func(dev, &superblock);
if (wipe == -1) {
log_error("Fatal error while trying to detect %s on %s.",
type, name);
return 0;
}
if (wipe == 0)
return 1;
/* Specifying --yes => do not ask. */
if (!pp->yes && (pp->force == PROMPT) &&
yes_no_prompt("WARNING: %s detected on %s. Wipe it? [y/n] ",
type, name) != 'y') {
log_error("Aborting pvcreate on %s.", name);
return 0;
}
log_print("Wiping %s on %s.", type, name);
if (!dev_set(dev, superblock, wipe_len, 0)) {
log_error("Failed to wipe %s on %s.", type, name);
return 0;
}
return 1;
}
/*
* See if we may pvcreate on this device.
* 0 indicates we may not.
@ -1535,8 +1569,6 @@ static int pvcreate_check(struct cmd_context *cmd, const char *name,
{
struct physical_volume *pv;
struct device *dev;
uint64_t md_superblock, swap_signature;
int wipe_md, wipe_swap;
struct dm_list mdas;
dm_list_init(&mdas);
@ -1602,41 +1634,11 @@ static int pvcreate_check(struct cmd_context *cmd, const char *name,
return 0;
}
/* Wipe superblock? */
if ((wipe_md = dev_is_md(dev, &md_superblock)) == 1 &&
((!pp->idp && !pp->restorefile) || pp->yes ||
(yes_no_prompt("Software RAID md superblock "
"detected on %s. Wipe it? [y/n] ", name) == 'y'))) {
log_print("Wiping software RAID md superblock on %s", name);
if (!dev_set(dev, md_superblock, 4, 0)) {
log_error("Failed to wipe RAID md superblock on %s",
name);
return 0;
}
}
if (wipe_md == -1) {
log_error("Fatal error while trying to detect software "
"RAID md superblock on %s", name);
if (!_wipe_sb(dev, "software RAID md superblock", name, 4, pp, dev_is_md))
return 0;
}
if ((wipe_swap = dev_is_swap(dev, &swap_signature)) == 1 &&
((!pp->idp && !pp->restorefile) || pp->yes ||
(yes_no_prompt("Swap signature detected on %s. Wipe it? [y/n] ",
name) == 'y'))) {
log_print("Wiping swap signature on %s", name);
if (!dev_set(dev, swap_signature, 10, 0)) {
log_error("Failed to wipe swap signature on %s", name);
return 0;
}
}
if (wipe_swap == -1) {
log_error("Fatal error while trying to detect swap "
"signature on %s", name);
if (!_wipe_sb(dev, "swap signature", name, 10, pp, dev_is_swap))
return 0;
}
if (sigint_caught())
return 0;