1
0
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:
David Teigland 2019-03-19 14:38:38 -05:00
parent 9b4926aaff
commit d369de8399
5 changed files with 25 additions and 2 deletions

View File

@ -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

View File

@ -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

View File

@ -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;
} }

View File

@ -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

View File

@ -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))