From: Alexander Shishkin Date: Mon, 21 Mar 2016 08:02:42 +0000 (+0200) Subject: perf/core: Don't leak event in the syscall error path X-Git-Tag: firefly_0821_release~176^2~4^2~44^2~86 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=75663c46e8076b468ceb1b4d17358cdb65d4ba77;p=firefly-linux-kernel-4.4.55.git perf/core: Don't leak event in the syscall error path In the error path, event_file not being NULL is used to determine whether the event itself still needs to be free'd, so fix it up to avoid leaking. Reported-by: Leon Yu Signed-off-by: Alexander Shishkin Signed-off-by: Peter Zijlstra (Intel) Cc: Arnaldo Carvalho de Melo Cc: Arnaldo Carvalho de Melo Cc: Jiri Olsa Cc: Linus Torvalds Cc: Peter Zijlstra Cc: Stephane Eranian Cc: Thomas Gleixner Cc: Vince Weaver Fixes: 130056275ade ("perf: Do not double free") Link: http://lkml.kernel.org/r/87twk06yxp.fsf@ashishki-desk.ger.corp.intel.com Signed-off-by: Ingo Molnar (cherry picked from commit 201c2f85bd0bc13b712d9c0b3d11251b182e06ae) --- diff --git a/kernel/events/core.c b/kernel/events/core.c index c22f4579a2e7..b296032a2c4e 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -8457,6 +8457,7 @@ SYSCALL_DEFINE5(perf_event_open, f_flags); if (IS_ERR(event_file)) { err = PTR_ERR(event_file); + event_file = NULL; goto err_context; }