1
0
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:
Patrick Caulfield 2005-08-16 08:25:09 +00:00
parent 3d38769798
commit fe6c78629d
4 changed files with 30 additions and 23 deletions

View File

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

View File

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

View File

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

View File

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