while (lv_is_cache(lv) || /* _corig */
lv_is_integrity(lv) ||
lv_is_thin_pool(lv) || /* _tdata */
- lv_is_vdo_pool(lv)) /* _vdata */
+ lv_is_vdo_pool(lv) || /* _vdata */
+ lv_is_writecache(lv)) /* _worigin */
lv = seg_lv(first_seg(lv), 0); /* component-level down */
return lv;
return (lv_is_cache_origin(lv) ||
lv_is_integrity_origin(lv) ||
lv_is_thin_pool_data(lv) ||
- lv_is_vdo_pool_data(lv));
+ lv_is_vdo_pool_data(lv) ||
+ lv_is_writecache_origin(lv));
}
/* Find the topmost LV in the stack - usually such LV is visible. */
struct volume_group *vg = lv->vg;
struct lv_segment *seg = first_seg(lv);
- if (lv_is_writecache(lv)) {
- log_error("Resize not yet allowed on LVs with writecache attached.");
- return 0;
- }
-
if (lv_is_external_origin(lv)) {
/*
* Since external-origin can be activated read-only,
display_lvname(lv));
return 0;
}
+ if (lv_is_writecache(lv)) {
+ /* TODO: detect kernel with support for reduction */
+ log_error("Reduce not yet allowed on LVs with writecache attached.");
+ return 0;
+ }
} else if (lp->resize == LV_EXTEND) {
if (lv_is_thin_pool_metadata(lv) &&
(!(seg = find_pool_seg(first_seg(lv))) ||