Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2725691pxv; Sun, 11 Jul 2021 23:58:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzSA4CBVslOybWiYX8s/qcEvCadJ/QFhW0lthM57joKN2TKHimNrvTPG+ZZRx3lMHkcmJrz X-Received: by 2002:a92:dd89:: with SMTP id g9mr37300709iln.209.1626073124916; Sun, 11 Jul 2021 23:58:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626073124; cv=none; d=google.com; s=arc-20160816; b=aMEW6jVhk3yjfemLboTxsOYLPbzY0utiJ2K3c4K1y6AIHwAu0qzqXdQ4302AI+JkYt g2oudVpJLsNljw7VWF9sHJallfqNWwNgot4Cs2i0YcGvT/62g3dKfTYVYQSNvkILYZrx w0yLs2ZV/JuKYZyAKSSMKzUjsWSO1A/hdgwPrRP2NbD6zz08HGtoUxkNpoEwc7ltNBxN p3cR0CGOxVni3t6XLvJT81fjenUat6rGpERSlJjpl5HOhlCfR4Oeb6kBphke5lWWrZGD Ke0tHNufnBdGD/axTLLSsosxNpKS59QFkpiqX6UrrcYzTKkxUboYCrj/hdBHUt9pFnny unjA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=n/X1C1coV2QhXDFtALur9r7d9PKN+fG/9BlsEw+QV4g=; b=qjBXuy2lBsmcGBlmSd9qvAu/k2oQZavb56LvOJ+e/Zgk18GbGjnx132GXJG2E+NVua zr4joPg8WrrmeZ9OE/Gyg/ZWrPeqxrsxoLkVdahhuhgotnK9kJO+PeDkktXM87iqZwuE m2rWwQogsGwqRLOg6yhKuEwmcIo/JFTHynOSsOO/vm1CYVIeUkFHlrfiaWwWBYCZ3H0T n/pLPB7FegjDQzBTGtVl7ueh3TVyWnWxyOBF7m+SNyPUQ+pO5GG/8bJaqNsTgHcF0so6 TyasthbsywUlH7IGRWm7b66m+gOT7DYbXD23igUPuG+WZHPMxW/PDg+1Nb+RktB6dATG 1L6g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=1BfmrTlY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r6si18168546iov.48.2021.07.11.23.58.33; Sun, 11 Jul 2021 23:58:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=1BfmrTlY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242199AbhGLG7u (ORCPT + 99 others); Mon, 12 Jul 2021 02:59:50 -0400 Received: from mail.kernel.org ([198.145.29.99]:41894 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238953AbhGLGob (ORCPT ); Mon, 12 Jul 2021 02:44:31 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 0462D61179; Mon, 12 Jul 2021 06:40:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626072025; bh=ESdIGpwSCk/t2BjGc+wdVh2bU381kVYma1kaCdaZ64U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=1BfmrTlYtm0vQsuoqqjZtqKV5mGGxLteCqJ2IIG14Amk5aiBjcRVe4S1dq/R5Ftuw 5OCZHsonOR4geQhzhqJfAFKpI0WH9R0gKpJsemFi34zQv6dLLsscNsN+OFJt4/SlUE pzOoPrkajC4Gqv/tkuFFlc0lIWrnr3rZNm2znV4c= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Max Gurtovoy , Bart Van Assche , Jason Gunthorpe , Sasha Levin Subject: [PATCH 5.10 321/593] RDMA/srp: Fix a recently introduced memory leak Date: Mon, 12 Jul 2021 08:08:01 +0200 Message-Id: <20210712060920.921983933@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060843.180606720@linuxfoundation.org> References: <20210712060843.180606720@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bart Van Assche [ Upstream commit 7ec2e27a3afff64c96bfe7a77685c33619db84be ] Only allocate a memory registration list if it will be used and if it will be freed. Link: https://lore.kernel.org/r/20210524041211.9480-5-bvanassche@acm.org Reviewed-by: Max Gurtovoy Fixes: f273ad4f8d90 ("RDMA/srp: Remove support for FMR memory registration") Signed-off-by: Bart Van Assche Signed-off-by: Jason Gunthorpe Signed-off-by: Sasha Levin --- drivers/infiniband/ulp/srp/ib_srp.c | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/drivers/infiniband/ulp/srp/ib_srp.c b/drivers/infiniband/ulp/srp/ib_srp.c index a8f85993dab3..86d5c4c92b36 100644 --- a/drivers/infiniband/ulp/srp/ib_srp.c +++ b/drivers/infiniband/ulp/srp/ib_srp.c @@ -998,7 +998,6 @@ static int srp_alloc_req_data(struct srp_rdma_ch *ch) struct srp_device *srp_dev = target->srp_host->srp_dev; struct ib_device *ibdev = srp_dev->dev; struct srp_request *req; - void *mr_list; dma_addr_t dma_addr; int i, ret = -ENOMEM; @@ -1009,12 +1008,12 @@ static int srp_alloc_req_data(struct srp_rdma_ch *ch) for (i = 0; i < target->req_ring_size; ++i) { req = &ch->req_ring[i]; - mr_list = kmalloc_array(target->mr_per_cmd, sizeof(void *), - GFP_KERNEL); - if (!mr_list) - goto out; - if (srp_dev->use_fast_reg) - req->fr_list = mr_list; + if (srp_dev->use_fast_reg) { + req->fr_list = kmalloc_array(target->mr_per_cmd, + sizeof(void *), GFP_KERNEL); + if (!req->fr_list) + goto out; + } req->indirect_desc = kmalloc(target->indirect_size, GFP_KERNEL); if (!req->indirect_desc) goto out; -- 2.30.2