1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-18 10:04:20 +03:00

metadata: use lv_set_name for raid and mirror

Use lv_set_name API also for raid and mirror LV manipulation.
This commit is contained in:
Zdenek Kabelac 2024-10-21 13:11:28 +02:00
parent c681d4e61a
commit 956b2c568f
2 changed files with 38 additions and 16 deletions

View File

@ -596,6 +596,7 @@ static int _split_mirror_images(struct logical_volume *lv,
struct lv_list *lvl; struct lv_list *lvl;
struct cmd_context *cmd = lv->vg->cmd; struct cmd_context *cmd = lv->vg->cmd;
char layer_name[NAME_LEN], format[NAME_LEN]; char layer_name[NAME_LEN], format[NAME_LEN];
const char *lv_name;
int act; int act;
if (!lv_is_mirrored(lv)) { if (!lv_is_mirrored(lv)) {
@ -662,8 +663,8 @@ static int _split_mirror_images(struct logical_volume *lv,
return 0; return 0;
} }
new_lv->name = dm_pool_strdup(lv->vg->vgmem, split_name); if (!(lv_name = dm_pool_strdup(lv->vg->vgmem, split_name)) ||
if (!new_lv->name) { !lv_set_name(new_lv, lv_name)) {
log_error("Unable to rename newly split LV."); log_error("Unable to rename newly split LV.");
return 0; return 0;
} }
@ -699,7 +700,8 @@ static int _split_mirror_images(struct logical_volume *lv,
display_lvname(new_lv)); display_lvname(new_lv));
return 0; return 0;
} }
if (!(sub_lv->name = dm_pool_strdup(lv->vg->vgmem, layer_name))) { if (!(lv_name = dm_pool_strdup(lv->vg->vgmem, layer_name)) ||
!lv_set_name(sub_lv, lv_name)) {
log_error("Unable to allocate memory."); log_error("Unable to allocate memory.");
return 0; return 0;
} }

View File

@ -913,6 +913,7 @@ static char *_generate_raid_name(struct logical_volume *lv,
static int _shift_and_rename_image_components(struct lv_segment *seg) static int _shift_and_rename_image_components(struct lv_segment *seg)
{ {
uint32_t s, missing; uint32_t s, missing;
const char *lv_name;
/* /*
* All LVs must be properly named for their index before * All LVs must be properly named for their index before
@ -943,13 +944,15 @@ static int _shift_and_rename_image_components(struct lv_segment *seg)
display_lvname(seg_lv(seg, s)), missing); display_lvname(seg_lv(seg, s)), missing);
/* Alter rmeta name */ /* Alter rmeta name */
if (!(seg_metalv(seg, s)->name = _generate_raid_name(seg->lv, "rmeta", s - missing))) { if (!(lv_name = _generate_raid_name(seg->lv, "rmeta", s - missing)) ||
!lv_set_name(seg_metalv(seg, s), lv_name)) {
log_error("Memory allocation failed."); log_error("Memory allocation failed.");
return 0; return 0;
} }
/* Alter rimage name */ /* Alter rimage name */
if (!(seg_lv(seg, s)->name = _generate_raid_name(seg->lv, "rimage", s - missing))) { if (!(lv_name = _generate_raid_name(seg->lv, "rimage", s - missing)) ||
!lv_set_name(seg_lv(seg, s), lv_name)) {
log_error("Memory allocation failed."); log_error("Memory allocation failed.");
return 0; return 0;
} }
@ -2703,17 +2706,20 @@ static int _raid_add_images_without_commit(struct logical_volume *lv,
if (seg_is_linear(seg)) { if (seg_is_linear(seg)) {
struct dm_list *l; struct dm_list *l;
struct lv_list *lvl_tmp; struct lv_list *lvl_tmp;
const char *lv_name;
dm_list_iterate(l, &data_lvs) { dm_list_iterate(l, &data_lvs) {
if (l == dm_list_last(&data_lvs)) { if (l == dm_list_last(&data_lvs)) {
lvl = dm_list_item(l, struct lv_list); lvl = dm_list_item(l, struct lv_list);
if (!(lvl->lv->name = _generate_raid_name(lv, "rimage", count))) if (!(lv_name = _generate_raid_name(lv, "rimage", count)) ||
!lv_set_name(lvl->lv, lv_name))
return_0; return_0;
continue; continue;
} }
lvl = dm_list_item(l, struct lv_list); lvl = dm_list_item(l, struct lv_list);
lvl_tmp = dm_list_item(l->n, struct lv_list); lvl_tmp = dm_list_item(l->n, struct lv_list);
lvl->lv->name = lvl_tmp->lv->name; if (!lv_set_name(lvl->lv, lvl_tmp->lv->name))
return_0;
} }
} }
@ -2902,6 +2908,7 @@ static int _extract_image_components(struct lv_segment *seg, uint32_t idx,
{ {
struct logical_volume *data_lv = seg_lv(seg, idx); struct logical_volume *data_lv = seg_lv(seg, idx);
struct logical_volume *meta_lv = seg_metalv(seg, idx); struct logical_volume *meta_lv = seg_metalv(seg, idx);
const char *data_lv_name, *meta_lv_name;
log_very_verbose("Extracting image components %s and %s from %s.", log_very_verbose("Extracting image components %s and %s from %s.",
display_lvname(data_lv), display_lvname(data_lv),
@ -2921,10 +2928,12 @@ static int _extract_image_components(struct lv_segment *seg, uint32_t idx,
seg_type(seg, idx) = AREA_UNASSIGNED; seg_type(seg, idx) = AREA_UNASSIGNED;
seg_metatype(seg, idx) = AREA_UNASSIGNED; seg_metatype(seg, idx) = AREA_UNASSIGNED;
if (!(data_lv->name = _generate_raid_name(data_lv, "extracted", -1))) if (!(data_lv_name = _generate_raid_name(data_lv, "extracted", -1)) ||
!(meta_lv_name = _generate_raid_name(meta_lv, "extracted", -1)))
return_0; return_0;
if (!(meta_lv->name = _generate_raid_name(meta_lv, "extracted", -1))) if (!lv_set_name(data_lv, data_lv_name) ||
!lv_set_name(meta_lv, meta_lv_name))
return_0; return_0;
*extracted_rmeta = meta_lv; *extracted_rmeta = meta_lv;
@ -3413,7 +3422,8 @@ int lv_raid_split(struct logical_volume *lv, int yes, const char *split_name,
/* Get first item */ /* Get first item */
lvl = (struct lv_list *) dm_list_first(&data_list); lvl = (struct lv_list *) dm_list_first(&data_list);
lvl->lv->name = split_name; if (!lv_set_name(lvl->lv, split_name))
return_0;
if (lv->vg->lock_type && !strcmp(lv->vg->lock_type, "dlm")) if (lv->vg->lock_type && !strcmp(lv->vg->lock_type, "dlm"))
lvl->lv->lock_args = lv->lock_args; lvl->lv->lock_args = lv->lock_args;
@ -3780,6 +3790,7 @@ static int _extract_image_component_error_seg(struct lv_segment *seg,
int set_error_seg) int set_error_seg)
{ {
struct logical_volume *lv; struct logical_volume *lv;
const char *lv_name;
switch (type) { switch (type) {
case RAID_META: case RAID_META:
@ -3806,7 +3817,10 @@ static int _extract_image_component_error_seg(struct lv_segment *seg,
if (!remove_seg_from_segs_using_this_lv(lv, seg)) if (!remove_seg_from_segs_using_this_lv(lv, seg))
return_0; return_0;
if (!(lv->name = _generate_raid_name(lv, "extracted", -1))) if (!(lv_name = _generate_raid_name(lv, "extracted", -1)))
return_0;
if (!lv_set_name(lv, lv_name))
return_0; return_0;
if (set_error_seg && !replace_lv_with_error_segment(lv)) if (set_error_seg && !replace_lv_with_error_segment(lv))
@ -4138,7 +4152,8 @@ static int _convert_mirror_to_raid1(struct logical_volume *lv,
if (!(new_name = _generate_raid_name(lv, "rimage", s))) if (!(new_name = _generate_raid_name(lv, "rimage", s)))
return_0; return_0;
log_debug_metadata("Renaming %s to %s.", seg_lv(seg, s)->name, new_name); log_debug_metadata("Renaming %s to %s.", seg_lv(seg, s)->name, new_name);
seg_lv(seg, s)->name = new_name; if (!lv_set_name(seg_lv(seg, s), new_name))
return_0;
seg_lv(seg, s)->status &= ~MIRROR_IMAGE; seg_lv(seg, s)->status &= ~MIRROR_IMAGE;
seg_lv(seg, s)->status |= RAID_IMAGE; seg_lv(seg, s)->status |= RAID_IMAGE;
} }
@ -7111,8 +7126,9 @@ skip_alloc:
struct logical_volume *lv_image = seg_lv(raid_seg, s); struct logical_volume *lv_image = seg_lv(raid_seg, s);
struct logical_volume *lv_rmeta = seg_metalv(raid_seg, s); struct logical_volume *lv_rmeta = seg_metalv(raid_seg, s);
lv_rmeta->name = tmp_names[s]; if (!lv_set_name(lv_rmeta, tmp_names[s]) ||
lv_image->name = tmp_names[sd]; !lv_set_name(lv_image, tmp_names[sd]))
return_0;
if (lv_is_integrity(lv_image)) { if (lv_is_integrity(lv_image)) {
struct logical_volume *lv_imeta; struct logical_volume *lv_imeta;
@ -7131,7 +7147,9 @@ skip_alloc:
stack; stack;
continue; continue;
} }
lv_imeta->name = tmp_name_dup;
if (!lv_set_name(lv_imeta, tmp_name_dup))
return_0;
if (dm_snprintf(tmp_name_buf, NAME_LEN, "%s_iorig", lv_image->name) < 0) { if (dm_snprintf(tmp_name_buf, NAME_LEN, "%s_iorig", lv_image->name) < 0) {
stack; stack;
@ -7141,7 +7159,9 @@ skip_alloc:
stack; stack;
continue; continue;
} }
lv_iorig->name = tmp_name_dup;
if (!lv_set_name(lv_iorig, tmp_name_dup))
return_0;
} }
} }
} }