mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
lv: add common lv_origin_lv fn for use in report and dup, use brackets for invisible devices
The common lv_origin_lv fn avoids code duplication and also the reporting part now uses _lvname_disp and _uuid_disp to display name and uuid respectively, including brackets for the name if the dev is invisible.
This commit is contained in:
parent
1bd83814ce
commit
aae45a1f21
@ -236,11 +236,9 @@ uint32_t lv_kernel_read_ahead(const struct logical_volume *lv)
|
|||||||
return info.read_ahead;
|
return info.read_ahead;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *_do_lv_origin_dup(struct dm_pool *mem, const struct logical_volume *lv,
|
struct logical_volume *lv_origin_lv(const struct logical_volume *lv)
|
||||||
int uuid)
|
|
||||||
{
|
{
|
||||||
struct logical_volume *origin;
|
struct logical_volume *origin = NULL;
|
||||||
|
|
||||||
|
|
||||||
if (lv_is_cow(lv))
|
if (lv_is_cow(lv))
|
||||||
origin = origin_from_cow(lv);
|
origin = origin_from_cow(lv);
|
||||||
@ -250,13 +248,22 @@ static char *_do_lv_origin_dup(struct dm_pool *mem, const struct logical_volume
|
|||||||
origin = first_seg(lv)->origin;
|
origin = first_seg(lv)->origin;
|
||||||
else if (lv_is_thin_volume(lv) && first_seg(lv)->external_lv)
|
else if (lv_is_thin_volume(lv) && first_seg(lv)->external_lv)
|
||||||
origin = first_seg(lv)->external_lv;
|
origin = first_seg(lv)->external_lv;
|
||||||
else
|
|
||||||
|
return origin;
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *_do_lv_origin_dup(struct dm_pool *mem, const struct logical_volume *lv,
|
||||||
|
int uuid)
|
||||||
|
{
|
||||||
|
struct logical_volume *origin_lv = lv_origin_lv(lv);
|
||||||
|
|
||||||
|
if (!lv)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (uuid)
|
if (uuid)
|
||||||
return lv_uuid_dup(mem, origin);
|
return lv_uuid_dup(mem, origin_lv);
|
||||||
else
|
else
|
||||||
return lv_name_dup(mem, origin);
|
return lv_name_dup(mem, origin_lv);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *lv_origin_dup(struct dm_pool *mem, const struct logical_volume *lv)
|
char *lv_origin_dup(struct dm_pool *mem, const struct logical_volume *lv)
|
||||||
|
@ -87,6 +87,7 @@ char *lv_name_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
|||||||
char *lv_fullname_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
char *lv_fullname_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
||||||
struct logical_volume *lv_parent(const struct logical_volume *lv);
|
struct logical_volume *lv_parent(const struct logical_volume *lv);
|
||||||
struct logical_volume *lv_convert_lv(const struct logical_volume *lv);
|
struct logical_volume *lv_convert_lv(const struct logical_volume *lv);
|
||||||
|
struct logical_volume *lv_origin_lv(const struct logical_volume *lv);
|
||||||
char *lv_parent_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
char *lv_parent_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
||||||
char *lv_origin_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
char *lv_origin_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
||||||
char *lv_origin_uuid_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
char *lv_origin_uuid_dup(struct dm_pool *mem, const struct logical_volume *lv);
|
||||||
|
@ -1795,24 +1795,15 @@ static int _do_origin_disp(struct dm_report *rh, struct dm_pool *mem,
|
|||||||
int uuid)
|
int uuid)
|
||||||
{
|
{
|
||||||
const struct logical_volume *lv = (const struct logical_volume *) data;
|
const struct logical_volume *lv = (const struct logical_volume *) data;
|
||||||
const struct lv_segment *seg = first_seg(lv);
|
struct logical_volume *origin_lv = lv_origin_lv(lv);
|
||||||
struct logical_volume *origin;
|
|
||||||
|
|
||||||
if (lv_is_cow(lv))
|
if (!origin_lv)
|
||||||
origin = origin_from_cow(lv);
|
|
||||||
else if (lv_is_cache(lv) && !lv_is_pending_delete(lv))
|
|
||||||
origin = seg_lv(seg, 0);
|
|
||||||
else if (lv_is_thin_volume(lv) && first_seg(lv)->origin)
|
|
||||||
origin = first_seg(lv)->origin;
|
|
||||||
else if (lv_is_thin_volume(lv) && first_seg(lv)->external_lv)
|
|
||||||
origin = first_seg(lv)->external_lv;
|
|
||||||
else
|
|
||||||
return _field_set_value(field, "", NULL);
|
return _field_set_value(field, "", NULL);
|
||||||
|
|
||||||
if (uuid)
|
if (uuid)
|
||||||
return _uuid_disp(rh, mem, field, &origin->lvid.id[1], private);
|
return _uuid_disp(rh, mem, field, &origin_lv->lvid.id[1], private);
|
||||||
else
|
else
|
||||||
return _lvname_disp(rh, mem, field, origin, private);
|
return _lvname_disp(rh, mem, field, origin_lv, private);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _origin_disp(struct dm_report *rh, struct dm_pool *mem,
|
static int _origin_disp(struct dm_report *rh, struct dm_pool *mem,
|
||||||
|
Loading…
Reference in New Issue
Block a user