1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-05 13:18:20 +03:00

o Format1 wasn't recording the snapshot chunk size properly

o  Activation of snapshots now works - though the resulting device
   doesn't (pjc ?)

o  text format wasn't setting vg->cmd.
This commit is contained in:
Joe Thornber 2002-02-26 16:48:52 +00:00
parent 6761081ab4
commit 841da63e77
3 changed files with 32 additions and 4 deletions

View File

@ -355,10 +355,17 @@ static int _populate_vanilla(struct dev_manager *dm,
static int _populate_origin(struct dev_manager *dm, static int _populate_origin(struct dev_manager *dm,
struct dm_task *dmt, struct dev_layer *dl) struct dm_task *dmt, struct dev_layer *dl)
{ {
char *real;
char params[PATH_MAX + 32]; char params[PATH_MAX + 32];
if (!(real = _build_name(dm->mem, dm->vg_name,
dl->lv->name, "real"))) {
stack;
return 0;
}
if (lvm_snprintf(params, sizeof(params), "%s/%s 0", if (lvm_snprintf(params, sizeof(params), "%s/%s 0",
dm_dir(), dl->name) == -1) { dm_dir(), real) == -1) {
log_err("Couldn't create origin device parameters for '%s'.", log_err("Couldn't create origin device parameters for '%s'.",
dl->name); dl->name);
return 0; return 0;
@ -558,6 +565,7 @@ static int _expand_lv(struct dev_manager *dm, struct logical_volume *lv)
dl->populate = _populate_vanilla; dl->populate = _populate_vanilla;
dl->visible = 0; dl->visible = 0;
/* insert the cow layer */
if (!hash_insert(dm->layers, dl->name, dl)) { if (!hash_insert(dm->layers, dl->name, dl)) {
stack; stack;
return 0; return 0;
@ -584,6 +592,21 @@ static int _expand_lv(struct dev_manager *dm, struct logical_volume *lv)
list_add(&dl->pre_create, &sl->list); list_add(&dl->pre_create, &sl->list);
/* add the dependency on the org device */
if (!(sl = pool_alloc(dm->mem, sizeof(*sl)))) {
stack;
return 0;
}
if (!(sl->str = _build_name(dm->mem, dm->vg_name,
s->origin->name, "top"))) {
stack;
return 0;
}
list_add(&dl->pre_create, &sl->list);
/* insert the snapshot layer */
if (!hash_insert(dm->layers,dl->name, dl)) { if (!hash_insert(dm->layers,dl->name, dl)) {
stack; stack;
return 0; return 0;

View File

@ -546,6 +546,7 @@ int export_lvs(struct disk_list *dl, struct volume_group *vg,
org->lv_access |= LV_SNAPSHOT_ORG; org->lv_access |= LV_SNAPSHOT_ORG;
cow->lv_access |= LV_SNAPSHOT; cow->lv_access |= LV_SNAPSHOT;
cow->lv_snapshot_minor = org->lv_number; cow->lv_snapshot_minor = org->lv_number;
cow->lv_chunk_size = s->chunk_size;
} }
r = 1; r = 1;
@ -618,7 +619,8 @@ int import_snapshots(struct pool *mem, struct volume_group *vg,
continue; continue;
/* insert the snapshot */ /* insert the snapshot */
if (!vg_add_snapshot(org, cow, 1, lvd->lv_chunk_size)) { if (!vg_add_snapshot(org, cow, 1,
lvd->lv_chunk_size)) {
log_err("Couldn't add snapshot."); log_err("Couldn't add snapshot.");
return 0; return 0;
} }

View File

@ -484,12 +484,14 @@ static int _read_sections(const char *section, section_fn fn,
return 1; return 1;
} }
static struct volume_group *_read_vg(struct pool *mem, struct config_file *cf, static struct volume_group *_read_vg(struct cmd_context *cmd,
struct config_file *cf,
struct uuid_map *um) struct uuid_map *um)
{ {
struct config_node *vgn, *cn; struct config_node *vgn, *cn;
struct volume_group *vg; struct volume_group *vg;
struct hash_table *pv_hash = NULL; struct hash_table *pv_hash = NULL;
struct pool *mem = cmd->mem;
/* skip any top-level values */ /* skip any top-level values */
for (vgn = cf->root; (vgn && vgn->v); vgn = vgn->sib) for (vgn = cf->root; (vgn && vgn->v); vgn = vgn->sib)
@ -504,6 +506,7 @@ static struct volume_group *_read_vg(struct pool *mem, struct config_file *cf,
stack; stack;
return NULL; return NULL;
} }
vg->cmd = cmd;
if (!(vg->name = pool_strdup(mem, vgn->key))) { if (!(vg->name = pool_strdup(mem, vgn->key))) {
stack; stack;
@ -648,7 +651,7 @@ struct volume_group *text_vg_import(struct cmd_context *cmd,
goto out; goto out;
} }
if (!(vg = _read_vg(cmd->mem, cf, um))) { if (!(vg = _read_vg(cmd, cf, um))) {
stack; stack;
goto out; goto out;
} }