mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
cache: improve wait for cache clear
Avoid printing misleading message about single dirty block. Instead properly detect condition where the 'cleaner' policy needs to be installed without 'overloading' dirty variable. Also print warning if we would be clearing read-only volume. (it really shouldn't happen).
This commit is contained in:
parent
36f609e513
commit
bf157ed833
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.169 -
|
Version 2.02.169 -
|
||||||
=====================================
|
=====================================
|
||||||
|
Avoid shifting by one number of blocks when clearing dirty cache volume.
|
||||||
Extend metadata validation of external origin LV use count.
|
Extend metadata validation of external origin LV use count.
|
||||||
Fix dm table when the last user of active external origin is removed.
|
Fix dm table when the last user of active external origin is removed.
|
||||||
Improve reported lvs status for active external origin volume.
|
Improve reported lvs status for active external origin volume.
|
||||||
|
@ -383,7 +383,7 @@ int lv_cache_wait_for_clean(struct logical_volume *cache_lv, int *is_clean)
|
|||||||
const struct logical_volume *lock_lv = lv_lock_holder(cache_lv);
|
const struct logical_volume *lock_lv = lv_lock_holder(cache_lv);
|
||||||
struct lv_segment *cache_seg = first_seg(cache_lv);
|
struct lv_segment *cache_seg = first_seg(cache_lv);
|
||||||
struct lv_status_cache *status;
|
struct lv_status_cache *status;
|
||||||
int cleaner_policy;
|
int cleaner_policy, writeback;
|
||||||
uint64_t dirty_blocks;
|
uint64_t dirty_blocks;
|
||||||
|
|
||||||
*is_clean = 0;
|
*is_clean = 0;
|
||||||
@ -402,14 +402,11 @@ int lv_cache_wait_for_clean(struct logical_volume *cache_lv, int *is_clean)
|
|||||||
|
|
||||||
cleaner_policy = !strcmp(status->cache->policy_name, "cleaner");
|
cleaner_policy = !strcmp(status->cache->policy_name, "cleaner");
|
||||||
dirty_blocks = status->cache->dirty_blocks;
|
dirty_blocks = status->cache->dirty_blocks;
|
||||||
|
writeback = (status->cache->feature_flags & DM_CACHE_FEATURE_WRITEBACK);
|
||||||
/* No clear policy and writeback mode means dirty */
|
|
||||||
if (!cleaner_policy &&
|
|
||||||
(status->cache->feature_flags & DM_CACHE_FEATURE_WRITEBACK))
|
|
||||||
dirty_blocks++;
|
|
||||||
dm_pool_destroy(status->mem);
|
dm_pool_destroy(status->mem);
|
||||||
|
|
||||||
if (!dirty_blocks)
|
/* Only clear when policy is Clear or mode != writeback */
|
||||||
|
if (!dirty_blocks && (cleaner_policy || !writeback))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
log_print_unless_silent("Flushing " FMTu64 " blocks for cache %s.",
|
log_print_unless_silent("Flushing " FMTu64 " blocks for cache %s.",
|
||||||
@ -420,6 +417,12 @@ int lv_cache_wait_for_clean(struct logical_volume *cache_lv, int *is_clean)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!(cache_lv->status & LVM_WRITE)) {
|
||||||
|
log_warn("WARNING: Dirty blocks found on read-only cache volume %s.",
|
||||||
|
display_lvname(cache_lv));
|
||||||
|
/* TODO: can we actually clean something? */
|
||||||
|
}
|
||||||
|
|
||||||
/* Switch to cleaner policy to flush the cache */
|
/* Switch to cleaner policy to flush the cache */
|
||||||
cache_seg->cleaner_policy = 1;
|
cache_seg->cleaner_policy = 1;
|
||||||
/* Reaload kernel with "cleaner" policy */
|
/* Reaload kernel with "cleaner" policy */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user