[lvm-devel] master - thin: report PERCENT_INVALID for failed pool
Zdenek Kabelac
zkabelac at fedoraproject.org
Thu Feb 18 15:50:20 UTC 2016
Gitweb: http://git.fedorahosted.org/git/?p=lvm2.git;a=commitdiff;h=0358ca3aadaddd8ed60c817abb67ea38bf07a420
Commit: 0358ca3aadaddd8ed60c817abb67ea38bf07a420
Parent: 0fb3669d49040ea2e616491326eecad9926048c8
Author: Zdenek Kabelac <zkabelac at redhat.com>
AuthorDate: Thu Feb 18 13:18:18 2016 +0100
Committer: Zdenek Kabelac <zkabelac at redhat.com>
CommitterDate: Thu Feb 18 16:45:42 2016 +0100
thin: report PERCENT_INVALID for failed pool
When thin-pool is in failed/error state, we can't
read percentage so report invalid value.
---
WHATS_NEW | 1 +
lib/thin/thin.c | 8 ++++++--
2 files changed, 7 insertions(+), 2 deletions(-)
diff --git a/WHATS_NEW b/WHATS_NEW
index bf3fc07..27bb7e2 100644
--- a/WHATS_NEW
+++ b/WHATS_NEW
@@ -1,5 +1,6 @@
Version 2.02.143 -
=====================================
+ For failing thin-pool and thin volume correctly report percentage as INVALID.
Report -1, not 'unkown' for lv_{snapshot_invalid,merge_failed} with --binary.
Add configure --enable-dbus-service for an LVM D-Bus service.
Replace configure --enable-python_bindings with python2 and python3 versions.
diff --git a/lib/thin/thin.c b/lib/thin/thin.c
index c9ee9f5..221ac48 100644
--- a/lib/thin/thin.c
+++ b/lib/thin/thin.c
@@ -404,8 +404,10 @@ static int _thin_pool_target_percent(void **target_state __attribute__((unused))
if (!dm_get_status_thin_pool(mem, params, &s))
return_0;
+ if (s->fail || s->error)
+ *percent = DM_PERCENT_INVALID;
/* With 'seg' report metadata percent, otherwice data percent */
- if (seg) {
+ else if (seg) {
*percent = dm_make_percent(s->used_metadata_blocks,
s->total_metadata_blocks);
*total_numerator += s->used_metadata_blocks;
@@ -622,7 +624,9 @@ static int _thin_target_percent(void **target_state __attribute__((unused)),
if (!dm_get_status_thin(mem, params, &s))
return_0;
- if (seg) {
+ if (s->fail)
+ *percent = DM_PERCENT_INVALID;
+ else if (seg) {
/* Pool allocates whole chunk so round-up to nearest one */
csize = first_seg(seg->pool_lv)->chunk_size;
csize = ((seg->lv->size + csize - 1) / csize) * csize;
More information about the lvm-devel
mailing list