mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-20 18:09:23 +03:00
raid: ad '.' to messages. lvchange --writemostly prevention during initial sync
This commit is contained in:
parent
efecf4a1d2
commit
d98932039f
@ -1241,6 +1241,7 @@ uint32_t raid_ensure_min_region_size(const struct logical_volume *lv, uint64_t r
|
||||
int lv_raid_change_region_size(struct logical_volume *lv,
|
||||
int yes, int force, uint32_t new_region_size);
|
||||
uint32_t lv_raid_data_copies(const struct segment_type *segtype, uint32_t area_count);
|
||||
int lv_raid_in_sync(const struct logical_volume *lv);
|
||||
/* -- metadata/raid_manip.c */
|
||||
|
||||
/* ++ metadata/cache_manip.c */
|
||||
|
@ -264,12 +264,12 @@ static int _get_dev_health(struct logical_volume *lv, uint32_t *kernel_devs,
|
||||
*devs_health = *devs_in_sync = 0;
|
||||
|
||||
if (!lv_raid_dev_count(lv, kernel_devs)) {
|
||||
log_error("Failed to get device count");
|
||||
log_error("Failed to get device count.");
|
||||
return_0;
|
||||
}
|
||||
|
||||
if (!lv_raid_dev_health(lv, &rh)) {
|
||||
log_error("Failed to get device health");
|
||||
log_error("Failed to get device health.");
|
||||
return_0;
|
||||
}
|
||||
|
||||
@ -313,7 +313,7 @@ static int _devs_in_sync_count(struct logical_volume *lv)
|
||||
* Returns: 1 if in-sync, 0 otherwise.
|
||||
*/
|
||||
#define _RAID_IN_SYNC_RETRIES 10
|
||||
static int _raid_in_sync(struct logical_volume *lv)
|
||||
static int _raid_in_sync(const struct logical_volume *lv)
|
||||
{
|
||||
int retries = _RAID_IN_SYNC_RETRIES;
|
||||
dm_percent_t sync_percent;
|
||||
@ -344,6 +344,12 @@ static int _raid_in_sync(struct logical_volume *lv)
|
||||
return (sync_percent == DM_PERCENT_100) ? 1 : 0;
|
||||
}
|
||||
|
||||
/* External interface to raid in-sync check */
|
||||
int lv_raid_in_sync(const struct logical_volume *lv)
|
||||
{
|
||||
return _raid_in_sync(lv);
|
||||
}
|
||||
|
||||
/* Check if RaidLV @lv is synced or any raid legs of @lv are not synced */
|
||||
static int _raid_devs_sync_healthy(struct logical_volume *lv)
|
||||
{
|
||||
@ -510,7 +516,7 @@ static int _clear_lv(struct logical_volume *lv)
|
||||
* to remove the superblock of any previous RAID devices. It is much
|
||||
* quicker than wiping a potentially larger metadata device completely.
|
||||
*/
|
||||
log_verbose("Clearing metadata area of %s", display_lvname(lv));
|
||||
log_verbose("Clearing metadata area of %s.", display_lvname(lv));
|
||||
offset = (pv->pe_start + seg_pe(seg, 0) * lv->vg->extent_size) << 9;
|
||||
|
||||
return dev_set(pv->dev, offset, 4096, 0);
|
||||
@ -604,7 +610,7 @@ static int _reorder_raid10_near_seg_areas(struct lv_segment *seg, enum raid0_rai
|
||||
|
||||
/* FIXME: once more data copies supported with raid10 */
|
||||
if (seg_is_raid10_near(seg) && (stripes % data_copies)) {
|
||||
log_error("Can't convert %s LV %s with number of stripes not divisable by number of data copies",
|
||||
log_error("Can't convert %s LV %s with number of stripes not divisable by number of data copies.",
|
||||
lvseg_name(seg), display_lvname(seg->lv));
|
||||
return 0;
|
||||
}
|
||||
@ -743,7 +749,7 @@ static int _shift_and_rename_image_components(struct lv_segment *seg)
|
||||
for (s = 0, missing = 0; s < seg->area_count; s++) {
|
||||
if (seg_type(seg, s) == AREA_UNASSIGNED) {
|
||||
if (seg_metatype(seg, s) != AREA_UNASSIGNED) {
|
||||
log_error(INTERNAL_ERROR "Metadata segment area"
|
||||
log_error(INTERNAL_ERROR "Metadata segment area."
|
||||
" #%d should be AREA_UNASSIGNED.", s);
|
||||
return 0;
|
||||
}
|
||||
@ -1305,7 +1311,7 @@ static int _lv_alloc_reshape_space(struct logical_volume *lv,
|
||||
|
||||
/* Get data_offset and dev_sectors from the kernel */
|
||||
if (!lv_raid_data_offset(lv, &data_offset)) {
|
||||
log_error("Can't get data offset and dev size for %s from kernel",
|
||||
log_error("Can't get data offset and dev size for %s from kernel.",
|
||||
display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
@ -1381,7 +1387,7 @@ static int _lv_alloc_reshape_space(struct logical_volume *lv,
|
||||
break;
|
||||
|
||||
default:
|
||||
log_error(INTERNAL_ERROR "Bogus reshape space allocation request");
|
||||
log_error(INTERNAL_ERROR "Bogus reshape space allocation request.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1580,12 +1586,12 @@ static int _raid_reshape_add_images(struct logical_volume *lv,
|
||||
vg = lv->vg;
|
||||
|
||||
if (!lv_info(vg->cmd, lv, 0, &info, 1, 0) && driver_version(NULL, 0)) {
|
||||
log_error("lv_info failed: aborting");
|
||||
log_error("lv_info failed: aborting.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (seg->segtype != new_segtype)
|
||||
log_print_unless_silent("Ignoring layout change on device adding reshape");
|
||||
log_print_unless_silent("Ignoring layout change on device adding reshape.");
|
||||
|
||||
if (seg_is_any_raid10(seg) && (new_image_count % seg->data_copies)) {
|
||||
log_error("Can't reshape %s LV %s to odd number of stripes.",
|
||||
@ -1602,7 +1608,7 @@ static int _raid_reshape_add_images(struct logical_volume *lv,
|
||||
"will grow it from %u to %u extents!",
|
||||
info.open_count ? " and open" : "",
|
||||
display_lvname(lv), current_le_count, grown_le_count);
|
||||
log_print_unless_silent("Run \"lvresize -l%u %s\" to shrink it or use the additional capacity",
|
||||
log_print_unless_silent("Run \"lvresize -l%u %s\" to shrink it or use the additional capacity.",
|
||||
current_le_count, display_lvname(lv));
|
||||
if (!yes && yes_no_prompt("Are you sure you want to add %u images to %s LV %s? [y/n]: ",
|
||||
new_image_count - old_image_count, lvseg_name(seg), display_lvname(lv)) == 'n') {
|
||||
@ -1612,7 +1618,7 @@ static int _raid_reshape_add_images(struct logical_volume *lv,
|
||||
|
||||
//printf("%s[%u] lv=%s segtype=%s data_copies=%u lv_size=%s le_count=%u\n", __func__, __LINE__, display_lvname(lv), lvseg_name(seg), seg->data_copies, display_size(lv->vg->cmd, lv->size), lv->le_count);
|
||||
/* Allocate new image component pairs for the additional stripes and grow LV size */
|
||||
log_debug_metadata("Adding %u data and metadata image LV pair%s to %s",
|
||||
log_debug_metadata("Adding %u data and metadata image LV pair%s to %s.",
|
||||
new_image_count - old_image_count, new_image_count - old_image_count > 1 ? "s" : "",
|
||||
display_lvname(lv));
|
||||
if (!_lv_raid_change_image_count(lv, new_image_count, allocate_pvs, NULL, 0, 0))
|
||||
@ -1625,7 +1631,7 @@ static int _raid_reshape_add_images(struct logical_volume *lv,
|
||||
}
|
||||
|
||||
/* Allocate forward out of place reshape space at the beginning of all data image LVs */
|
||||
log_debug_metadata("(Re)allocating reshape space for %s", display_lvname(lv));
|
||||
log_debug_metadata("(Re)allocating reshape space for %s.", display_lvname(lv));
|
||||
if (!_lv_alloc_reshape_space(lv, alloc_begin, NULL, allocate_pvs))
|
||||
return 0;
|
||||
|
||||
@ -1636,7 +1642,7 @@ static int _raid_reshape_add_images(struct logical_volume *lv,
|
||||
* - set delta disks plus flag on new image LVs
|
||||
*/
|
||||
if (old_image_count < seg->area_count) {
|
||||
log_debug_metadata("Setting delta disk flag on new data LVs of %s",
|
||||
log_debug_metadata("Setting delta disk flag on new data LVs of %s.",
|
||||
display_lvname(lv));
|
||||
for (s = old_image_count; s < seg->area_count; s++) {
|
||||
slv = seg_lv(seg, s);
|
||||
@ -1671,7 +1677,7 @@ static int _raid_reshape_remove_images(struct logical_volume *lv,
|
||||
struct lvinfo info = { 0 };
|
||||
|
||||
if (seg_is_any_raid6(seg) && new_stripes < 3) {
|
||||
log_error("Minimum 3 stripes required for %s LV %s",
|
||||
log_error("Minimum 3 stripes required for %s LV %s.",
|
||||
lvseg_name(seg), display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
@ -1692,10 +1698,10 @@ static int _raid_reshape_remove_images(struct logical_volume *lv,
|
||||
*
|
||||
*/
|
||||
if (seg->segtype != new_segtype)
|
||||
log_print_unless_silent("Ignoring layout change on device removing reshape");
|
||||
log_print_unless_silent("Ignoring layout change on device removing reshape.");
|
||||
|
||||
if (!lv_info(lv->vg->cmd, lv, 0, &info, 1, 0) && driver_version(NULL, 0)) {
|
||||
log_error("lv_info failed: aborting");
|
||||
log_error("lv_info failed: aborting.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1722,7 +1728,7 @@ static int _raid_reshape_remove_images(struct logical_volume *lv,
|
||||
new_stripes, display_lvname(lv));
|
||||
|
||||
if (!force) {
|
||||
log_warn("WARNING: Can't remove stripes without --force option");
|
||||
log_warn("WARNING: Can't remove stripes without --force option.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1763,7 +1769,7 @@ static int _raid_reshape_remove_images(struct logical_volume *lv,
|
||||
struct logical_volume *slv;
|
||||
|
||||
if (!seg_lv(seg, s) || !(slv = seg_lv(seg, s))) {
|
||||
log_error("Missing image sub lv off LV %s", display_lvname(lv));
|
||||
log_error("Missing image sub lv off LV %s.", display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1774,12 +1780,12 @@ static int _raid_reshape_remove_images(struct logical_volume *lv,
|
||||
}
|
||||
|
||||
if (devs_in_sync != new_image_count) {
|
||||
log_error("No correct kernel/lvm active LV count on %s", display_lvname(lv));
|
||||
log_error("No correct kernel/lvm active LV count on %s.", display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (active_lvs + removed_lvs != old_image_count) {
|
||||
log_error ("No correct kernel/lvm total LV count on %s", display_lvname(lv));
|
||||
log_error ("No correct kernel/lvm total LV count on %s.", display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1789,7 +1795,7 @@ static int _raid_reshape_remove_images(struct logical_volume *lv,
|
||||
return 0;
|
||||
}
|
||||
|
||||
log_debug_metadata("Removing %u data and metadata image LV pair%s from %s",
|
||||
log_debug_metadata("Removing %u data and metadata image LV pair%s from %s.",
|
||||
old_image_count - new_image_count, old_image_count - new_image_count > 1 ? "s" : "",
|
||||
display_lvname(lv));
|
||||
if (!_lv_raid_change_image_count(lv, new_image_count, allocate_pvs, removal_lvs, 0, 0))
|
||||
@ -1825,7 +1831,7 @@ static int _raid_reshape_keep_images(struct logical_volume *lv,
|
||||
struct lv_segment *seg = first_seg(lv);
|
||||
|
||||
if (seg->segtype != new_segtype)
|
||||
log_print_unless_silent("Converting %s LV %s to %s",
|
||||
log_print_unless_silent("Converting %s LV %s to %s.",
|
||||
lvseg_name(seg), display_lvname(lv), new_segtype->name);
|
||||
if (!yes && yes_no_prompt("Are you sure you want to convert %s LV %s? [y/n]: ",
|
||||
lvseg_name(seg), display_lvname(lv)) == 'n') {
|
||||
@ -1866,20 +1872,20 @@ static int _vg_write_lv_suspend_commit_backup(struct volume_group *vg,
|
||||
int r = 1;
|
||||
|
||||
if (!vg_write(vg)) {
|
||||
log_error("Write of VG %s failed", vg->name);
|
||||
log_error("Write of VG %s failed.", vg->name);
|
||||
return_0;
|
||||
}
|
||||
|
||||
if (lv && !(r = (origin_only ? suspend_lv_origin(vg->cmd, lv_lock_holder(lv)) :
|
||||
suspend_lv(vg->cmd, lv_lock_holder(lv))))) {
|
||||
log_error("Failed to suspend %s before committing changes",
|
||||
log_error("Failed to suspend %s before committing changes.",
|
||||
display_lvname(lv));
|
||||
vg_revert(lv->vg);
|
||||
} else if (!(r = vg_commit(vg)))
|
||||
stack; /* !vg_commit() has implicit vg_revert() */
|
||||
|
||||
if (r && do_backup && !backup(vg))
|
||||
log_error("Backup of VG %s failed; continuing", vg->name);
|
||||
log_error("Backup of VG %s failed; continuing.", vg->name);
|
||||
|
||||
return r;
|
||||
}
|
||||
@ -1919,7 +1925,7 @@ static int _activate_sub_lvs_excl_local(struct logical_volume *lv, uint32_t star
|
||||
struct lv_segment *seg = first_seg(lv);
|
||||
|
||||
/* seg->area_count may be 0 here! */
|
||||
log_debug_metadata("Activating %u image component%s of LV %s",
|
||||
log_debug_metadata("Activating %u image component%s of LV %s.",
|
||||
seg->area_count - start_idx, seg->meta_areas ? " pairs" : "s",
|
||||
display_lvname(lv));
|
||||
for (s = start_idx; s < seg->area_count; s++)
|
||||
@ -2022,7 +2028,7 @@ static int _raid_reshape(struct logical_volume *lv,
|
||||
return_0;
|
||||
|
||||
if (!_raid_in_sync(lv)) {
|
||||
log_error("Unable to convert %s while it is not in-sync",
|
||||
log_error("Unable to convert %s while it is not in-sync.",
|
||||
display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
@ -2040,15 +2046,15 @@ static int _raid_reshape(struct logical_volume *lv,
|
||||
* user requests this to remove any reshape space from the @lv
|
||||
*/
|
||||
if (!_lv_free_reshape_space_with_status(lv, &where_it_was)) {
|
||||
log_error(INTERNAL_ERROR "Failed to free reshape space of %s",
|
||||
log_error(INTERNAL_ERROR "Failed to free reshape space of %s.",
|
||||
display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
log_print_unless_silent("No change in RAID LV %s layout, freeing reshape space", display_lvname(lv));
|
||||
log_print_unless_silent("No change in RAID LV %s layout, freeing reshape space.", display_lvname(lv));
|
||||
|
||||
if (where_it_was == alloc_none) {
|
||||
log_print_unless_silent("LV %s does not have reshape space allocated",
|
||||
log_print_unless_silent("LV %s does not have reshape space allocated.",
|
||||
display_lvname(lv));
|
||||
return 1;
|
||||
}
|
||||
@ -2069,7 +2075,7 @@ static int _raid_reshape(struct logical_volume *lv,
|
||||
too_few = 1;
|
||||
|
||||
if (too_few) {
|
||||
log_error("Too few stripes requested");
|
||||
log_error("Too few stripes requested.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -2081,7 +2087,7 @@ static int _raid_reshape(struct logical_volume *lv,
|
||||
* Check for device health
|
||||
*/
|
||||
if (devs_in_sync < devs_health) {
|
||||
log_error("Can't reshape out of sync LV %s", display_lvname(lv));
|
||||
log_error("Can't reshape out of sync LV %s.", display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -2105,7 +2111,7 @@ static int _raid_reshape(struct logical_volume *lv,
|
||||
}
|
||||
|
||||
if (seg->stripe_size != new_stripe_size)
|
||||
log_print_unless_silent("Converting stripesize %s of %s LV %s to %s",
|
||||
log_print_unless_silent("Converting stripesize %s of %s LV %s to %s.",
|
||||
display_size(lv->vg->cmd, seg->stripe_size),
|
||||
lvseg_name(seg), display_lvname(lv),
|
||||
display_size(lv->vg->cmd, new_stripe_size));
|
||||
@ -2199,7 +2205,7 @@ static int _reshape_requested(const struct logical_volume *lv, const struct segm
|
||||
!seg_is_any_raid0(seg) &&
|
||||
(region_size || stripe_size) &&
|
||||
((region_size ?: seg->region_size) < (stripe_size ?: seg->stripe_size))) {
|
||||
log_error("region size may not be smaller than stripe size on LV %s",
|
||||
log_error("region size may not be smaller than stripe size on LV %s.",
|
||||
display_lvname(lv));
|
||||
return 2;
|
||||
}
|
||||
@ -2212,7 +2218,7 @@ static int _reshape_requested(const struct logical_volume *lv, const struct segm
|
||||
(seg_is_raid10_far(seg) && !segtype_is_striped(segtype))) {
|
||||
if (data_copies == seg->data_copies &&
|
||||
region_size == seg->region_size) {
|
||||
log_error("Can't convert %sraid10_far",
|
||||
log_error("Can't convert %sraid10_far.",
|
||||
seg_is_raid10_far(seg) ? "" : "to ");
|
||||
goto err;
|
||||
}
|
||||
@ -2220,12 +2226,12 @@ static int _reshape_requested(const struct logical_volume *lv, const struct segm
|
||||
|
||||
if (seg_is_raid10_far(seg)) {
|
||||
if (stripes != _data_rimages_count(seg, seg->area_count)) {
|
||||
log_error("Can't change stripes in raid10_far");
|
||||
log_error("Can't change stripes in raid10_far.");
|
||||
goto err;
|
||||
}
|
||||
|
||||
if (stripe_size != seg->stripe_size) {
|
||||
log_error("Can't change stripe size in raid10_far");
|
||||
log_error("Can't change stripe size in raid10_far.");
|
||||
goto err;
|
||||
}
|
||||
}
|
||||
@ -2245,7 +2251,7 @@ static int _reshape_requested(const struct logical_volume *lv, const struct segm
|
||||
return segtype_is_raid10_far(segtype) ? 1 : 0;
|
||||
|
||||
if (seg_is_raid10_offset(seg)) {
|
||||
log_error("Can't change number of data copies on %s LV %s",
|
||||
log_error("Can't change number of data copies on %s LV %s.",
|
||||
lvseg_name(seg), display_lvname(lv));
|
||||
goto err;
|
||||
}
|
||||
@ -2300,9 +2306,9 @@ static int _reshape_requested(const struct logical_volume *lv, const struct segm
|
||||
err:
|
||||
#if 0
|
||||
if (lv_is_duplicated(lv))
|
||||
log_error("Conversion of duplicating sub LV %s rejected", display_lvname(lv));
|
||||
log_error("Conversion of duplicating sub LV %s rejected.", display_lvname(lv));
|
||||
else
|
||||
log_error("Use \"lvconvert --duplicate --type %s ... %s", segtype->name, display_lvname(lv));
|
||||
log_error("Use \"lvconvert --duplicate --type %s ... %s.", segtype->name, display_lvname(lv));
|
||||
#endif
|
||||
return 2;
|
||||
}
|
||||
@ -2738,12 +2744,12 @@ static int _raid_extract_images(struct logical_volume *lv,
|
||||
* cannot honor that list because error LVs
|
||||
* must come first.
|
||||
*/
|
||||
log_error("%s has components with error targets"
|
||||
log_error("%s has components with error targets."
|
||||
" that must be removed first: %s.",
|
||||
display_lvname(lv),
|
||||
display_lvname(seg_lv(seg, s)));
|
||||
|
||||
log_error("Try removing the PV list and rerun"
|
||||
log_error("Try removing the PV list and rerun."
|
||||
" the command.");
|
||||
return 0;
|
||||
}
|
||||
@ -2762,7 +2768,7 @@ static int _raid_extract_images(struct logical_volume *lv,
|
||||
*/
|
||||
if (!_raid_devs_sync_healthy(lv) &&
|
||||
(!seg_is_mirrored(seg) || (s == 0 && !force))) {
|
||||
log_error("Unable to extract %sRAID image"
|
||||
log_error("Unable to extract %sRAID image."
|
||||
" while RAID array is not in-sync%s.",
|
||||
seg_is_mirrored(seg) ? "primary " : "",
|
||||
seg_is_mirrored(seg) ? " (use --force option to replace)" : "");
|
||||
@ -3624,7 +3630,7 @@ static int _lv_update_reload_fns_reset_eliminate_lvs(struct logical_volume *lv,
|
||||
|
||||
/* Call any efn_pre_on_lv before the first update and reload call (e.g. to rename LVs) */
|
||||
if (fn_pre_on_lv && !(r = fn_pre_on_lv(lv, fn_pre_data))) {
|
||||
log_error(INTERNAL_ERROR "Pre callout function failed");
|
||||
log_error(INTERNAL_ERROR "Pre callout function failed.");
|
||||
goto err;
|
||||
}
|
||||
|
||||
@ -3635,7 +3641,7 @@ static int _lv_update_reload_fns_reset_eliminate_lvs(struct logical_volume *lv,
|
||||
*/
|
||||
if (!(origin_only ? resume_lv_origin(lv->vg->cmd, lv_lock_holder(lv)) :
|
||||
resume_lv(lv->vg->cmd, lv_lock_holder(lv)))) {
|
||||
log_error("Failed to resume %s", display_lvname(lv));
|
||||
log_error("Failed to resume %s.", display_lvname(lv));
|
||||
goto err;
|
||||
}
|
||||
|
||||
@ -3656,20 +3662,20 @@ static int _lv_update_reload_fns_reset_eliminate_lvs(struct logical_volume *lv,
|
||||
* Writes and commits metadata if any flags have been reset
|
||||
* and if successful, performs metadata backup.
|
||||
*/
|
||||
log_debug_metadata("Clearing any flags for %s passed to the kernel", display_lvname(lv));
|
||||
log_debug_metadata("Clearing any flags for %s passed to the kernel.", display_lvname(lv));
|
||||
if (!_reset_flags_passed_to_kernel(lv, &flags_reset))
|
||||
goto err;
|
||||
|
||||
/* Call any @fn_post_on_lv before the second update call (e.g. to rename LVs back) */
|
||||
if (fn_post_on_lv && !(r = fn_post_on_lv(lv, fn_post_data))) {
|
||||
log_error("Post callout function failed");
|
||||
log_error("Post callout function failed.");
|
||||
goto err;
|
||||
}
|
||||
|
||||
/* Update and reload to clear out reset flags in the metadata and in the kernel */
|
||||
log_debug_metadata("Updating metadata mappings for %s", display_lvname(lv));
|
||||
log_debug_metadata("Updating metadata mappings for %s.", display_lvname(lv));
|
||||
if ((r != 2 || flags_reset) && !(origin_only ? lv_update_and_reload_origin(lv) : lv_update_and_reload(lv))) {
|
||||
log_error(INTERNAL_ERROR "Update of LV %s failed", display_lvname(lv));
|
||||
log_error(INTERNAL_ERROR "Update of LV %s failed.", display_lvname(lv));
|
||||
goto err;
|
||||
}
|
||||
|
||||
@ -4389,7 +4395,7 @@ static int _log_possible_conversion(uint64_t *processed_segtypes, void *data)
|
||||
if (!(~*processed_segtypes & segtype->flags))
|
||||
return 1;
|
||||
|
||||
log_error(" %s", segtype->name);
|
||||
log_error(" %s.", segtype->name);
|
||||
|
||||
*processed_segtypes |= segtype->flags;
|
||||
|
||||
@ -4788,7 +4794,7 @@ static int _takeover_downconvert_wrapper(TAKEOVER_FN_ARGS)
|
||||
}
|
||||
|
||||
if (seg_is_any_raid10(seg) && (seg->area_count % seg->data_copies)) {
|
||||
log_error("Can't convert %s LV %s to %s with odd number of stripes",
|
||||
log_error("Can't convert %s LV %s to %s with odd number of stripes.",
|
||||
lvseg_name(seg), display_lvname(lv), new_segtype->name);
|
||||
return 0;
|
||||
}
|
||||
@ -4835,7 +4841,7 @@ static int _takeover_downconvert_wrapper(TAKEOVER_FN_ARGS)
|
||||
return 0;
|
||||
|
||||
} else if (seg_is_raid10_near(seg)) {
|
||||
log_debug_metadata("Reordering areas for raid10 -> raid0 takeover");
|
||||
log_debug_metadata("Reordering areas for raid10 -> raid0 takeover.");
|
||||
if (!_reorder_raid10_near_seg_areas(seg, reorder_from_raid10_near))
|
||||
return 0;
|
||||
}
|
||||
@ -5022,7 +5028,7 @@ static int _takeover_upconvert_wrapper(TAKEOVER_FN_ARGS)
|
||||
}
|
||||
|
||||
if (seg_is_any_raid5(seg) && segtype_is_any_raid6(new_segtype) && seg->area_count < 4) {
|
||||
log_error("Minimum of 3 stripes needed for conversion from %s to %s",
|
||||
log_error("Minimum of 3 stripes needed for conversion from %s to %s.",
|
||||
lvseg_name(seg), new_segtype->name);
|
||||
return 0;
|
||||
}
|
||||
@ -5114,7 +5120,7 @@ static int _takeover_upconvert_wrapper(TAKEOVER_FN_ARGS)
|
||||
/* FIXME: raid10 ; needs to change once more than 2 data copies! */
|
||||
seg->data_copies = 2;
|
||||
|
||||
log_debug_metadata("Reordering areas for raid0 -> raid10 takeover");
|
||||
log_debug_metadata("Reordering areas for raid0 -> raid10 takeover.");
|
||||
if (!_reorder_raid10_near_seg_areas(seg, reorder_to_raid10_near))
|
||||
return 0;
|
||||
/* Set rebuild flags accordingly */
|
||||
@ -5711,7 +5717,7 @@ replaced:
|
||||
if (!yes && yes_no_prompt("Do you want to convert %s LV %s to %s? [y/n]: ",
|
||||
segtype_sav->name, display_lvname(seg_from->lv),
|
||||
(*segtype)->name) == 'n') {
|
||||
log_error("Logical volume %s NOT converted", display_lvname(seg_from->lv));
|
||||
log_error("Logical volume %s NOT converted.", display_lvname(seg_from->lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -5768,7 +5774,7 @@ static int _region_size_change_requested(struct logical_volume *lv, int yes, con
|
||||
if (!yes && yes_no_prompt("Do you really want to change the region_size %s of LV %s to %s? [y/n]: ",
|
||||
display_size(lv->vg->cmd, old_region_size),
|
||||
display_lvname(lv), seg_region_size_str) == 'n') {
|
||||
log_error("Logical volume %s NOT converted", display_lvname(lv));
|
||||
log_error("Logical volume %s NOT converted.", display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -5818,19 +5824,19 @@ static int _conversion_options_allowed(const struct lv_segment *seg_from,
|
||||
}
|
||||
|
||||
if (stripes > 1 && !(opts & ALLOW_STRIPES)) {
|
||||
if (!_log_prohibited_option(seg_from, *segtype_to, "--stripes"))
|
||||
if (!_log_prohibited_option(seg_from, *segtype_to, "--stripes."))
|
||||
stack;
|
||||
r = 0;
|
||||
}
|
||||
|
||||
if (new_stripe_size_supplied && !(opts & ALLOW_STRIPE_SIZE)) {
|
||||
if (!_log_prohibited_option(seg_from, *segtype_to, "-I/--stripesize"))
|
||||
if (!_log_prohibited_option(seg_from, *segtype_to, "-I/--stripesize."))
|
||||
stack;
|
||||
r = 0;
|
||||
}
|
||||
|
||||
if (new_region_size && !(opts & ALLOW_REGION_SIZE)) {
|
||||
if (!_log_prohibited_option(seg_from, *segtype_to, "-R/--regionsize"))
|
||||
if (!_log_prohibited_option(seg_from, *segtype_to, "-R/--regionsize."))
|
||||
stack;
|
||||
r = 0;
|
||||
}
|
||||
@ -5896,17 +5902,17 @@ int lv_raid_convert(struct logical_volume *lv,
|
||||
if (!_raid_reshape(lv, new_segtype, yes, force,
|
||||
data_copies, region_size,
|
||||
stripes, stripe_size, allocate_pvs)) {
|
||||
log_error("Reshape request failed on LV %s", display_lvname(lv));
|
||||
log_error("Reshape request failed on LV %s.", display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
case 2:
|
||||
log_error("Invalid conversion request on %s", display_lvname(lv));
|
||||
log_error("Invalid conversion request on %s.", display_lvname(lv));
|
||||
/* Error if we got here with stripes and/or stripe size change requested */
|
||||
return 0;
|
||||
default:
|
||||
log_error(INTERNAL_ERROR "_reshape_requested failed");
|
||||
log_error(INTERNAL_ERROR "_reshape_requested failed.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
41
test/shell/lvchange-raid1-writemostly.sh
Normal file
41
test/shell/lvchange-raid1-writemostly.sh
Normal file
@ -0,0 +1,41 @@
|
||||
#!/bin/sh
|
||||
# Copyright (C) 2017 Red Hat, Inc. All rights reserved.
|
||||
#
|
||||
# This copyrighted material is made available to anyone wishing to use,
|
||||
# modify, copy, or redistribute it subject to the terms and conditions
|
||||
# of the GNU General Public License v.2.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA2110-1301 USA
|
||||
|
||||
SKIP_WITH_LVMLOCKD=1
|
||||
SKIP_WITH_LVMPOLLD=1
|
||||
|
||||
. lib/inittest
|
||||
|
||||
which mkfs.ext4 || skip
|
||||
aux have_raid 1 3 5 || skip
|
||||
|
||||
aux prepare_vg 4
|
||||
|
||||
for d in $dev1 $dev2 $dev3 $dev4
|
||||
do
|
||||
aux delay_dev $d 1
|
||||
done
|
||||
|
||||
#
|
||||
# Test writemostly prohibited on resyncrhonizing raid1
|
||||
#
|
||||
|
||||
# Create 4-way striped LV
|
||||
lvcreate -aey --ty raid1 -m 3 -L 32M -n $lv1 $vg
|
||||
not lvchange -y --writemostly $dev1 $vg/$lv1
|
||||
check lv_field $vg/$lv1 segtype "raid1"
|
||||
check lv_field $vg/$lv1 stripes 4
|
||||
check lv_attr_bit health $vg/${lv1}_rimage_0 "-"
|
||||
aux wait_for_sync $vg $lv1
|
||||
lvchange -y --writemostly $dev1 $vg/$lv1
|
||||
check lv_attr_bit health $vg/${lv1}_rimage_0 "w"
|
||||
|
||||
vgremove -ff $vg
|
@ -1,63 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Copyright (C) 2017 Red Hat, Inc. All rights reserved.
|
||||
#
|
||||
# This copyrighted material is made available to anyone wishing to use,
|
||||
# modify, copy, or redistribute it subject to the terms and conditions
|
||||
# of the GNU General Public License v.2.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA2110-1301 USA
|
||||
|
||||
SKIP_WITH_LVMLOCKD=1
|
||||
SKIP_WITH_LVMPOLLD=1
|
||||
|
||||
. lib/inittest
|
||||
|
||||
which mkfs.ext4 || skip
|
||||
aux have_raid 1 10 2 || skip
|
||||
|
||||
aux prepare_vg 4
|
||||
|
||||
# Create linear LV
|
||||
lvcreate -aey -L16M -n$lv1 $vg
|
||||
check lv_field $vg/$lv1 segtype "linear"
|
||||
echo y|mkfs -t ext4 $DM_DEV_DIR/$vg/$lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Upconvert it to 2-legged raid1
|
||||
lvconvert -y -m 1 --ty raid1 --regionsize 512K $vg/$lv1
|
||||
check lv_field $vg/$lv1 segtype "raid1"
|
||||
check lv_field $vg/$lv1 stripes 2
|
||||
check lv_field $vg/$lv1 regionsize "512.00k"
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Convert 2-legged raid1 to raid5_n
|
||||
lvconvert -y --ty raid5_n $vg/$lv1
|
||||
check lv_field $vg/$lv1 segtype "raid5_n"
|
||||
check lv_field $vg/$lv1 stripes 2
|
||||
check lv_field $vg/$lv1 stripesize "64.00k"
|
||||
check lv_field $vg/$lv1 regionsize "512.00k"
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Reshape it to to 3 stripes and 256K stripe size
|
||||
lvconvert -y --stripes 3 --stripesize 256K $vg/$lv1
|
||||
check lv_first_seg_field $vg/$lv1 stripes 4
|
||||
check lv_first_seg_field $vg/$lv1 stripesize "256.00k"
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
aux wait_for_sync $vg $lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Use the additonal space gained by adding stripes
|
||||
resize2fs $DM_DEV_DIR/$vg/$lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Convert it to striped
|
||||
# FIXME: _lvconvert fails here?
|
||||
lvconvert -y --ty striped $vg/$lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
check lv_first_seg_field $vg/$lv1 segtype "striped"
|
||||
check lv_first_seg_field $vg/$lv1 stripes 3
|
||||
check lv_first_seg_field $vg/$lv1 stripesize "256.00k"
|
||||
|
||||
vgremove -ff $vg
|
@ -132,8 +132,12 @@ _reshape_layout raid5_ls 15 $vg $lv1 --stripes 14
|
||||
# Convert raid5_ls to 63 stripes
|
||||
_reshape_layout raid5_ls 64 $vg $lv1 --stripes 63
|
||||
|
||||
# Convert raid5_ls back to 27 stripes
|
||||
_reshape_layout raid5_ls 64 $vg $lv1 --stripes 27 --force
|
||||
_reshape_layout raid5_ls 28 $vg $lv1 --stripes 27
|
||||
|
||||
# Convert raid5_ls back to 4 stripes
|
||||
_reshape_layout raid5_ls 15 $vg $lv1 --stripes 4 --force
|
||||
_reshape_layout raid5_ls 28 $vg $lv1 --stripes 4 --force
|
||||
_reshape_layout raid5_ls 5 $vg $lv1 --stripes 4
|
||||
|
||||
# Convert raid5_ls back to 3 stripes
|
||||
|
@ -1,65 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Copyright (C) 2017 Red Hat, Inc. All rights reserved.
|
||||
#
|
||||
# This copyrighted material is made available to anyone wishing to use,
|
||||
# modify, copy, or redistribute it subject to the terms and conditions
|
||||
# of the GNU General Public License v.2.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA2110-1301 USA
|
||||
|
||||
SKIP_WITH_LVMLOCKD=1
|
||||
SKIP_WITH_LVMPOLLD=1
|
||||
|
||||
. lib/inittest
|
||||
|
||||
which mkfs.ext4 || skip
|
||||
aux have_raid 1 10 2 || skip
|
||||
|
||||
aux prepare_vg 5
|
||||
|
||||
# Create 4-way striped LV
|
||||
lvcreate -aey --ty striped -i4 -L16M -n $lv1 $vg
|
||||
check lv_field $vg/$lv1 segtype "striped"
|
||||
check lv_field $vg/$lv1 stripes 4
|
||||
echo y|mkfs -t ext4 $DM_DEV_DIR/$vg/$lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Upconvert to raid5_n
|
||||
lvconvert -y --ty raid5 $vg/$lv1
|
||||
check lv_field $vg/$lv1 segtype "raid5_n"
|
||||
check lv_field $vg/$lv1 stripes 5
|
||||
check lv_field $vg/$lv1 stripesize "64.00k"
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
aux wait_for_sync $vg $lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Grow it *4 to keep the given fs
|
||||
lvresize -L64M $vg/$lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
check lv_first_seg_field $vg/$lv1 lv_size "64.00m"
|
||||
aux wait_for_sync $vg $lv1
|
||||
|
||||
# Convert to 1 stripe
|
||||
lvconvert -y -f --stripes 1 $vg/$lv1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
aux wait_for_sync $vg $lv1 1
|
||||
lvconvert --stripes 1 $vg/$lv1
|
||||
check lv_first_seg_field $vg/$lv1 stripes 2
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Convert to raid1
|
||||
lvconvert -y --ty raid1 $vg/$lv1
|
||||
check lv_first_seg_field $vg/$lv1 segtype "raid1"
|
||||
check lv_first_seg_field $vg/$lv1 stripes 2
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
# Convert to linear
|
||||
lvconvert -y --ty linear $vg/$lv1
|
||||
# lvconvert -y -m 0 $vg/$lv1
|
||||
check lv_first_seg_field $vg/$lv1 segtype "linear"
|
||||
check lv_first_seg_field $vg/$lv1 stripes 1
|
||||
fsck -fn $DM_DEV_DIR/$vg/$lv1
|
||||
|
||||
vgremove -ff $vg
|
@ -739,6 +739,21 @@ static int _lvchange_writemostly(struct logical_volume *lv)
|
||||
struct cmd_context *cmd = lv->vg->cmd;
|
||||
struct lv_segment *raid_seg = first_seg(lv);
|
||||
|
||||
/*
|
||||
* Prohibit on synchronization.
|
||||
*
|
||||
* FIXME: we can do better once we can distingush between
|
||||
* an initial sync after a linear -> raid1 upconversion
|
||||
* and any later additions of legs, requested resyncs
|
||||
* via lvchange or leg repairs/replacements.
|
||||
*/
|
||||
if (!lv_raid_in_sync(lv)) {
|
||||
log_error("Unable to change write%s on %s while it is not in-sync.",
|
||||
arg_is_set(cmd, writemostly_ARG) ? "mostly" : "behind",
|
||||
display_lvname(lv));
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (arg_is_set(cmd, writebehind_ARG))
|
||||
raid_seg->writebehind = arg_uint_value(cmd, writebehind_ARG, 0);
|
||||
|
||||
@ -816,7 +831,6 @@ static int _lvchange_writemostly(struct logical_volume *lv)
|
||||
}
|
||||
}
|
||||
|
||||
/* FIXME: prohibit on primary if not in-sync! */
|
||||
if (!lv_update_and_reload(lv))
|
||||
return_0;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user