mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
clvmd no longer takes out locks for non-clusteed LVs,
and non-clustered LVs are only activated on the local node.
This commit is contained in:
parent
3d38769798
commit
fe6c78629d
@ -11,6 +11,7 @@ Version 2.01.15 -
|
|||||||
Move compose_log_line() into mirror directory.
|
Move compose_log_line() into mirror directory.
|
||||||
Factor out _get_library_path().
|
Factor out _get_library_path().
|
||||||
Don't kill idling clvmd threads.
|
Don't kill idling clvmd threads.
|
||||||
|
clvmd no longer takes out locks for non-clustered LVs.
|
||||||
Recognise ATA over Ethernet (aoe) devices.
|
Recognise ATA over Ethernet (aoe) devices.
|
||||||
|
|
||||||
Version 2.01.14 - 4th August 2005
|
Version 2.01.14 - 4th August 2005
|
||||||
|
@ -109,7 +109,7 @@ int do_command(struct local_client *client, struct clvm_header *msg, int msglen,
|
|||||||
|
|
||||||
case CLVMD_CMD_LOCK_LV:
|
case CLVMD_CMD_LOCK_LV:
|
||||||
/* This is the biggie */
|
/* This is the biggie */
|
||||||
lock_cmd = args[0];
|
lock_cmd = args[0] & 0x3F;
|
||||||
lock_flags = args[1];
|
lock_flags = args[1];
|
||||||
lockname = &args[2];
|
lockname = &args[2];
|
||||||
status = do_lock_lv(lock_cmd, lock_flags, lockname);
|
status = do_lock_lv(lock_cmd, lock_flags, lockname);
|
||||||
@ -161,7 +161,7 @@ static int lock_vg(struct local_client *client)
|
|||||||
client->bits.localsock.private = (void *)lock_hash;
|
client->bits.localsock.private = (void *)lock_hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
lock_cmd = args[0];
|
lock_cmd = args[0] & 0x3F;
|
||||||
lock_flags = args[1];
|
lock_flags = args[1];
|
||||||
lockname = &args[2];
|
lockname = &args[2];
|
||||||
DEBUGLOG("doing PRE command LOCK_VG '%s' at %x (client=%p)\n", lockname, lock_cmd, client);
|
DEBUGLOG("doing PRE command LOCK_VG '%s' at %x (client=%p)\n", lockname, lock_cmd, client);
|
||||||
|
@ -168,7 +168,7 @@ int hold_unlock(char *resource)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* Activate LV exclusive or non-exclusive */
|
/* Activate LV exclusive or non-exclusive */
|
||||||
static int do_activate_lv(char *resource, int mode)
|
static int do_activate_lv(char *resource, unsigned char lock_flags, int mode)
|
||||||
{
|
{
|
||||||
int oldmode;
|
int oldmode;
|
||||||
int status;
|
int status;
|
||||||
@ -195,10 +195,12 @@ static int do_activate_lv(char *resource, int mode)
|
|||||||
mode = LKM_EXMODE;
|
mode = LKM_EXMODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* OK, try to get the lock */
|
/* Try to get the lock if it's a clustered volume group */
|
||||||
|
if (lock_flags & LCK_CLUSTER_VG) {
|
||||||
status = hold_lock(resource, mode, LKF_NOQUEUE);
|
status = hold_lock(resource, mode, LKF_NOQUEUE);
|
||||||
if (status)
|
if (status)
|
||||||
return errno;
|
return errno;
|
||||||
|
}
|
||||||
|
|
||||||
/* If it's suspended then resume it */
|
/* If it's suspended then resume it */
|
||||||
if (!lv_info_by_lvid(cmd, resource, &lvi, 0))
|
if (!lv_info_by_lvid(cmd, resource, &lvi, 0))
|
||||||
@ -258,14 +260,14 @@ static int do_suspend_lv(char *resource)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int do_deactivate_lv(char *resource)
|
static int do_deactivate_lv(char *resource, unsigned char lock_flags)
|
||||||
{
|
{
|
||||||
int oldmode;
|
int oldmode;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
/* Is it open ? */
|
/* Is it open ? */
|
||||||
oldmode = get_current_lock(resource);
|
oldmode = get_current_lock(resource);
|
||||||
if (oldmode == -1) {
|
if (oldmode == -1 && (lock_flags & LCK_CLUSTER_VG)) {
|
||||||
DEBUGLOG("do_deactivate_lock, lock not already held\n");
|
DEBUGLOG("do_deactivate_lock, lock not already held\n");
|
||||||
return 0; /* We don't need to do anything */
|
return 0; /* We don't need to do anything */
|
||||||
}
|
}
|
||||||
@ -273,9 +275,11 @@ static int do_deactivate_lv(char *resource)
|
|||||||
if (!lv_deactivate(cmd, resource))
|
if (!lv_deactivate(cmd, resource))
|
||||||
return EIO;
|
return EIO;
|
||||||
|
|
||||||
|
if (lock_flags & LCK_CLUSTER_VG) {
|
||||||
status = hold_unlock(resource);
|
status = hold_unlock(resource);
|
||||||
if (status)
|
if (status)
|
||||||
return errno;
|
return errno;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -286,7 +290,7 @@ int do_lock_lv(unsigned char command, unsigned char lock_flags, char *resource)
|
|||||||
{
|
{
|
||||||
int status = 0;
|
int status = 0;
|
||||||
|
|
||||||
DEBUGLOG("do_lock_lv: resource '%s', cmd = 0x%x, flags = %d\n",
|
DEBUGLOG("do_lock_lv: resource '%s', cmd = 0x%x, flags = %x\n",
|
||||||
resource, command, lock_flags);
|
resource, command, lock_flags);
|
||||||
|
|
||||||
if (!cmd->config_valid || config_files_changed(cmd)) {
|
if (!cmd->config_valid || config_files_changed(cmd)) {
|
||||||
@ -299,7 +303,7 @@ int do_lock_lv(unsigned char command, unsigned char lock_flags, char *resource)
|
|||||||
|
|
||||||
switch (command) {
|
switch (command) {
|
||||||
case LCK_LV_EXCLUSIVE:
|
case LCK_LV_EXCLUSIVE:
|
||||||
status = do_activate_lv(resource, LKM_EXMODE);
|
status = do_activate_lv(resource, lock_flags, LKM_EXMODE);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LCK_LV_SUSPEND:
|
case LCK_LV_SUSPEND:
|
||||||
@ -312,11 +316,11 @@ int do_lock_lv(unsigned char command, unsigned char lock_flags, char *resource)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LCK_LV_ACTIVATE:
|
case LCK_LV_ACTIVATE:
|
||||||
status = do_activate_lv(resource, LKM_CRMODE);
|
status = do_activate_lv(resource, lock_flags, LKM_CRMODE);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LCK_LV_DEACTIVATE:
|
case LCK_LV_DEACTIVATE:
|
||||||
status = do_deactivate_lv(resource);
|
status = do_deactivate_lv(resource, lock_flags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -436,23 +440,24 @@ static void drop_vg_locks()
|
|||||||
*/
|
*/
|
||||||
static void *get_initial_state()
|
static void *get_initial_state()
|
||||||
{
|
{
|
||||||
char lv[64], vg[64], flags[25];
|
char lv[64], vg[64], flags[25], vg_flags[25];
|
||||||
char uuid[65];
|
char uuid[65];
|
||||||
char line[255];
|
char line[255];
|
||||||
FILE *lvs =
|
FILE *lvs =
|
||||||
popen
|
popen
|
||||||
("lvm lvs --nolocking --noheadings -o vg_uuid,lv_uuid,lv_attr",
|
("lvm lvs --nolocking --noheadings -o vg_uuid,lv_uuid,lv_attr,vg_attr",
|
||||||
"r");
|
"r");
|
||||||
|
|
||||||
if (!lvs)
|
if (!lvs)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
while (fgets(line, sizeof(line), lvs)) {
|
while (fgets(line, sizeof(line), lvs)) {
|
||||||
if (sscanf(line, "%s %s %s\n", vg, lv, flags) == 3) {
|
if (sscanf(line, "%s %s %s %s\n", vg, lv, flags, vg_flags) == 4) {
|
||||||
|
|
||||||
/* States: s:suspended a:active S:dropped snapshot I:invalid snapshot */
|
/* States: s:suspended a:active S:dropped snapshot I:invalid snapshot */
|
||||||
if (strlen(vg) == 38 && /* is is a valid UUID ? */
|
if (strlen(vg) == 38 && /* is is a valid UUID ? */
|
||||||
(flags[4] == 'a' || flags[4] == 's')) { /* is it active or suspended? */
|
(flags[4] == 'a' || flags[4] == 's') && /* is it active or suspended? */
|
||||||
|
vg_flags[5] == 'c') { /* is it clustered ? */
|
||||||
/* Convert hyphen-separated UUIDs into one */
|
/* Convert hyphen-separated UUIDs into one */
|
||||||
memcpy(&uuid[0], &vg[0], 6);
|
memcpy(&uuid[0], &vg[0], 6);
|
||||||
memcpy(&uuid[6], &vg[7], 4);
|
memcpy(&uuid[6], &vg[7], 4);
|
||||||
|
@ -327,8 +327,8 @@ static int _lock_for_cluster(unsigned char cmd, unsigned int flags, char *name)
|
|||||||
args = alloca(len);
|
args = alloca(len);
|
||||||
strcpy(args + 2, name);
|
strcpy(args + 2, name);
|
||||||
|
|
||||||
args[0] = flags & 0xBF; /* Maskoff LOCAL flag */
|
args[0] = flags & 0x7F; /* Maskoff lock flags */
|
||||||
args[1] = 0; /* Not used now */
|
args[1] = flags & 0xC0; /* Bitmap flags */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* VG locks are just that: locks, and have no side effects
|
* VG locks are just that: locks, and have no side effects
|
||||||
@ -339,7 +339,8 @@ static int _lock_for_cluster(unsigned char cmd, unsigned int flags, char *name)
|
|||||||
*/
|
*/
|
||||||
if (cmd == CLVMD_CMD_LOCK_VG ||
|
if (cmd == CLVMD_CMD_LOCK_VG ||
|
||||||
(flags & LCK_TYPE_MASK) == LCK_EXCL ||
|
(flags & LCK_TYPE_MASK) == LCK_EXCL ||
|
||||||
(flags & LCK_LOCAL))
|
(flags & LCK_LOCAL) ||
|
||||||
|
!(flags & LCK_CLUSTER_VG))
|
||||||
node = ".";
|
node = ".";
|
||||||
|
|
||||||
status = _cluster_request(cmd, node, args, len,
|
status = _cluster_request(cmd, node, args, len,
|
||||||
|
Loading…
Reference in New Issue
Block a user