1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-21 22:04:19 +03:00

export: pass buffer size as parameter

Avoid strlen() for buffer when size is known.
This commit is contained in:
Zdenek Kabelac 2024-10-19 21:51:34 +02:00
parent 057314ff8d
commit 1eb8177bae
7 changed files with 12 additions and 14 deletions

View File

@ -4889,7 +4889,8 @@ static void client_recv_action(struct client *cl)
return;
}
req.cft = config_tree_from_string_without_dup_node_check(req.buffer.mem);
req.cft = config_tree_from_string_without_dup_node_check(req.buffer.mem,
req.buffer.used);
if (!req.cft) {
log_error("client recv %u config_from_string error", cl->id);
buffer_destroy(&req.buffer);

View File

@ -1059,22 +1059,19 @@ size_t text_vg_export_raw(struct volume_group *vg, const char *desc, char **buf,
return r;
}
static size_t _export_vg_to_buffer(struct volume_group *vg, char **buf)
{
return text_vg_export_raw(vg, "", buf, NULL);
}
struct dm_config_tree *export_vg_to_config_tree(struct volume_group *vg)
{
char *buf = NULL;
uint32_t buf_size = 0;
struct dm_config_tree *vg_cft;
if (!_export_vg_to_buffer(vg, &buf)) {
/* export vg to buffer */
if (!text_vg_export_raw(vg, "", &buf, &buf_size)) {
log_error("Could not format metadata for VG %s.", vg->name);
return NULL;
}
if (!(vg_cft = config_tree_from_string_without_dup_node_check(buf))) {
if (!(vg_cft = config_tree_from_string_without_dup_node_check(buf, buf_size))) {
log_error("Error parsing metadata for VG %s.", vg->name);
free(buf);
return NULL;

View File

@ -647,7 +647,7 @@ static int _vg_write_raw(struct format_instance *fid, struct volume_group *vg,
*
* 'Lazy' creation of such VG might improve performance, but we
* lose important validation that written metadata can be parsed. */
if (!(cft = config_tree_from_string_without_dup_node_check(write_buf))) {
if (!(cft = config_tree_from_string_without_dup_node_check(write_buf, new_size - 1))) {
log_error("Error parsing metadata for VG %s.", vg->name);
goto out;
}

View File

@ -159,14 +159,14 @@ void chain_node(struct dm_config_node *cn,
}
struct dm_config_tree *config_tree_from_string_without_dup_node_check(const char *config_settings)
struct dm_config_tree *config_tree_from_string_without_dup_node_check(const char *config_settings, size_t len)
{
struct dm_config_tree *cft;
if (!(cft = dm_config_create()))
return_NULL;
if (!dm_config_parse_without_dup_node_check(cft, config_settings, config_settings + strlen(config_settings))) {
if (!dm_config_parse_without_dup_node_check(cft, config_settings, config_settings + len)) {
dm_config_destroy(cft);
return_NULL;
}

View File

@ -66,6 +66,6 @@ struct dm_config_node *config_make_nodes(struct dm_config_tree *cft,
struct dm_config_node *pre_sib,
...);
struct dm_config_tree *config_tree_from_string_without_dup_node_check(const char *config_settings);
struct dm_config_tree *config_tree_from_string_without_dup_node_check(const char *config_settings, size_t len);
#endif /* _LVM_DAEMON_CONFIG_UTIL_H */

View File

@ -118,7 +118,7 @@ daemon_reply daemon_send(daemon_handle h, daemon_request rq)
reply.error = errno;
if (buffer_read(h.socket_fd, &reply.buffer)) {
reply.cft = config_tree_from_string_without_dup_node_check(reply.buffer.mem);
reply.cft = config_tree_from_string_without_dup_node_check(reply.buffer.mem, reply.buffer.used);
if (!reply.cft)
reply.error = EPROTO;
} else

View File

@ -450,7 +450,7 @@ static void *_client_thread(void *state)
if (!buffer_read(ts->client.socket_fd, &req.buffer))
goto fail;
req.cft = config_tree_from_string_without_dup_node_check(req.buffer.mem);
req.cft = config_tree_from_string_without_dup_node_check(req.buffer.mem, req.buffer.used);
if (!req.cft)
fprintf(stderr, "error parsing request:\n %s\n", req.buffer.mem);