mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
lv: fix lock holder for external origin
External origin could be reloaded via more locks. It's actually even more complex then thin-pool, as it may be active on more nodes for linear LVs (and maybe even more types). External origin is always read-only thus unmodifiable device so there should not be a problem accesing it through multiple nodes. Also for thin-pool check first presence of active thin-pool. FIXME: It's not easy to detect on which nodes this device is active Thus manipulation with such device may require checking every node and it active state and refresh. But since such setup is quite complex to prepare and use, hopefully there are not user trying to 'explore' this usage yet.
This commit is contained in:
parent
a24eae6e82
commit
29b0e42be3
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.169 -
|
Version 2.02.169 -
|
||||||
=====================================
|
=====================================
|
||||||
|
Improve search of lock-holder for external origin and thin-pool.
|
||||||
Support status checking of cache volume used in layer.
|
Support status checking of cache volume used in layer.
|
||||||
Avoid shifting by one number of blocks when clearing dirty cache volume.
|
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.
|
||||||
|
@ -1551,8 +1551,13 @@ const struct logical_volume *lv_lock_holder(const struct logical_volume *lv)
|
|||||||
if (lv_is_cow(lv))
|
if (lv_is_cow(lv))
|
||||||
return lv_lock_holder(origin_from_cow(lv));
|
return lv_lock_holder(origin_from_cow(lv));
|
||||||
|
|
||||||
if (lv_is_thin_pool(lv)) {
|
if (lv_is_thin_pool(lv) ||
|
||||||
/* Find any active LV from the pool */
|
lv_is_external_origin(lv)) {
|
||||||
|
/* FIXME: Ensure cluster keeps thin-pool active exlusively.
|
||||||
|
* External origin can be activated on more nodes (depends on type).
|
||||||
|
*/
|
||||||
|
if (!lv_is_active(lv))
|
||||||
|
/* Find any active LV from the pool or external origin */
|
||||||
dm_list_iterate_items(sl, &lv->segs_using_this_lv)
|
dm_list_iterate_items(sl, &lv->segs_using_this_lv)
|
||||||
if (lv_is_active(sl->seg->lv)) {
|
if (lv_is_active(sl->seg->lv)) {
|
||||||
log_debug_activation("Thin volume %s is active.",
|
log_debug_activation("Thin volume %s is active.",
|
||||||
@ -1573,9 +1578,6 @@ const struct logical_volume *lv_lock_holder(const struct logical_volume *lv)
|
|||||||
lv_is_thin_volume(sl->seg->lv) &&
|
lv_is_thin_volume(sl->seg->lv) &&
|
||||||
first_seg(lv)->pool_lv == sl->seg->pool_lv)
|
first_seg(lv)->pool_lv == sl->seg->pool_lv)
|
||||||
continue; /* Skip thin snaphost */
|
continue; /* Skip thin snaphost */
|
||||||
if (lv_is_external_origin(lv) &&
|
|
||||||
lv_is_thin_volume(sl->seg->lv))
|
|
||||||
continue; /* Skip external origin */
|
|
||||||
if (lv_is_pending_delete(sl->seg->lv))
|
if (lv_is_pending_delete(sl->seg->lv))
|
||||||
continue; /* Skip deleted LVs */
|
continue; /* Skip deleted LVs */
|
||||||
return lv_lock_holder(sl->seg->lv);
|
return lv_lock_holder(sl->seg->lv);
|
||||||
|
Loading…
Reference in New Issue
Block a user