From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752586Ab1HTHiO (ORCPT ); Sat, 20 Aug 2011 03:38:14 -0400 Received: from forward16.mail.yandex.net ([95.108.253.141]:47400 "EHLO forward16.mail.yandex.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751319Ab1HTHiM (ORCPT ); Sat, 20 Aug 2011 03:38:12 -0400 X-Greylist: delayed 370 seconds by postgrey-1.27 at vger.kernel.org; Sat, 20 Aug 2011 03:38:12 EDT X-Yandex-Spam: 1 Subject: Re: [PATCH 2/4] sound/soc/ep93xx/ep93xx-i2s.c: add missing kfree From: Alexander Sverdlin To: Julia Lawall Cc: Liam Girdwood , kernel-janitors@vger.kernel.org, Mark Brown , Jaroslav Kysela , Takashi Iwai , Ryan Mallon , H Hartley Sweeten , alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org In-Reply-To: <1313820761-12042-2-git-send-email-julia@diku.dk> References: <1313820761-12042-2-git-send-email-julia@diku.dk> Content-Type: text/plain; charset="UTF-8" Date: Sat, 20 Aug 2011 09:31:55 +0200 Message-ID: <1313825516.15081.1.camel@r60e> Mime-Version: 1.0 X-Mailer: Evolution 2.32.2 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello! I believe, fix is correct. Acked-by: Alexander Sverdlin On Sat, 2011-08-20 at 08:12 +0200, Julia Lawall wrote: > From: Julia Lawall > > Introduce a new label that includes kfree and jump to that one. > > A simplified version of the semantic match that finds this problem is as > follows: (http://coccinelle.lip6.fr/) > > // > @@ > identifier x; > expression E1!=0,E2,E3,E4; > statement S; > iterator I; > @@ > > ( > if (...) { ... when != kfree(x) > when != x = E3 > when != E3 = x > * return ...; > } > ... when != x = E2 > when != I(...,x,...) S > if (...) { ... when != x = E4 > kfree(x); ... return ...; } > ) > // > > Signed-off-by: Julia Lawall > > --- > sound/soc/ep93xx/ep93xx-i2s.c | 5 +++-- > 1 file changed, 3 insertions(+), 2 deletions(-) > > diff --git a/sound/soc/ep93xx/ep93xx-i2s.c b/sound/soc/ep93xx/ep93xx-i2s.c > index 56efa0c..099614e 100644 > --- a/sound/soc/ep93xx/ep93xx-i2s.c > +++ b/sound/soc/ep93xx/ep93xx-i2s.c > @@ -385,14 +385,14 @@ static int ep93xx_i2s_probe(struct platform_device *pdev) > res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > if (!res) { > err = -ENODEV; > - goto fail; > + goto fail_free_info; > } > > info->mem = request_mem_region(res->start, resource_size(res), > pdev->name); > if (!info->mem) { > err = -EBUSY; > - goto fail; > + goto fail_free_info; > } > > info->regs = ioremap(info->mem->start, resource_size(info->mem)); > @@ -435,6 +435,7 @@ fail_unmap_mem: > iounmap(info->regs); > fail_release_mem: > release_mem_region(info->mem->start, resource_size(info->mem)); > +fail_free_info: > kfree(info); > fail: > return err; > >