[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20220513023308.2400381-2-bobo.shaobowang@huawei.com>
Date: Fri, 13 May 2022 10:33:07 +0800
From: Wang ShaoBo <bobo.shaobowang@...wei.com>
To: unlisted-recipients:; (no To-header on input)
CC: <bobo.shaobowang@...wei.com>, <cj.chengjian@...wei.com>,
<linux-kernel@...r.kernel.org>, <liwei391@...wei.com>,
<mhiramat@...nel.org>, <rostedt@...dmis.org>, <acme@...hat.com>,
<yuehaibing@...wei.com>
Subject: [PATCH 1/2] libtraceevent: fix memleak in make_bprint_args()
Release arg allocated from alloc_arg() when strdup failed in make_bprint_args().
Fixes: a6d2a61ac653 ("tools lib traceevent: Remove some die() calls")
Signed-off-by: Wang ShaoBo <bobo.shaobowang@...wei.com>
---
tools/lib/traceevent/event-parse.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/tools/lib/traceevent/event-parse.c b/tools/lib/traceevent/event-parse.c
index 8e24c4c78c7f..69e4d5229362 100644
--- a/tools/lib/traceevent/event-parse.c
+++ b/tools/lib/traceevent/event-parse.c
@@ -4507,8 +4507,10 @@ static struct tep_print_arg *make_bprint_args(char *fmt, void *data, int size, s
arg->next = NULL;
arg->type = TEP_PRINT_BSTRING;
arg->string.string = strdup(bptr);
- if (!arg->string.string)
+ if (!arg->string.string) {
+ free(arg);
goto out_free;
+ }
bptr += strlen(bptr) + 1;
*next = arg;
next = &arg->next;
--
2.25.1
Powered by blists - more mailing lists