Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp244874pxj; Fri, 14 May 2021 02:19:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyLVpPYjUAIwC8NYlArhZ/m15hbu1UzRVyr00FG4cv6f007ir+1dei89LOeKsHXa2bGSuP9 X-Received: by 2002:a92:da06:: with SMTP id z6mr41177402ilm.129.1620983973010; Fri, 14 May 2021 02:19:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620983973; cv=none; d=google.com; s=arc-20160816; b=jF7fclvQMHOesYIC221DXvwCLZ5y/YGv2JJrfGtv9sV9BkHyar4eb6EJ3s+yNWOjec RbzVLSF6E1XKkUvxXJFEZr4RTW77rMqrmXJl4N7PWsypaPzemi/7sHX5cPN3g9OSRM+P nrmWXJI+bWYLMy38pkJb7Li1vvYIXAmpaKL+4Y6mq8P3mhLGezMGdgUiggYqIRspiqYx J350KBE4u87bmNfmbWxzBiA0255OM1qNcb0c75YadJSltxTFV1do3erpECs8l5FtNXC9 SH6rAz8TXYQbs7G4wgrN7FWuxQ8SMkEhmIoo8pDPRC5mQjJPIkHj+8x0HRt7pWdsmfuQ azvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=PALKO/ZmBba8DWUiQAcupRawTuMcbmcdH19qDlLlH7s=; b=zRxlScGyBnMCa67cAIRrFWuKiAJ5qV4yBQh6PR6gSfOVVkfedJI/sRJm35yHuVBkV2 T2jYK0lgkIZvqkh1B4dpEEuSqORLzkiQ0+sH2+zFx7HecikJPoEsuRuczhMc7y+s1qSd 4KlxMGCvXfQ1J5DedyIDJGFwoJ0YoBCLIowTuK88uKwe2rClS1C+MoBhXpECC5PI7m3g 0Lcg1xkJucIWI7AkpUvguqd4U3nNIkVcN/hyjgnYKM/Ohl5QExgoUCf0f8YNruBzcTsw JTdLjGnf5NV/TK66mdEAQ3a+ZubfWkQgulPhLp87U4iYjtXUR5HXuUKZvZb05HaOvkfO +q9g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o1si7329263jat.48.2021.05.14.02.19.10; Fri, 14 May 2021 02:19:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232241AbhENExp (ORCPT + 99 others); Fri, 14 May 2021 00:53:45 -0400 Received: from out30-56.freemail.mail.aliyun.com ([115.124.30.56]:51986 "EHLO out30-56.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231967AbhENExp (ORCPT ); Fri, 14 May 2021 00:53:45 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R681e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04426;MF=tianjia.zhang@linux.alibaba.com;NM=1;PH=DS;RN=9;SR=0;TI=SMTPD_---0UYoDsTm_1620967950; Received: from B-455UMD6M-2027.local(mailfrom:tianjia.zhang@linux.alibaba.com fp:SMTPD_---0UYoDsTm_1620967950) by smtp.aliyun-inc.com(127.0.0.1); Fri, 14 May 2021 12:52:31 +0800 Subject: Re: [PATCH 1/7] crypto: fix a memory leak in sm2 To: Hongbo Li , keyrings@vger.kernel.org, linux-crypto@vger.kernel.org, herbert@gondor.apana.org.au, dhowells@redhat.com, jarkko@kernel.org, herberthbli@tencent.com, stable@vger.kernel.org Cc: linux-kernel@vger.kernel.org References: <1620828254-25545-1-git-send-email-herbert.tencent@gmail.com> <1620828254-25545-2-git-send-email-herbert.tencent@gmail.com> From: Tianjia Zhang Message-ID: <246ad441-76c9-0934-d132-42d263d63195@linux.alibaba.com> Date: Fri, 14 May 2021 12:52:29 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:78.0) Gecko/20100101 Thunderbird/78.9.0 MIME-Version: 1.0 In-Reply-To: <1620828254-25545-2-git-send-email-herbert.tencent@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org Hi Hongbo, On 5/12/21 10:04 PM, Hongbo Li wrote: > From: Hongbo Li > > SM2 module alloc ec->Q in sm2_set_pub_key(), when doing alg test in > test_akcipher_one(), it will set public key for every test vector, > and don't free ec->Q. This will cause a memory leak. > > This patch alloc ec->Q in sm2_ec_ctx_init(). > > Signed-off-by: Hongbo Li > --- > crypto/sm2.c | 24 ++++++++++-------------- > 1 file changed, 10 insertions(+), 14 deletions(-) > > diff --git a/crypto/sm2.c b/crypto/sm2.c > index b21addc..db8a4a2 100644 > --- a/crypto/sm2.c > +++ b/crypto/sm2.c > @@ -79,10 +79,17 @@ static int sm2_ec_ctx_init(struct mpi_ec_ctx *ec) > goto free; > > rc = -ENOMEM; > + > + ec->Q = mpi_point_new(0); > + if (!ec->Q) > + goto free; > + > /* mpi_ec_setup_elliptic_curve */ > ec->G = mpi_point_new(0); > - if (!ec->G) > + if (!ec->G) { > + mpi_point_release(ec->Q); > goto free; > + } > > mpi_set(ec->G->x, x); > mpi_set(ec->G->y, y); > @@ -91,6 +98,7 @@ static int sm2_ec_ctx_init(struct mpi_ec_ctx *ec) > rc = -EINVAL; > ec->n = mpi_scanval(ecp->n); > if (!ec->n) { > + mpi_point_release(ec->Q); > mpi_point_release(ec->G); > goto free; > } > @@ -386,27 +394,15 @@ static int sm2_set_pub_key(struct crypto_akcipher *tfm, > MPI a; > int rc; > > - ec->Q = mpi_point_new(0); > - if (!ec->Q) > - return -ENOMEM; > - > /* include the uncompressed flag '0x04' */ > - rc = -ENOMEM; > a = mpi_read_raw_data(key, keylen); > if (!a) > - goto error; > + return -ENOMEM; > > mpi_normalize(a); > rc = sm2_ecc_os2ec(ec->Q, a); > mpi_free(a); > - if (rc) > - goto error; > - > - return 0; > > -error: > - mpi_point_release(ec->Q); > - ec->Q = NULL; > return rc; > } > > Thanks a lot for fixing this issue. Reviewed-by: Tianjia Zhang Also added: Cc: stable@vger.kernel.org # v5.10+ Best regards, Tianjia