mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
activation: fix activation lock
Activation lock has a primary purpose to serialize locking of individual LV in case there is no other protecting mechanism for parallel execution. However in the case an activated LV is composed from several other LVs, noone should be able to manipulate with those LVs as well. This patch add a very 'naive' global VG activation locking in this case. In the future we may introduce smarter function detecting minimal closed graph components if this will appear as bottleneck Patch checks if the VG Write lock is held - in this case we do not need any more locking - command has exclusive access to VG. In case we have clustered VG and we are activating an LV which does not need other LVs - we also do not need any more locks. In all other cases take respective lock - for single LV - use lvid, for complex LVs use vgname.
This commit is contained in:
parent
9bd7615fef
commit
e02e5b0c5b
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.176 -
|
Version 2.02.176 -
|
||||||
===================================
|
===================================
|
||||||
|
Improve selection of resource name for activation lock.
|
||||||
Avoid cutting 1st. character of resource name for activation lock.
|
Avoid cutting 1st. character of resource name for activation lock.
|
||||||
Support for encrypted devices in fsadm.
|
Support for encrypted devices in fsadm.
|
||||||
Improve thin pool overprovisioning and repair warning messages.
|
Improve thin pool overprovisioning and repair warning messages.
|
||||||
|
@ -174,14 +174,20 @@ int check_lvm1_vg_inactive(struct cmd_context *cmd, const char *vgname);
|
|||||||
/*
|
/*
|
||||||
* Activation locks are wrapped around activation commands that have to
|
* Activation locks are wrapped around activation commands that have to
|
||||||
* be processed atomically one-at-a-time.
|
* be processed atomically one-at-a-time.
|
||||||
* If a VG WRITE lock is held, an activation lock is redundant.
|
* If a VG WRITE lock is held or clustered activation activates simple LV
|
||||||
|
* an activation lock is redundant.
|
||||||
*
|
*
|
||||||
* FIXME Test and support this for thin and cache types.
|
* Some LV types do require taking a lock common for whole group of LVs.
|
||||||
* FIXME Add cluster support.
|
* TODO: For simplicity reasons ATM take a VG activation global lock and
|
||||||
|
* later more fine-grained component detection algorithm can be added
|
||||||
*/
|
*/
|
||||||
#define lv_supports_activation_locking(lv) (!vg_is_clustered((lv)->vg) && !lv_is_thin_type(lv) && !lv_is_cache_type(lv))
|
|
||||||
#define lock_activation(cmd, lv) (vg_write_lock_held() && lv_supports_activation_locking(lv) ? 1 : lock_vol(cmd, (lv)->lvid.s, LCK_ACTIVATE_LOCK, lv))
|
#define lv_type_requires_activation_lock(lv) ((lv_is_thin_type(lv) || lv_is_cache_type(lv) || lv_is_mirror_type(lv) || lv_is_raid_type(lv) || lv_is_origin(lv) || lv_is_snapshot(lv)) ? 1 : 0)
|
||||||
#define unlock_activation(cmd, lv) (vg_write_lock_held() && lv_supports_activation_locking(lv) ? 1 : lock_vol(cmd, (lv)->lvid.s, LCK_ACTIVATE_UNLOCK, lv))
|
#define lv_activation_lock_name(lv) (lv_type_requires_activation_lock(lv) ? (lv)->vg->name : (lv)->lvid.s)
|
||||||
|
#define lv_requires_activation_lock_now(lv) ((!vg_write_lock_held() && (!vg_is_clustered((lv)->vg) || !lv_type_requires_activation_lock(lv))) ? 1 : 0)
|
||||||
|
|
||||||
|
#define lock_activation(cmd, lv) (lv_requires_activation_lock_now(lv) ? lock_vol(cmd, lv_activation_lock_name(lv), LCK_ACTIVATE_LOCK, lv) : 1)
|
||||||
|
#define unlock_activation(cmd, lv) (lv_requires_activation_lock_now(lv) ? lock_vol(cmd, lv_activation_lock_name(lv), LCK_ACTIVATE_UNLOCK, lv) : 1)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Place temporary exclusive 'activation' lock around an LV locking operation
|
* Place temporary exclusive 'activation' lock around an LV locking operation
|
||||||
|
Loading…
Reference in New Issue
Block a user