From: Dave Wysochanski Date: Tue, 12 Oct 2010 16:11:48 +0000 (+0000) Subject: Refactor and add code for (lv) 'origin_size' get function. X-Git-Tag: v2_02_91~1495 X-Git-Url: https://sourceware.org/git/?a=commitdiff_plain;h=29636f38e3068852ef85fc838a95584c8441941c;p=lvm2.git Refactor and add code for (lv) 'origin_size' get function. Signed-off-by: Dave Wysochanski Reviewed-By: Petr Rockai --- diff --git a/lib/metadata/lv.c b/lib/metadata/lv.c index d63ce2957..48707ff84 100644 --- a/lib/metadata/lv.c +++ b/lib/metadata/lv.c @@ -18,6 +18,15 @@ #include "activate.h" #include "toolcontext.h" +uint64_t lv_origin_size(const struct logical_volume *lv) +{ + if (lv_is_cow(lv)) + return (uint64_t) find_cow(lv)->len * lv->vg->extent_size; + if (lv_is_origin(lv)) + return lv->size; + return 0; +} + char *lv_path_dup(struct dm_pool *mem, const struct logical_volume *lv) { char *repstr; diff --git a/lib/metadata/lv.h b/lib/metadata/lv.h index eee281150..69c4077ac 100644 --- a/lib/metadata/lv.h +++ b/lib/metadata/lv.h @@ -53,5 +53,6 @@ char *lv_attr_dup(struct dm_pool *mem, const struct logical_volume *lv); char *lv_uuid_dup(const struct logical_volume *lv); char *lv_tags_dup(const struct logical_volume *lv); char *lv_path_dup(struct dm_pool *mem, const struct logical_volume *lv); +uint64_t lv_origin_size(const struct logical_volume *lv); #endif diff --git a/lib/report/properties.c b/lib/report/properties.c index 8890e273e..27503a95f 100644 --- a/lib/report/properties.c +++ b/lib/report/properties.c @@ -123,7 +123,7 @@ GET_LV_NUM_PROPERTY_FN(seg_count, dm_list_size(&lv->segments)) #define _seg_count_set _not_implemented_set #define _origin_get _not_implemented_get #define _origin_set _not_implemented_set -#define _origin_size_get _not_implemented_get +GET_LV_NUM_PROPERTY_FN(origin_size, lv_origin_size(lv)) #define _origin_size_set _not_implemented_set #define _snap_percent_get _not_implemented_get #define _snap_percent_set _not_implemented_set diff --git a/lib/report/report.c b/lib/report/report.c index 32559b898..83216b28a 100644 --- a/lib/report/report.c +++ b/lib/report/report.c @@ -570,12 +570,7 @@ static int _originsize_disp(struct dm_report *rh, struct dm_pool *mem, const struct logical_volume *lv = (const struct logical_volume *) data; uint64_t size; - if (lv_is_cow(lv)) - size = (uint64_t) find_cow(lv)->len * lv->vg->extent_size; - else if (lv_is_origin(lv)) - size = lv->size; - else - size = UINT64_C(0); + size = lv_origin_size(lv); return _size64_disp(rh, mem, field, &size, private); }