Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp5403318img; Wed, 27 Mar 2019 07:57:00 -0700 (PDT) X-Google-Smtp-Source: APXvYqwbMe0SAQbONcBt3op77CVUhxFZJnuFeTpHjVEb74Xem9EWmdI8uzMPy/VHfyvp26Y52ekp X-Received: by 2002:a65:50cc:: with SMTP id s12mr34553626pgp.130.1553698620851; Wed, 27 Mar 2019 07:57:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553698620; cv=none; d=google.com; s=arc-20160816; b=UIIIbAMDIlCTCelN7whPjV+GQrbt/75IG0G8WIj0hZPhKtHCWRV6EWkhO1EEHhILA1 BaIvTZDHCBAddxkMRsoF/JzZCPhrLG+jX1Kgp1Z5gN6V6jSHuTVWkSsucLoFXC+M3wV3 WGTfmOUwEgxMyaK4HwvFB33gvRVlJ19umiKa48nqlCJ3pMZpN4YKvagKj4dP67Bt2BUQ nuOWdV46R8cWVq0BTCzx0GMY5op7U6zhTOyrEbhSaMBFygdfRnLFwucELZWZjO4SVbDt jg0sUaYr6bFBNssmsJH40+oMd8H8pI9tXvvMD68Sz6wqXfCq3lhJRARhIyXJE47A/M85 8NHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature; bh=iESYhZi5SnLsW8aSKupszhy12zzLijSzcAriyVFf3TU=; b=YWXaVg2m9K/bmsgbrzi+WSZih2NOE9o3L/bLAPanpHJZby4AplLes1SFrjiLacAkee rMJp69REkhQ69qFc0jj7iN44MSW8QgOUYtXov55BcNju2ho9IMW7cAELfJ7vkf1fpAYM MfG/p7CCa4THBecYAvYD8eAliN7/axncLiSA6QaBcdTwXhPmPKkdEtbYGoZRRIqvxvg1 gFcvVcir1hDPdda6f0KztLoWDQes2lKhfFllnz9hMy5pKBMOOY1vglMwZ1O6p5JeSVGf WHsdOPpkvNAkvv1yMl6WpEZ1BxD+GTDLlf83UOMPy2ZfKGNQ5wfZZO1Kd+iwtVRohvyk QuIA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=dGxWHqMY; dkim=pass header.i=@codeaurora.org header.s=default header.b=YIHx5LHG; 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 25si18637016pgl.60.2019.03.27.07.56.45; Wed, 27 Mar 2019 07:57:00 -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; dkim=pass header.i=@codeaurora.org header.s=default header.b=dGxWHqMY; dkim=pass header.i=@codeaurora.org header.s=default header.b=YIHx5LHG; 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 S1728739AbfC0O4F (ORCPT + 99 others); Wed, 27 Mar 2019 10:56:05 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:56756 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727488AbfC0O4F (ORCPT ); Wed, 27 Mar 2019 10:56:05 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id AC82360A0A; Wed, 27 Mar 2019 14:56:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1553698564; bh=TQt9HC+tr1uEQzkbJoLeoLoHRM/F3bRwChMrVh9KkDo=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=dGxWHqMYpujb5nyYxjspPxXMuuobnoXSpUJJ7v9u5adPm/yyNVsqBjy5hf0TqVGG/ lK8JJhbPnK61WPrJejeTd1DLDmmWJuSB5t8WOp/2qNJdg9GBXgzyUxj+rRq5jgVTNg vn3CqsCaRNSlE2HzED1mfBBqWNWS0nV56GCdG2u8= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from [10.204.79.83] (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: mojha@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 458E2605A2; Wed, 27 Mar 2019 14:55:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1553698562; bh=TQt9HC+tr1uEQzkbJoLeoLoHRM/F3bRwChMrVh9KkDo=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=YIHx5LHG8wJzEsMn8ENa0tFIY+gz2WonAaPrxOVta7k6fSafl3ipos8+xprLN9Xfd 4zw557+MRkueCPCKUgnz5Us74aaxAMjva0LuWcmDzgN7ecPCxrRivz61XU7k3UGR1w wSeROKV2itDW+umJZLIXulZ6A8IwaebpjZsJmkjI= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 458E2605A2 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=mojha@codeaurora.org Subject: Re: [PATCH v3] dccp: Fix memleak in __feat_register_sp To: Yue Haibing , davem@davemloft.net, gerrit@erg.abdn.ac.uk Cc: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, dccp@vger.kernel.org References: <20190325024106.10808-1-yuehaibing@huawei.com> From: Mukesh Ojha Message-ID: <120ffaa7-0e53-7a19-7fbf-898275ff3dab@codeaurora.org> Date: Wed, 27 Mar 2019 20:25:57 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.6.0 MIME-Version: 1.0 In-Reply-To: <20190325024106.10808-1-yuehaibing@huawei.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/25/2019 8:11 AM, Yue Haibing wrote: > From: YueHaibing > > If dccp_feat_push_change fails, we forget free the mem > which is alloced by kmemdup in dccp_feat_clone_sp_val. > > Reported-by: Hulk Robot > Fixes: e8ef967a54f4 ("dccp: Registration routines for changing feature values") > Signed-off-by: YueHaibing Reviewed-by: Mukesh Ojha -Mukesh > --- > v3: fix compile issue, sorry for this again > v2: kfree 'val --> 'fval' > --- > net/dccp/feat.c | 7 ++++++- > 1 file changed, 6 insertions(+), 1 deletion(-) > > diff --git a/net/dccp/feat.c b/net/dccp/feat.c > index f227f00..db87d9f 100644 > --- a/net/dccp/feat.c > +++ b/net/dccp/feat.c > @@ -738,7 +738,12 @@ static int __feat_register_sp(struct list_head *fn, u8 feat, u8 is_local, > if (dccp_feat_clone_sp_val(&fval, sp_val, sp_len)) > return -ENOMEM; > > - return dccp_feat_push_change(fn, feat, is_local, mandatory, &fval); > + if (dccp_feat_push_change(fn, feat, is_local, mandatory, &fval)) { > + kfree(fval.sp.vec); > + return -ENOMEM; > + } > + > + return 0; > } > > /**