From: wuguanghao Date: Wed, 30 Jun 2021 08:27:13 +0000 (+0800) Subject: profile_create_node: set magic before strdup(name) to avoid memory leak X-Git-Tag: v1.46.3~23 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=cac906a942f41b9b8515b10877d3e0b23ef548a9;p=thirdparty%2Fe2fsprogs.git profile_create_node: set magic before strdup(name) to avoid memory leak If new->magic != PROF_MAGIC_NODE, profile_free_node() don't free node. This will cause the node to be unable to be released correctly and a memory leak will occur. Signed-off-by: Wu Guanghao Signed-off-by: Zhiqiang Liu Reviewed-by: Wu Bo Signed-off-by: Theodore Ts'o --- diff --git a/lib/support/profile.c b/lib/support/profile.c index 585ed595d..f54739e7b 100644 --- a/lib/support/profile.c +++ b/lib/support/profile.c @@ -1093,6 +1093,7 @@ errcode_t profile_create_node(const char *name, const char *value, if (!new) return ENOMEM; memset(new, 0, sizeof(struct profile_node)); + new->magic = PROF_MAGIC_NODE; new->name = strdup(name); if (new->name == 0) { profile_free_node(new); @@ -1105,7 +1106,6 @@ errcode_t profile_create_node(const char *name, const char *value, return ENOMEM; } } - new->magic = PROF_MAGIC_NODE; *ret_node = new; return 0;