1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

Prepare for _get_lvconvert_vg() reuse as part of a larger lvconvert.c

refactoring.

Document the need to cleanup the "name" args passed around polldaemon,
lvconvert and pvmove.  It is quite a mess.

Annotate the unused nature of the existing poll_fns->get_copy_vg
methods' 'uuid' arg.
This commit is contained in:
Mike Snitzer 2010-02-05 22:40:49 +00:00
parent abdd429f35
commit 0ade9a8b37
2 changed files with 18 additions and 4 deletions

View File

@ -306,11 +306,16 @@ static int _read_params(struct lvconvert_params *lp, struct cmd_context *cmd,
} }
static struct volume_group *_get_lvconvert_vg(struct cmd_context *cmd, static struct volume_group *_get_lvconvert_vg(struct cmd_context *cmd,
const char *lv_name, const char *uuid) const char *name,
const char *uuid __attribute((unused)))
{ {
dev_close_all(); dev_close_all();
return vg_read_for_update(cmd, extract_vgname(cmd, lv_name), if (name && !strchr(name, '/'))
return vg_read_for_update(cmd, name, NULL, 0);
/* 'name' is the full LV name; must extract_vgname() */
return vg_read_for_update(cmd, extract_vgname(cmd, name),
NULL, 0); NULL, 0);
} }
@ -440,11 +445,19 @@ static struct poll_functions _lvconvert_merge_fns = {
int lvconvert_poll(struct cmd_context *cmd, struct logical_volume *lv, int lvconvert_poll(struct cmd_context *cmd, struct logical_volume *lv,
unsigned background) unsigned background)
{ {
/*
* FIXME allocate an "object key" structure with split
* out members (vg_name, lv_name, uuid, etc) and pass that
* around the lvconvert and polldaemon code
* - will avoid needless work, e.g. extract_vgname()
* - unfortunately there are enough overloaded "name" dragons in
* the polldaemon, lvconvert, pvmove code that a comprehensive
* audit/rework is needed
*/
int len = strlen(lv->vg->name) + strlen(lv->name) + 2; int len = strlen(lv->vg->name) + strlen(lv->name) + 2;
char *uuid = alloca(sizeof(lv->lvid)); char *uuid = alloca(sizeof(lv->lvid));
char *lv_full_name = alloca(len); char *lv_full_name = alloca(len);
if (!uuid || !lv_full_name) if (!uuid || !lv_full_name)
return_0; return_0;

View File

@ -595,7 +595,8 @@ static int _finish_pvmove(struct cmd_context *cmd, struct volume_group *vg,
} }
static struct volume_group *_get_move_vg(struct cmd_context *cmd, static struct volume_group *_get_move_vg(struct cmd_context *cmd,
const char *name, const char *uuid) const char *name,
const char *uuid __attribute((unused)))
{ {
struct physical_volume *pv; struct physical_volume *pv;