mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
lvextend: allow on LV active with a shared lock
Detect when a shared lock exists, don't require the normal exclusive lock, and allow the lvextend.
This commit is contained in:
parent
9b4926aaff
commit
d369de8399
@ -1816,9 +1816,9 @@ static void res_process(struct lockspace *ls, struct resource *r,
|
|||||||
add_client_result(act);
|
add_client_result(act);
|
||||||
} else {
|
} else {
|
||||||
/* persistent lock is sh, transient request is ex */
|
/* persistent lock is sh, transient request is ex */
|
||||||
/* FIXME: can we remove this case? do a convert here? */
|
|
||||||
log_debug("res_process %s existing persistent lock new transient", r->name);
|
log_debug("res_process %s existing persistent lock new transient", r->name);
|
||||||
r->last_client_id = act->client_id;
|
r->last_client_id = act->client_id;
|
||||||
|
act->flags |= LD_AF_SH_EXISTS;
|
||||||
act->result = -EEXIST;
|
act->result = -EEXIST;
|
||||||
list_del(&act->list);
|
list_del(&act->list);
|
||||||
add_client_result(act);
|
add_client_result(act);
|
||||||
@ -3661,6 +3661,9 @@ static int client_send_result(struct client *cl, struct action *act)
|
|||||||
if ((act->flags & LD_AF_WARN_GL_REMOVED) || gl_vg_removed)
|
if ((act->flags & LD_AF_WARN_GL_REMOVED) || gl_vg_removed)
|
||||||
strcat(result_flags, "WARN_GL_REMOVED,");
|
strcat(result_flags, "WARN_GL_REMOVED,");
|
||||||
|
|
||||||
|
if (act->flags & LD_AF_SH_EXISTS)
|
||||||
|
strcat(result_flags, "SH_EXISTS,");
|
||||||
|
|
||||||
if (act->op == LD_OP_INIT) {
|
if (act->op == LD_OP_INIT) {
|
||||||
/*
|
/*
|
||||||
* init is a special case where lock args need
|
* init is a special case where lock args need
|
||||||
|
@ -106,6 +106,7 @@ struct client {
|
|||||||
#define LD_AF_WARN_GL_REMOVED 0x00020000
|
#define LD_AF_WARN_GL_REMOVED 0x00020000
|
||||||
#define LD_AF_LV_LOCK 0x00040000
|
#define LD_AF_LV_LOCK 0x00040000
|
||||||
#define LD_AF_LV_UNLOCK 0x00080000
|
#define LD_AF_LV_UNLOCK 0x00080000
|
||||||
|
#define LD_AF_SH_EXISTS 0x00100000
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Number of times to repeat a lock request after
|
* Number of times to repeat a lock request after
|
||||||
|
@ -118,6 +118,9 @@ static void _flags_str_to_lockd_flags(const char *flags_str, uint32_t *lockd_fla
|
|||||||
|
|
||||||
if (strstr(flags_str, "WARN_GL_REMOVED"))
|
if (strstr(flags_str, "WARN_GL_REMOVED"))
|
||||||
*lockd_flags |= LD_RF_WARN_GL_REMOVED;
|
*lockd_flags |= LD_RF_WARN_GL_REMOVED;
|
||||||
|
|
||||||
|
if (strstr(flags_str, "SH_EXISTS"))
|
||||||
|
*lockd_flags |= LD_RF_SH_EXISTS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2205,6 +2208,20 @@ int lockd_lv_name(struct cmd_context *cmd, struct volume_group *vg,
|
|||||||
* LV with an ex LV lock when the LV is already active with a
|
* LV with an ex LV lock when the LV is already active with a
|
||||||
* sh LV lock.
|
* sh LV lock.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Special case to allow lvextend under gfs2.
|
||||||
|
*
|
||||||
|
* FIXME: verify the LV actually holds gfs2/ocfs2 which we know
|
||||||
|
* allow this (other users of the LV may not.)
|
||||||
|
*/
|
||||||
|
if (lockd_flags & LD_RF_SH_EXISTS) {
|
||||||
|
if (flags & LDLV_EXTEND) {
|
||||||
|
log_warn("WARNING: extending LV with a shared lock, other hosts may require LV refresh.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
log_error("LV is already locked with incompatible mode: %s/%s", vg->name, lv_name);
|
log_error("LV is already locked with incompatible mode: %s/%s", vg->name, lv_name);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
/* lockd_lv flags */
|
/* lockd_lv flags */
|
||||||
#define LDLV_MODE_NO_SH 0x00000001
|
#define LDLV_MODE_NO_SH 0x00000001
|
||||||
#define LDLV_PERSISTENT 0x00000002
|
#define LDLV_PERSISTENT 0x00000002
|
||||||
|
#define LDLV_EXTEND 0x00000004
|
||||||
|
|
||||||
/* lvmlockd result flags */
|
/* lvmlockd result flags */
|
||||||
#define LD_RF_NO_LOCKSPACES 0x00000001
|
#define LD_RF_NO_LOCKSPACES 0x00000001
|
||||||
@ -29,6 +30,7 @@
|
|||||||
#define LD_RF_WARN_GL_REMOVED 0x00000004
|
#define LD_RF_WARN_GL_REMOVED 0x00000004
|
||||||
#define LD_RF_DUP_GL_LS 0x00000008
|
#define LD_RF_DUP_GL_LS 0x00000008
|
||||||
#define LD_RF_NO_LM 0x00000010
|
#define LD_RF_NO_LM 0x00000010
|
||||||
|
#define LD_RF_SH_EXISTS 0x00000020
|
||||||
|
|
||||||
/* lockd_state flags */
|
/* lockd_state flags */
|
||||||
#define LDST_EX 0x00000001
|
#define LDST_EX 0x00000001
|
||||||
|
@ -5762,7 +5762,7 @@ int lv_resize(struct logical_volume *lv,
|
|||||||
* If the LV is locked from activation, this lock call is a no-op.
|
* If the LV is locked from activation, this lock call is a no-op.
|
||||||
* Otherwise, this acquires a transient lock on the lv (not PERSISTENT).
|
* Otherwise, this acquires a transient lock on the lv (not PERSISTENT).
|
||||||
*/
|
*/
|
||||||
if (!lockd_lv(cmd, lock_lv, "ex", 0))
|
if (!lockd_lv(cmd, lock_lv, "ex", (lp->resize == LV_EXTEND) ? LDLV_EXTEND : 0))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg))
|
||||||
|
Loading…
Reference in New Issue
Block a user