1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-06 17:18:29 +03:00

wipe_lv: interruptible wiping

Since we now block signals and wiping may take unexpectedly long
time - support breaking command while wipe is in progress.
This commit is contained in:
Zdenek Kabelac 2020-10-02 19:31:05 +02:00
parent e94e0cd020
commit e9241860a8
2 changed files with 17 additions and 0 deletions

View File

@ -1,5 +1,6 @@
Version 2.02.188 - Version 2.02.188 -
================================== ==================================
Support interruption when wipping LVs.
Add configure --enable-editline support as an alternative to readline. Add configure --enable-editline support as an alternative to readline.
Zero pool metadata on allocation (disable with allocation/zero_metadata=0). Zero pool metadata on allocation (disable with allocation/zero_metadata=0).
Failure in zeroing or wiping will fail command (bypass with -Zn, -Wn). Failure in zeroing or wiping will fail command (bypass with -Zn, -Wn).

View File

@ -31,6 +31,7 @@
#include "memlock.h" #include "memlock.h"
#include "lvmlockd.h" #include "lvmlockd.h"
#include "label.h" #include "label.h"
#include "lvm-signal.h"
typedef enum { typedef enum {
PREFERRED, PREFERRED,
@ -7225,12 +7226,20 @@ int wipe_lv(struct logical_volume *lv, struct wipe_params wp)
return 0; return 0;
} }
sigint_allow();
if (wp.do_wipe_signatures) { if (wp.do_wipe_signatures) {
log_verbose("Wiping known signatures on logical volume %s.", log_verbose("Wiping known signatures on logical volume %s.",
display_lvname(lv)); display_lvname(lv));
if (!wipe_known_signatures(lv->vg->cmd, dev, name, 0, if (!wipe_known_signatures(lv->vg->cmd, dev, name, 0,
TYPE_DM_SNAPSHOT_COW, TYPE_DM_SNAPSHOT_COW,
wp.yes, wp.force, NULL)) { wp.yes, wp.force, NULL)) {
sigint_restore();
label_scan_invalidate(dev);
if (sigint_caught()) {
log_error("Interrupted initialization logical volume %s.",
display_lvname(lv));
return 0;
}
log_error("Filed to wipe signatures of logical volume %s.", log_error("Filed to wipe signatures of logical volume %s.",
display_lvname(lv)); display_lvname(lv));
return 0; return 0;
@ -7262,12 +7271,19 @@ int wipe_lv(struct logical_volume *lv, struct wipe_params wp)
display_lvname(lv), wp.zero_value); display_lvname(lv), wp.zero_value);
if (!dev_set_bytes(dev, UINT64_C(0), (size_t) zero_sectors << SECTOR_SHIFT, wp.zero_value)) { if (!dev_set_bytes(dev, UINT64_C(0), (size_t) zero_sectors << SECTOR_SHIFT, wp.zero_value)) {
sigint_restore();
if (sigint_caught()) {
log_error("Interrupted initialization logical volume %s.",
display_lvname(lv));
return 0;
}
log_error("Failed to initialize %s of logical volume %s with value %d.", log_error("Failed to initialize %s of logical volume %s with value %d.",
display_size(lv->vg->cmd, zero_sectors), display_size(lv->vg->cmd, zero_sectors),
display_lvname(lv), wp.zero_value); display_lvname(lv), wp.zero_value);
return 0; return 0;
} }
} }
sigint_restore();
label_scan_invalidate(dev); label_scan_invalidate(dev);