mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
wiping: blkid: do not count skipped signatures in final number of wipes
We exclude some signatures from being wiped when using blkid wiping.
These are signatures which we simply overwrite. For example, the
LVM2_member signature which denotes a PV - if we call pvcreate on
existing PV, we just overwrite the PV header, no need to wipe it.
Previously, we counted such signatures as if they were wiped
and they were counted in the final number of wiped signatures
that _wipe_known_signatures_with_blkid fn returned in the "wiped"
output arg. Then the code checking this output arg could be
mislead that wiping happened while no wiping took place in real
and we could fire some code uselessly based on this information
(e.g. refreshing filters/rescanning - see also
commit 6b4066585f
).
This commit is contained in:
parent
373f855684
commit
69b1e32c8a
@ -540,7 +540,7 @@ static int _blkid_wipe(blkid_probe probe, struct device *dev, const char *name,
|
|||||||
|
|
||||||
if (!blkid_probe_lookup_value(probe, "TYPE", &type, NULL)) {
|
if (!blkid_probe_lookup_value(probe, "TYPE", &type, NULL)) {
|
||||||
if (_type_in_flag_list(type, types_to_exclude))
|
if (_type_in_flag_list(type, types_to_exclude))
|
||||||
return 1;
|
return 2;
|
||||||
if (blkid_probe_lookup_value(probe, "SBMAGIC_OFFSET", &offset, NULL)) {
|
if (blkid_probe_lookup_value(probe, "SBMAGIC_OFFSET", &offset, NULL)) {
|
||||||
log_error(_msg_failed_offset, type, name);
|
log_error(_msg_failed_offset, type, name);
|
||||||
return 0;
|
return 0;
|
||||||
@ -600,6 +600,7 @@ static int _wipe_known_signatures_with_blkid(struct device *dev, const char *nam
|
|||||||
{
|
{
|
||||||
blkid_probe probe = NULL;
|
blkid_probe probe = NULL;
|
||||||
int found = 0, left = 0, wiped_tmp;
|
int found = 0, left = 0, wiped_tmp;
|
||||||
|
int r_wipe;
|
||||||
int r = 0;
|
int r = 0;
|
||||||
|
|
||||||
if (!wiped)
|
if (!wiped)
|
||||||
@ -626,9 +627,11 @@ static int _wipe_known_signatures_with_blkid(struct device *dev, const char *nam
|
|||||||
BLKID_SUBLKS_BADCSUM);
|
BLKID_SUBLKS_BADCSUM);
|
||||||
|
|
||||||
while (!blkid_do_probe(probe)) {
|
while (!blkid_do_probe(probe)) {
|
||||||
found++;
|
if ((r_wipe = _blkid_wipe(probe, dev, name, types_to_exclude, types_no_prompt, yes, force)) == 1)
|
||||||
if (_blkid_wipe(probe, dev, name, types_to_exclude, types_no_prompt, yes, force))
|
|
||||||
(*wiped)++;
|
(*wiped)++;
|
||||||
|
/* do not count excluded types */
|
||||||
|
if (r_wipe != 2)
|
||||||
|
found++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!found)
|
if (!found)
|
||||||
|
Loading…
Reference in New Issue
Block a user