Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp5096394ybh; Wed, 7 Aug 2019 00:20:20 -0700 (PDT) X-Google-Smtp-Source: APXvYqzHE2818eDs6YKkHBgeuDMJzEgt5XBxceI784WRnI2HvWwaov0cGNpXPUZcSUw3+FF7FlxO X-Received: by 2002:a65:62cd:: with SMTP id m13mr6479986pgv.437.1565162420230; Wed, 07 Aug 2019 00:20:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565162420; cv=none; d=google.com; s=arc-20160816; b=HlvTvyefVZTVTemFejjcJAl75FZBLFTBa9MxTFH6nTubGXbzxCvQFujJ+MS/AiuWgk wUb+XB7bRlvVvMKgMJo7N3BheODUFz3QgUbOTGO15UMjQEUKw4riYS0klFzBQGkQsjZv O+T/kbyCWicvaeLTXdr4AYrC1FRHxi+UgvINJSVc3nFQsWO8QNy+Da4ZcefSpZRjashp k0FmPW/urSG/Kh2kS+3vpwSpErTsa+DmLEsUXdHOv76qxijXGg7SqZ7raOszbJrt2psG LKj65sMvBsu0QIIc6Gx3AiAbQq9Z8abM53IqnpgB3s+ghm6Hwf6N6jmLgU9seg9ZXkPQ ypkQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:subject:cc:to:from:message-id:date; bh=Fnz7XWAcPJw9IPpbkSDLxXEFIRqALP0+01YzKOJSYas=; b=vw0rBiYyaCTHbnCkJqgS0a1csClw5VzWQ9xbfqRBxwDFpLfw13a1Tf8qfPL/Hj38LT efj1ahBZ3ugxu9W5Gi48x4GNEwzQU4xFzupqfYAG5duMKZageJb2XiwIf1l+mNU7kvmd BrUOYk+q4k+YVtWOvjeieP856AWKL3sm/1hw6JWA3PXvzaopz3vtslVNVCuJ0c1FggkW JWjIKahcbU03CPnXlggQP636d9oz68uGzUl5fG4AgIvRpnfX3aRkQXUifNaaDgh4Cj2+ UhcZZVSdWSnJl5LJv4IN8oXNo9H1/Cp6fjJ/Ob/IagPXILQvQ1I04vpQDJfeXAWMgHpe hUkA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v16si50221934pfi.142.2019.08.07.00.20.04; Wed, 07 Aug 2019 00:20:20 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387429AbfHGHSx (ORCPT + 99 others); Wed, 7 Aug 2019 03:18:53 -0400 Received: from mx2.suse.de ([195.135.220.15]:54980 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727281AbfHGHSx (ORCPT ); Wed, 7 Aug 2019 03:18:53 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 7A192AF40; Wed, 7 Aug 2019 07:18:52 +0000 (UTC) Date: Wed, 07 Aug 2019 09:18:52 +0200 Message-ID: From: Takashi Iwai To: Wenwen Wang Cc: "moderated list:SOUND" , Thomas Gleixner , Greg Kroah-Hartman , Allison Randal , Jaroslav Kysela , Takashi Iwai , open list Subject: Re: [PATCH v2] ALSA: pcm: fix multiple memory leak bugs In-Reply-To: References: User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI/1.14.6 (Maruoka) FLIM/1.14.9 (=?UTF-8?B?R29qxY0=?=) APEL/10.8 Emacs/25.3 (x86_64-suse-linux-gnu) MULE/6.0 (HANACHIRUSATO) MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 07 Aug 2019 09:09:59 +0200, Wenwen Wang wrote: > > In hiface_pcm_init(), 'rt' is firstly allocated through kzalloc(). Later > on, hiface_pcm_init_urb() is invoked to initialize 'rt->out_urbs[i]'. In > hiface_pcm_init_urb(), 'rt->out_urbs[i].buffer' is allocated through > kzalloc(). However, if hiface_pcm_init_urb() fails, both 'rt' and > 'rt->out_urbs[i].buffer' are not deallocated, leading to memory leak bugs. > Also, 'rt->out_urbs[i].buffer' is not deallocated if snd_pcm_new() fails. > > To fix the above issues, free 'rt' and 'rt->out_urbs[i].buffer'. > > Signed-off-by: Wenwen Wang > --- > sound/usb/hiface/pcm.c | 8 +++++++- > 1 file changed, 7 insertions(+), 1 deletion(-) > > diff --git a/sound/usb/hiface/pcm.c b/sound/usb/hiface/pcm.c > index 14fc1e1..9b132aa 100644 > --- a/sound/usb/hiface/pcm.c > +++ b/sound/usb/hiface/pcm.c > @@ -599,12 +599,18 @@ int hiface_pcm_init(struct hiface_chip *chip, u8 > extra_freq) > for (i = 0; i < PCM_N_URBS; i++) { > ret = hiface_pcm_init_urb(&rt->out_urbs[i], chip, OUT_EP, > hiface_pcm_out_urb_handler); > - if (ret < 0) > + if (ret < 0) { > + for (; i >= 0; i--) > + kfree(rt->out_urbs[i].buffer); > + kfree(rt); > return ret; > + } > } > > ret = snd_pcm_new(chip->card, "USB-SPDIF Audio", 0, 1, 0, &pcm); > if (ret < 0) { > + for (i = 0; i < PCM_N_URBS; i++) > + kfree(rt->out_urbs[i].buffer); > kfree(rt); > dev_err(&chip->dev->dev, "Cannot create pcm instance\n"); > return ret; The fixes look correct, but since we can unconditionally call kfree() for NULL, both error paths can be unified as: for (i = 0; i < PCM_N_URBS; i++) kfree(rt->out_urbs[i].buffer); kfree(rt); and this would be better to be put in the common path at the end and do "goto error" or such from both places. BTW, your patch doesn't seem cleanly applicable in anyway because the tabs are converted to spaces. Please check the mail setup. Also, please try to make the subject line more unique. This is about hiface driver, so "ALSA: hiface: xxx" should be more appropriate. thanks, Takashi