From mboxrd@z Thu Jan 1 00:00:00 1970 From: Pekka Enberg Subject: Re: [Patch] fs/binfmt_elf.c: fix a wrong free Date: Sun, 04 May 2008 13:39:03 +0300 Message-ID: <481D9247.4010804@cs.helsinki.fi> References: <20080503124610.GA3986@hack> <20080503143942.GE3986@hack> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: LKML , Eric Youngdale , viro@zeniv.linux.org.uk, linux-fsdevel@vger.kernel.org, Andrew Morton To: WANG Cong Return-path: Received: from courier.cs.helsinki.fi ([128.214.9.1]:49545 "EHLO mail.cs.helsinki.fi" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754641AbYEDKky (ORCPT ); Sun, 4 May 2008 06:40:54 -0400 In-Reply-To: <20080503143942.GE3986@hack> Sender: linux-fsdevel-owner@vger.kernel.org List-ID: WANG Cong wrote: > Hi, Pekka! > > Thanks for your comments. Yes, it seems that fill_note_info() is ugly. > :-) How about the below one? > > Signed-off-by: WANG Cong > > --- > diff --git a/fs/binfmt_elf.c b/fs/binfmt_elf.c > index f6d5a9d..357b503 100644 > --- a/fs/binfmt_elf.c > +++ b/fs/binfmt_elf.c > @@ -1900,7 +1900,7 @@ static int elf_core_dump(long signr, struct pt_regs *regs, struct file *file, un > /* alloc memory for large data structures: too large to be on stack */ > elf = kmalloc(sizeof(*elf), GFP_KERNEL); > if (!elf) > - goto cleanup; > + goto ret; > > segs = current->mm->map_count; > #ifdef ELF_CORE_EXTRA_PHDRS > @@ -2034,8 +2034,9 @@ end_coredump: > set_fs(fs); > > cleanup: > - kfree(elf); > free_note_info(&info); > + kfree(elf); > +ret: > return has_dumped; Looks good although 'ret' is usually reserved for the variable that contains the return value so you might want to consider using the more idiomatic 'out' as the label name. Pekka