mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-17 06:04:23 +03:00
check: add internal errors for unexpected paths
Adding couple INTERNAL_ERROR reports for unwanted parameters: Ensure the 'top' metadata node cannot be NULL for lvmetad. Make obvious vginfo2 cannot be NULL. Report internal error if handler and vg is undefined. Check for handle in poll_vg(). Ensure seg is not NULL in dev_manager_transient(). Report missing read_ahead for _lv_read_ahead_single(). Check for report handler in dm_report_object(). Check missing VG in _vgreduce_single().
This commit is contained in:
parent
15891d366d
commit
fd417db274
@ -668,6 +668,11 @@ int dev_manager_transient(struct dev_manager *dm, struct logical_volume *lv)
|
|||||||
if (!type || !params)
|
if (!type || !params)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (!seg) {
|
||||||
|
log_error(INTERNAL_ERROR "Segment is not selected.");
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
if (seg->segtype->ops->check_transient_status &&
|
if (seg->segtype->ops->check_transient_status &&
|
||||||
!seg->segtype->ops->check_transient_status(seg, params))
|
!seg->segtype->ops->check_transient_status(seg, params))
|
||||||
goto_out;
|
goto_out;
|
||||||
|
12
lib/cache/lvmcache.c
vendored
12
lib/cache/lvmcache.c
vendored
@ -1005,12 +1005,14 @@ static int _free_vginfo(struct lvmcache_vginfo *vginfo)
|
|||||||
vginfo->vgname);
|
vginfo->vgname);
|
||||||
r = 0;
|
r = 0;
|
||||||
}
|
}
|
||||||
} else do
|
} else
|
||||||
if (vginfo2->next == vginfo) {
|
while (vginfo2) {
|
||||||
vginfo2->next = vginfo->next;
|
if (vginfo2->next == vginfo) {
|
||||||
break;
|
vginfo2->next = vginfo->next;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
vginfo2 = vginfo2->next;
|
||||||
}
|
}
|
||||||
while ((vginfo2 = vginfo2->next));
|
|
||||||
|
|
||||||
dm_free(vginfo->vgname);
|
dm_free(vginfo->vgname);
|
||||||
dm_free(vginfo->creation_host);
|
dm_free(vginfo->creation_host);
|
||||||
|
11
lib/cache/lvmetad.c
vendored
11
lib/cache/lvmetad.c
vendored
@ -199,7 +199,11 @@ struct volume_group *lvmetad_vg_lookup(struct cmd_context *cmd, const char *vgna
|
|||||||
|
|
||||||
if (!strcmp(daemon_reply_str(reply, "response", ""), "OK")) {
|
if (!strcmp(daemon_reply_str(reply, "response", ""), "OK")) {
|
||||||
|
|
||||||
top = dm_config_find_node(reply.cft->root, "metadata");
|
if (!(top = dm_config_find_node(reply.cft->root, "metadata"))) {
|
||||||
|
log_error(INTERNAL_ERROR "metadata config node not found.");
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
name = daemon_reply_str(reply, "name", NULL);
|
name = daemon_reply_str(reply, "name", NULL);
|
||||||
|
|
||||||
/* fall back to lvm2 if we don't know better */
|
/* fall back to lvm2 if we don't know better */
|
||||||
@ -593,6 +597,11 @@ int lvmetad_pv_found(struct id pvid, struct device *device, const struct format_
|
|||||||
"metadata = %b", strchr(buf, '{'),
|
"metadata = %b", strchr(buf, '{'),
|
||||||
NULL);
|
NULL);
|
||||||
} else {
|
} else {
|
||||||
|
if (handler) {
|
||||||
|
log_error(INTERNAL_ERROR "Handler needs existing VG.");
|
||||||
|
dm_free(pvmeta);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
/* There are no MDAs on this PV. */
|
/* There are no MDAs on this PV. */
|
||||||
reply = daemon_send_simple(_lvmetad,
|
reply = daemon_send_simple(_lvmetad,
|
||||||
"pv_found",
|
"pv_found",
|
||||||
|
@ -2221,6 +2221,11 @@ static int _lv_read_ahead_single(struct logical_volume *lv, void *data)
|
|||||||
struct lv_segment *seg = first_seg(lv);
|
struct lv_segment *seg = first_seg(lv);
|
||||||
uint32_t seg_read_ahead = 0, *read_ahead = data;
|
uint32_t seg_read_ahead = 0, *read_ahead = data;
|
||||||
|
|
||||||
|
if (!read_ahead) {
|
||||||
|
log_error(INTERNAL_ERROR "Read ahead data missing.");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (seg && seg->area_count && seg_type(seg, 0) == AREA_PV)
|
if (seg && seg->area_count && seg_type(seg, 0) == AREA_PV)
|
||||||
dev_get_read_ahead(seg_pv(seg, 0)->dev, &seg_read_ahead);
|
dev_get_read_ahead(seg_pv(seg, 0)->dev, &seg_read_ahead);
|
||||||
|
|
||||||
|
@ -695,6 +695,11 @@ int dm_report_object(struct dm_report *rh, void *object)
|
|||||||
struct dm_report_field *field;
|
struct dm_report_field *field;
|
||||||
void *data = NULL;
|
void *data = NULL;
|
||||||
|
|
||||||
|
if (!rh) {
|
||||||
|
log_error(INTERNAL_ERROR "dm_report handler is NULL.");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (!(row = dm_pool_zalloc(rh->mem, sizeof(*row)))) {
|
if (!(row = dm_pool_zalloc(rh->mem, sizeof(*row)))) {
|
||||||
log_error("dm_report_object: struct row allocation failed");
|
log_error("dm_report_object: struct row allocation failed");
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -261,6 +261,11 @@ static int _poll_vg(struct cmd_context *cmd, const char *vgname,
|
|||||||
const char *name;
|
const char *name;
|
||||||
int finished;
|
int finished;
|
||||||
|
|
||||||
|
if (!parms) {
|
||||||
|
log_error(INTERNAL_ERROR "Handle is undefined.");
|
||||||
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
dm_list_iterate_items(lvl, &vg->lvs) {
|
dm_list_iterate_items(lvl, &vg->lvs) {
|
||||||
lv = lvl->lv;
|
lv = lvl->lv;
|
||||||
if (!(lv->status & parms->lv_type))
|
if (!(lv->status & parms->lv_type))
|
||||||
|
@ -124,6 +124,11 @@ static int _vgreduce_single(struct cmd_context *cmd, struct volume_group *vg,
|
|||||||
int r = ECMD_FAILED;
|
int r = ECMD_FAILED;
|
||||||
const char *name = pv_dev_name(pv);
|
const char *name = pv_dev_name(pv);
|
||||||
|
|
||||||
|
if (!vg) {
|
||||||
|
log_error(INTERNAL_ERROR "VG is NULL.");
|
||||||
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (pv_pe_alloc_count(pv)) {
|
if (pv_pe_alloc_count(pv)) {
|
||||||
log_error("Physical volume \"%s\" still in use", name);
|
log_error("Physical volume \"%s\" still in use", name);
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user