mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
display: basic vdo segment lvdisplay and lvs support
Print some basic info about vdo segment. 'lvdisplay -m' ATM shows the most. lvs shows usage percentage.
This commit is contained in:
parent
4f708e8709
commit
5807993bbf
@ -411,6 +411,7 @@ int lvdisplay_full(struct cmd_context *cmd,
|
|||||||
int thin_active = 0;
|
int thin_active = 0;
|
||||||
dm_percent_t thin_percent;
|
dm_percent_t thin_percent;
|
||||||
struct lv_status_cache *cache_status = NULL;
|
struct lv_status_cache *cache_status = NULL;
|
||||||
|
struct lv_status_vdo *vdo_status = NULL;
|
||||||
|
|
||||||
if (lv_is_historical(lv))
|
if (lv_is_historical(lv))
|
||||||
return _lvdisplay_historical_full(cmd, lv);
|
return _lvdisplay_historical_full(cmd, lv);
|
||||||
@ -529,6 +530,27 @@ int lvdisplay_full(struct cmd_context *cmd,
|
|||||||
seg = first_seg(lv);
|
seg = first_seg(lv);
|
||||||
log_print("LV Pool metadata %s", seg->metadata_lv->name);
|
log_print("LV Pool metadata %s", seg->metadata_lv->name);
|
||||||
log_print("LV Pool data %s", seg_lv(seg, 0)->name);
|
log_print("LV Pool data %s", seg_lv(seg, 0)->name);
|
||||||
|
} else if (lv_is_vdo_pool(lv)) {
|
||||||
|
seg = first_seg(lv);
|
||||||
|
log_print("LV VDO Pool data %s", seg_lv(seg, 0)->name);
|
||||||
|
if (inkernel && lv_vdo_pool_status(lv, 0, &vdo_status)) { /* FIXME: flush option? */
|
||||||
|
log_print("LV VDO Pool usage %s%%",
|
||||||
|
display_percent(cmd, vdo_status->usage));
|
||||||
|
log_print("LV VDO Pool saving %s%%",
|
||||||
|
display_percent(cmd, vdo_status->saving));
|
||||||
|
log_print("LV VDO Operating mode %s",
|
||||||
|
get_vdo_operating_mode_name(vdo_status->vdo->operating_mode));
|
||||||
|
log_print("LV VDO Index state %s",
|
||||||
|
get_vdo_index_state_name(vdo_status->vdo->index_state));
|
||||||
|
log_print("LV VDO Compression st %s",
|
||||||
|
get_vdo_compression_state_name(vdo_status->vdo->compression_state));
|
||||||
|
log_print("LV VDO Used size %s",
|
||||||
|
display_size(cmd, vdo_status->vdo->used_blocks * DM_VDO_BLOCK_SIZE));
|
||||||
|
dm_pool_destroy(vdo_status->mem);
|
||||||
|
}
|
||||||
|
} else if (lv_is_vdo(lv)) {
|
||||||
|
seg = first_seg(lv);
|
||||||
|
log_print("LV VDO Pool name %s", seg_lv(seg, 0)->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inkernel && info.suspended)
|
if (inkernel && info.suspended)
|
||||||
|
@ -450,6 +450,9 @@ dm_percent_t lvseg_percent_with_info_and_seg_status(const struct lv_with_info_an
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case SEG_STATUS_VDO_POOL:
|
||||||
|
p = s->vdo_pool.usage;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
p = DM_PERCENT_INVALID;
|
p = DM_PERCENT_INVALID;
|
||||||
}
|
}
|
||||||
@ -695,11 +698,13 @@ char *lv_mirror_log_uuid_dup(struct dm_pool *mem, const struct logical_volume *l
|
|||||||
|
|
||||||
struct logical_volume *lv_pool_lv(const struct logical_volume *lv)
|
struct logical_volume *lv_pool_lv(const struct logical_volume *lv)
|
||||||
{
|
{
|
||||||
struct lv_segment *seg = (lv_is_thin_volume(lv) || lv_is_cache(lv)) ?
|
if (lv_is_thin_volume(lv) || lv_is_cache(lv))
|
||||||
first_seg(lv) : NULL;
|
return first_seg(lv)->pool_lv;
|
||||||
struct logical_volume *pool_lv = seg ? seg->pool_lv : NULL;
|
|
||||||
|
|
||||||
return pool_lv;
|
if (lv_is_vdo(lv))
|
||||||
|
return seg_lv(first_seg(lv), 0);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *_do_lv_pool_lv_dup(struct dm_pool *mem, const struct logical_volume *lv,
|
static char *_do_lv_pool_lv_dup(struct dm_pool *mem, const struct logical_volume *lv,
|
||||||
@ -728,7 +733,9 @@ char *lv_pool_lv_uuid_dup(struct dm_pool *mem, const struct logical_volume *lv)
|
|||||||
|
|
||||||
struct logical_volume *lv_data_lv(const struct logical_volume *lv)
|
struct logical_volume *lv_data_lv(const struct logical_volume *lv)
|
||||||
{
|
{
|
||||||
struct lv_segment *seg = (lv_is_thin_pool(lv) || lv_is_cache_pool(lv)) ?
|
struct lv_segment *seg = (lv_is_cache_pool(lv) ||
|
||||||
|
lv_is_thin_pool(lv) ||
|
||||||
|
lv_is_vdo_pool(lv)) ?
|
||||||
first_seg(lv) : NULL;
|
first_seg(lv) : NULL;
|
||||||
struct logical_volume *data_lv = seg ? seg_lv(seg, 0) : NULL;
|
struct logical_volume *data_lv = seg ? seg_lv(seg, 0) : NULL;
|
||||||
|
|
||||||
@ -1181,6 +1188,13 @@ char *lv_attr_dup_with_info_and_seg_status(struct dm_pool *mem, const struct lv_
|
|||||||
else if (lv_is_thin_volume(lv))
|
else if (lv_is_thin_volume(lv))
|
||||||
repstr[0] = lv_is_merging_origin(lv) ?
|
repstr[0] = lv_is_merging_origin(lv) ?
|
||||||
'O' : (lv_is_merging_thin_snapshot(lv) ? 'S' : 'V');
|
'O' : (lv_is_merging_thin_snapshot(lv) ? 'S' : 'V');
|
||||||
|
//else if (lv_is_vdo(lv))
|
||||||
|
// repstr[0] = 'V'; // TODO: Show 'V' like Virtual Thin ?
|
||||||
|
// ATM shows 'v' as virtual target just like: error, zero
|
||||||
|
else if (lv_is_vdo_pool(lv))
|
||||||
|
repstr[0] = 'd';
|
||||||
|
else if (lv_is_vdo_pool_data(lv))
|
||||||
|
repstr[0] = 'D';
|
||||||
else if (lv_is_virtual(lv))
|
else if (lv_is_virtual(lv))
|
||||||
repstr[0] = 'v';
|
repstr[0] = 'v';
|
||||||
else if (lv_is_thin_pool(lv))
|
else if (lv_is_thin_pool(lv))
|
||||||
|
@ -66,6 +66,11 @@ static const char *_vdo_name(const struct lv_segment *seg)
|
|||||||
return SEG_TYPE_NAME_VDO;
|
return SEG_TYPE_NAME_VDO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void _vdo_display(const struct lv_segment *seg)
|
||||||
|
{
|
||||||
|
display_stripe(seg, 0, " ");
|
||||||
|
}
|
||||||
|
|
||||||
static int _vdo_text_import(struct lv_segment *seg,
|
static int _vdo_text_import(struct lv_segment *seg,
|
||||||
const struct dm_config_node *n,
|
const struct dm_config_node *n,
|
||||||
struct dm_hash_table *pv_hash __attribute__((unused)))
|
struct dm_hash_table *pv_hash __attribute__((unused)))
|
||||||
@ -150,6 +155,43 @@ static const char *_vdo_pool_name(const struct lv_segment *seg)
|
|||||||
return SEG_TYPE_NAME_VDO_POOL;
|
return SEG_TYPE_NAME_VDO_POOL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void _vdo_pool_display(const struct lv_segment *seg)
|
||||||
|
{
|
||||||
|
struct cmd_context *cmd = seg->lv->vg->cmd;
|
||||||
|
const struct dm_vdo_target_params *vtp = &seg->vdo_params;
|
||||||
|
|
||||||
|
log_print(" Virtual size\t%s", display_size(cmd, get_vdo_pool_virtual_size(seg)));
|
||||||
|
log_print(" Header size\t\t%s", display_size(cmd, seg->vdo_pool_header_size));
|
||||||
|
|
||||||
|
_print_yes_no("Compression\t", vtp->use_compression);
|
||||||
|
_print_yes_no("Deduplication", vtp->use_deduplication);
|
||||||
|
_print_yes_no("Emulate 512 sectors", vtp->emulate_512_sectors);
|
||||||
|
|
||||||
|
log_print(" Block map cache sz\t%s",
|
||||||
|
display_size(cmd, vtp->block_map_cache_size_mb * UINT64_C(2 * 1024)));
|
||||||
|
log_print(" Block map period\t%u", vtp->block_map_period);
|
||||||
|
|
||||||
|
_print_yes_no("Sparse index", vtp->use_sparse_index);
|
||||||
|
|
||||||
|
log_print(" Index memory size\t%s",
|
||||||
|
display_size(cmd, vtp->index_memory_size_mb * UINT64_C(2 * 1024)));
|
||||||
|
|
||||||
|
_print_yes_no("Using read cache", vtp->use_read_cache);
|
||||||
|
|
||||||
|
log_print(" Read cache size\t%s",
|
||||||
|
display_size(cmd, vtp->read_cache_size_mb * UINT64_C(2 * 1024)));
|
||||||
|
log_print(" Slab size\t\t%s",
|
||||||
|
display_size(cmd, vtp->slab_size_mb * UINT64_C(2 * 1024)));
|
||||||
|
|
||||||
|
log_print(" # Ack threads\t%u", (unsigned) vtp->ack_threads);
|
||||||
|
log_print(" # Bio threads\t%u", (unsigned) vtp->bio_threads);
|
||||||
|
log_print(" Bio rotation\t%u", (unsigned) vtp->bio_rotation);
|
||||||
|
log_print(" # CPU threads\t%u", (unsigned) vtp->cpu_threads);
|
||||||
|
log_print(" # Hash zone threads\t%u", (unsigned) vtp->hash_zone_threads);
|
||||||
|
log_print(" # Logical threads\t%u", (unsigned) vtp->logical_threads);
|
||||||
|
log_print(" # Physical threads\t%u", (unsigned) vtp->physical_threads);
|
||||||
|
}
|
||||||
|
|
||||||
/* reused as _vdo_text_import_area_count */
|
/* reused as _vdo_text_import_area_count */
|
||||||
static int _vdo_pool_text_import_area_count(const struct dm_config_node *sn __attribute__((unused)),
|
static int _vdo_pool_text_import_area_count(const struct dm_config_node *sn __attribute__((unused)),
|
||||||
uint32_t *area_count)
|
uint32_t *area_count)
|
||||||
@ -419,6 +461,7 @@ static void _vdo_pool_destroy(struct segment_type *segtype)
|
|||||||
|
|
||||||
static struct segtype_handler _vdo_ops = {
|
static struct segtype_handler _vdo_ops = {
|
||||||
.name = _vdo_name,
|
.name = _vdo_name,
|
||||||
|
.display = _vdo_display,
|
||||||
.text_import = _vdo_text_import,
|
.text_import = _vdo_text_import,
|
||||||
.text_import_area_count = _vdo_pool_text_import_area_count,
|
.text_import_area_count = _vdo_pool_text_import_area_count,
|
||||||
.text_export = _vdo_text_export,
|
.text_export = _vdo_text_export,
|
||||||
@ -434,6 +477,7 @@ static struct segtype_handler _vdo_ops = {
|
|||||||
|
|
||||||
static struct segtype_handler _vdo_pool_ops = {
|
static struct segtype_handler _vdo_pool_ops = {
|
||||||
.name = _vdo_pool_name,
|
.name = _vdo_pool_name,
|
||||||
|
.display = _vdo_pool_display,
|
||||||
.text_import = _vdo_pool_text_import,
|
.text_import = _vdo_pool_text_import,
|
||||||
.text_import_area_count = _vdo_pool_text_import_area_count,
|
.text_import_area_count = _vdo_pool_text_import_area_count,
|
||||||
.text_export = _vdo_pool_text_export,
|
.text_export = _vdo_pool_text_export,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user