mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
Set PV size to current device size if it is found to be zero.
This commit is contained in:
parent
7c5ec12630
commit
b16b9c2bf1
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.13 -
|
Version 2.02.13 -
|
||||||
===================================
|
===================================
|
||||||
|
Set PV size to current device size if it is found to be zero.
|
||||||
Add segment parameter to target_present functions.
|
Add segment parameter to target_present functions.
|
||||||
|
|
||||||
Version 2.02.12 - 16th October 2006
|
Version 2.02.12 - 16th October 2006
|
||||||
|
@ -203,8 +203,8 @@ int write_disks(const struct format_type *fmt, struct list *pvds);
|
|||||||
* Functions to translate to between disk and in
|
* Functions to translate to between disk and in
|
||||||
* core structures.
|
* core structures.
|
||||||
*/
|
*/
|
||||||
int import_pv(struct dm_pool *mem, struct device *dev,
|
int import_pv(const struct format_type *fmt, struct dm_pool *mem,
|
||||||
struct volume_group *vg,
|
struct device *dev, struct volume_group *vg,
|
||||||
struct physical_volume *pv, struct pv_disk *pvd,
|
struct physical_volume *pv, struct pv_disk *pvd,
|
||||||
struct vg_disk *vgd);
|
struct vg_disk *vgd);
|
||||||
int export_pv(struct cmd_context *cmd, struct dm_pool *mem,
|
int export_pv(struct cmd_context *cmd, struct dm_pool *mem,
|
||||||
|
@ -312,7 +312,7 @@ static int _format1_pv_read(const struct format_type *fmt, const char *pv_name,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!import_pv(fmt->cmd->mem, dl->dev, NULL, pv, &dl->pvd, &dl->vgd)) {
|
if (!import_pv(fmt, fmt->cmd->mem, dl->dev, NULL, pv, &dl->pvd, &dl->vgd)) {
|
||||||
stack;
|
stack;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#include "toolcontext.h"
|
#include "toolcontext.h"
|
||||||
#include "segtype.h"
|
#include "segtype.h"
|
||||||
#include "pv_alloc.h"
|
#include "pv_alloc.h"
|
||||||
|
#include "display.h"
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
@ -47,11 +48,13 @@ static char *_create_lv_name(struct dm_pool *mem, const char *full_name)
|
|||||||
return dm_pool_strdup(mem, ptr);
|
return dm_pool_strdup(mem, ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
int import_pv(struct dm_pool *mem, struct device *dev,
|
int import_pv(const struct format_type *fmt, struct dm_pool *mem,
|
||||||
struct volume_group *vg,
|
struct device *dev, struct volume_group *vg,
|
||||||
struct physical_volume *pv, struct pv_disk *pvd,
|
struct physical_volume *pv, struct pv_disk *pvd,
|
||||||
struct vg_disk *vgd)
|
struct vg_disk *vgd)
|
||||||
{
|
{
|
||||||
|
uint64_t size;
|
||||||
|
|
||||||
memset(pv, 0, sizeof(*pv));
|
memset(pv, 0, sizeof(*pv));
|
||||||
memcpy(&pv->id, pvd->pv_uuid, ID_LEN);
|
memcpy(&pv->id, pvd->pv_uuid, ID_LEN);
|
||||||
|
|
||||||
@ -89,6 +92,25 @@ int import_pv(struct dm_pool *mem, struct device *dev,
|
|||||||
pv->pe_count = pvd->pe_total;
|
pv->pe_count = pvd->pe_total;
|
||||||
pv->pe_alloc_count = 0;
|
pv->pe_alloc_count = 0;
|
||||||
|
|
||||||
|
/* Fix up pv size if missing */
|
||||||
|
if (!pv->size) {
|
||||||
|
if (!dev_get_size(dev, &pv->size)) {
|
||||||
|
log_error("%s: Couldn't get size.", dev_name(pv->dev));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
log_verbose("Fixing up missing format1 size (%s) "
|
||||||
|
"for PV %s", display_size(fmt->cmd, pv->size),
|
||||||
|
dev_name(pv->dev));
|
||||||
|
if (vg) {
|
||||||
|
size = pv->pe_count * (uint64_t) vg->extent_size +
|
||||||
|
pv->pe_start;
|
||||||
|
if (size > pv->size)
|
||||||
|
log_error("WARNING: Physical Volume %s is too "
|
||||||
|
"large for underlying device",
|
||||||
|
dev_name(pv->dev));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
list_init(&pv->tags);
|
list_init(&pv->tags);
|
||||||
list_init(&pv->segments);
|
list_init(&pv->segments);
|
||||||
|
|
||||||
@ -427,7 +449,7 @@ int import_pvs(const struct format_type *fmt, struct dm_pool *mem,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!import_pv(mem, dl->dev, vg, pvl->pv, &dl->pvd, &dl->vgd)) {
|
if (!import_pv(fmt, mem, dl->dev, vg, pvl->pv, &dl->pvd, &dl->vgd)) {
|
||||||
stack;
|
stack;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -116,6 +116,7 @@ static int _read_pv(struct format_instance *fid, struct dm_pool *mem,
|
|||||||
struct physical_volume *pv;
|
struct physical_volume *pv;
|
||||||
struct pv_list *pvl;
|
struct pv_list *pvl;
|
||||||
struct config_node *cn;
|
struct config_node *cn;
|
||||||
|
uint64_t size;
|
||||||
|
|
||||||
if (!(pvl = dm_pool_zalloc(mem, sizeof(*pvl))) ||
|
if (!(pvl = dm_pool_zalloc(mem, sizeof(*pvl))) ||
|
||||||
!(pvl->pv = dm_pool_zalloc(mem, sizeof(*pvl->pv)))) {
|
!(pvl->pv = dm_pool_zalloc(mem, sizeof(*pvl->pv)))) {
|
||||||
@ -213,6 +214,25 @@ static int _read_pv(struct format_instance *fid, struct dm_pool *mem,
|
|||||||
pv->pe_alloc_count = 0;
|
pv->pe_alloc_count = 0;
|
||||||
pv->fmt = fid->fmt;
|
pv->fmt = fid->fmt;
|
||||||
|
|
||||||
|
/* Fix up pv size if missing */
|
||||||
|
if (!pv->size && pv->dev) {
|
||||||
|
if (!dev_get_size(pv->dev, &pv->size)) {
|
||||||
|
log_error("%s: Couldn't get size.", dev_name(pv->dev));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
log_verbose("Fixing up missing format1 size (%s) "
|
||||||
|
"for PV %s", display_size(fid->fmt->cmd, pv->size),
|
||||||
|
dev_name(pv->dev));
|
||||||
|
if (vg) {
|
||||||
|
size = pv->pe_count * (uint64_t) vg->extent_size +
|
||||||
|
pv->pe_start;
|
||||||
|
if (size > pv->size)
|
||||||
|
log_error("WARNING: Physical Volume %s is too "
|
||||||
|
"large for underlying device",
|
||||||
|
dev_name(pv->dev));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!alloc_pv_segment_whole_pv(mem, pv)) {
|
if (!alloc_pv_segment_whole_pv(mem, pv)) {
|
||||||
stack;
|
stack;
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user