1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-17 06:04:23 +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 4e3c31102d
commit 715d62d671
7 changed files with 12 additions and 14 deletions

View File

@ -4894,7 +4894,8 @@ static void client_recv_action(struct client *cl)
return; 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) { if (!req.cft) {
log_error("client recv %u config_from_string error", cl->id); log_error("client recv %u config_from_string error", cl->id);
buffer_destroy(&req.buffer); 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; 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) struct dm_config_tree *export_vg_to_config_tree(struct volume_group *vg)
{ {
char *buf = NULL; char *buf = NULL;
uint32_t buf_size = 0;
struct dm_config_tree *vg_cft; 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); log_error("Could not format metadata for VG %s.", vg->name);
return NULL; 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); log_error("Error parsing metadata for VG %s.", vg->name);
free(buf); free(buf);
return NULL; 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 * 'Lazy' creation of such VG might improve performance, but we
* lose important validation that written metadata can be parsed. */ * 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); log_error("Error parsing metadata for VG %s.", vg->name);
goto out; 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; struct dm_config_tree *cft;
if (!(cft = dm_config_create())) if (!(cft = dm_config_create()))
return_NULL; 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); dm_config_destroy(cft);
return_NULL; 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_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 */ #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; reply.error = errno;
if (buffer_read(h.socket_fd, &reply.buffer)) { 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) if (!reply.cft)
reply.error = EPROTO; reply.error = EPROTO;
} else } else

View File

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