mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
cache: support no_discard_passdown
Recent kernel version from kernel commit: de7180ff908b2bc0342e832dbdaa9a5f1ecaa33a started to report in cache status line new flag: no_discard_passdown Whenever lvm spots unknown status it reports: Unknown feature in status: So add reconginzing this feature flag and also report this with 'lvs -o+kernel_discards' When no_discard_passdown is found in status 'nopassdown' gets reported for this field (roughly matching what we report for thin-pools).
This commit is contained in:
parent
d18e491f68
commit
e3c4ab0cc7
@ -1,5 +1,6 @@
|
|||||||
Version 2.03.02 -
|
Version 2.03.02 -
|
||||||
===================================
|
===================================
|
||||||
|
Report no_discard_passdown for cache LVs with lvs -o+kernel_discards.
|
||||||
Add pvck --dump option to extract metadata.
|
Add pvck --dump option to extract metadata.
|
||||||
Fix signal delivery checking race in libdaemon (lvmetad).
|
Fix signal delivery checking race in libdaemon (lvmetad).
|
||||||
Add missing Before=shutdown.target to LVM2 services to fix shutdown ordering.
|
Add missing Before=shutdown.target to LVM2 services to fix shutdown ordering.
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
Version 1.02.155 -
|
Version 1.02.155 -
|
||||||
====================================
|
====================================
|
||||||
|
Parsing of cache status understand no_discard_passdown.
|
||||||
Ensure migration_threshold for cache is at least 8 chunks.
|
Ensure migration_threshold for cache is at least 8 chunks.
|
||||||
Include correct internal header inside libdm list.c.
|
Include correct internal header inside libdm list.c.
|
||||||
Enhance ioctl flattening and add parameters only when needed.
|
Enhance ioctl flattening and add parameters only when needed.
|
||||||
|
@ -903,6 +903,7 @@ int dm_tree_node_add_raid_target_with_params_v2(struct dm_tree_node *node,
|
|||||||
#define DM_CACHE_FEATURE_WRITETHROUGH 0x00000002
|
#define DM_CACHE_FEATURE_WRITETHROUGH 0x00000002
|
||||||
#define DM_CACHE_FEATURE_PASSTHROUGH 0x00000004
|
#define DM_CACHE_FEATURE_PASSTHROUGH 0x00000004
|
||||||
#define DM_CACHE_FEATURE_METADATA2 0x00000008 /* cache v1.10 */
|
#define DM_CACHE_FEATURE_METADATA2 0x00000008 /* cache v1.10 */
|
||||||
|
#define DM_CACHE_FEATURE_NO_DISCARD_PASSDOWN 0x00000010
|
||||||
|
|
||||||
struct dm_config_node;
|
struct dm_config_node;
|
||||||
/*
|
/*
|
||||||
|
@ -296,6 +296,8 @@ int dm_get_status_cache(struct dm_pool *mem, const char *params,
|
|||||||
s->feature_flags |= DM_CACHE_FEATURE_PASSTHROUGH;
|
s->feature_flags |= DM_CACHE_FEATURE_PASSTHROUGH;
|
||||||
else if (!strncmp(p, "metadata2 ", 10))
|
else if (!strncmp(p, "metadata2 ", 10))
|
||||||
s->feature_flags |= DM_CACHE_FEATURE_METADATA2;
|
s->feature_flags |= DM_CACHE_FEATURE_METADATA2;
|
||||||
|
else if (!strncmp(p, "no_discard_passdown ", 20))
|
||||||
|
s->feature_flags |= DM_CACHE_FEATURE_NO_DISCARD_PASSDOWN;
|
||||||
else
|
else
|
||||||
log_error("Unknown feature in status: %s", params);
|
log_error("Unknown feature in status: %s", params);
|
||||||
|
|
||||||
|
@ -245,6 +245,11 @@ char *lvseg_kernel_discards_dup_with_info_and_seg_status(struct dm_pool *mem, co
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
s = get_pool_discards_name(d);
|
s = get_pool_discards_name(d);
|
||||||
|
} else if (lvdm->seg_status.type == SEG_STATUS_CACHE) {
|
||||||
|
if (lvdm->seg_status.cache->feature_flags &
|
||||||
|
DM_CACHE_FEATURE_NO_DISCARD_PASSDOWN) {
|
||||||
|
s = "nopassdown";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(ret = dm_pool_strdup(mem, s))) {
|
if (!(ret = dm_pool_strdup(mem, s))) {
|
||||||
|
@ -1893,6 +1893,7 @@ int dm_tree_node_add_raid_target_with_params_v2(struct dm_tree_node *node,
|
|||||||
#define DM_CACHE_FEATURE_WRITETHROUGH 0x00000002
|
#define DM_CACHE_FEATURE_WRITETHROUGH 0x00000002
|
||||||
#define DM_CACHE_FEATURE_PASSTHROUGH 0x00000004
|
#define DM_CACHE_FEATURE_PASSTHROUGH 0x00000004
|
||||||
#define DM_CACHE_FEATURE_METADATA2 0x00000008 /* cache v1.10 */
|
#define DM_CACHE_FEATURE_METADATA2 0x00000008 /* cache v1.10 */
|
||||||
|
#define DM_CACHE_FEATURE_NO_DISCARD_PASSDOWN 0x00000010
|
||||||
|
|
||||||
struct dm_config_node;
|
struct dm_config_node;
|
||||||
/*
|
/*
|
||||||
|
@ -296,6 +296,8 @@ int dm_get_status_cache(struct dm_pool *mem, const char *params,
|
|||||||
s->feature_flags |= DM_CACHE_FEATURE_PASSTHROUGH;
|
s->feature_flags |= DM_CACHE_FEATURE_PASSTHROUGH;
|
||||||
else if (!strncmp(p, "metadata2 ", 10))
|
else if (!strncmp(p, "metadata2 ", 10))
|
||||||
s->feature_flags |= DM_CACHE_FEATURE_METADATA2;
|
s->feature_flags |= DM_CACHE_FEATURE_METADATA2;
|
||||||
|
else if (!strncmp(p, "no_discard_passdown ", 20))
|
||||||
|
s->feature_flags |= DM_CACHE_FEATURE_NO_DISCARD_PASSDOWN;
|
||||||
else
|
else
|
||||||
log_error("Unknown feature in status: %s", params);
|
log_error("Unknown feature in status: %s", params);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user