mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
libdm: free mem pool on err path
Since we use get_status also in dmeventd, which may use one pool for a single device, in case it would be repeatedly returning error, it may not be freeing the pool and would cause slow but steady growth. To stay safe in the error path release any allocated memory.
This commit is contained in:
parent
4707ac7200
commit
cb587fd100
@ -2955,10 +2955,10 @@ int dm_get_status_raid(struct dm_pool *mem, const char *params,
|
|||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (!(s->raid_type = dm_pool_zalloc(mem, p - params)))
|
if (!(s->raid_type = dm_pool_zalloc(mem, p - params)))
|
||||||
return_0; /* memory is freed went pool is destroyed */
|
goto_bad; /* memory is freed went pool is destroyed */
|
||||||
|
|
||||||
if (!(s->dev_health = dm_pool_zalloc(mem, i + 1)))
|
if (!(s->dev_health = dm_pool_zalloc(mem, i + 1)))
|
||||||
return_0;
|
goto_bad;
|
||||||
|
|
||||||
if (sscanf(params, "%s %d %s %" PRIu64 "/%" PRIu64,
|
if (sscanf(params, "%s %d %s %" PRIu64 "/%" PRIu64,
|
||||||
s->raid_type,
|
s->raid_type,
|
||||||
@ -2967,7 +2967,7 @@ int dm_get_status_raid(struct dm_pool *mem, const char *params,
|
|||||||
&s->insync_regions,
|
&s->insync_regions,
|
||||||
&s->total_regions) != 5) {
|
&s->total_regions) != 5) {
|
||||||
log_error("Failed to parse raid params: %s", params);
|
log_error("Failed to parse raid params: %s", params);
|
||||||
return 0;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
*status = s;
|
*status = s;
|
||||||
@ -2986,19 +2986,23 @@ int dm_get_status_raid(struct dm_pool *mem, const char *params,
|
|||||||
pp = p;
|
pp = p;
|
||||||
if (!(p = strchr(p, ' '))) {
|
if (!(p = strchr(p, ' '))) {
|
||||||
log_error(INTERNAL_ERROR "Bad RAID status received.");
|
log_error(INTERNAL_ERROR "Bad RAID status received.");
|
||||||
return 0;
|
goto bad;
|
||||||
}
|
}
|
||||||
p++;
|
p++;
|
||||||
|
|
||||||
if (!(s->sync_action = dm_pool_zalloc(mem, p - pp)))
|
if (!(s->sync_action = dm_pool_zalloc(mem, p - pp)))
|
||||||
return_0;
|
goto_bad;
|
||||||
|
|
||||||
if (sscanf(pp, "%s %" PRIu64, s->sync_action, &s->mismatch_count) != 2) {
|
if (sscanf(pp, "%s %" PRIu64, s->sync_action, &s->mismatch_count) != 2) {
|
||||||
log_error("Failed to parse raid params: %s", params);
|
log_error("Failed to parse raid params: %s", params);
|
||||||
return 0;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
|
bad:
|
||||||
|
dm_pool_free(mem, s);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int dm_tree_node_add_replicator_target(struct dm_tree_node *node,
|
int dm_tree_node_add_replicator_target(struct dm_tree_node *node,
|
||||||
@ -3428,6 +3432,7 @@ int dm_get_status_thin_pool(struct dm_pool *mem, const char *params,
|
|||||||
&s->total_metadata_blocks,
|
&s->total_metadata_blocks,
|
||||||
&s->used_data_blocks,
|
&s->used_data_blocks,
|
||||||
&s->total_data_blocks, &pos) < 5) {
|
&s->total_data_blocks, &pos) < 5) {
|
||||||
|
dm_pool_free(mem, s);
|
||||||
log_error("Failed to parse thin pool params: %s.", params);
|
log_error("Failed to parse thin pool params: %s.", params);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -3468,6 +3473,7 @@ int dm_get_status_thin(struct dm_pool *mem, const char *params,
|
|||||||
} else if (sscanf(params, "%" PRIu64 " %" PRIu64,
|
} else if (sscanf(params, "%" PRIu64 " %" PRIu64,
|
||||||
&s->mapped_sectors,
|
&s->mapped_sectors,
|
||||||
&s->highest_mapped_sector) != 2) {
|
&s->highest_mapped_sector) != 2) {
|
||||||
|
dm_pool_free(mem, s);
|
||||||
log_error("Failed to parse thin params: %s.", params);
|
log_error("Failed to parse thin params: %s.", params);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user