Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4753132pxj; Wed, 12 May 2021 12:26:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzvEdVtCRb36I1NlpcOd2iox1fOWpVMS6a6BwrQqTXhjSGvxOuy2D+mA/Nk0RuCtFBfDB17 X-Received: by 2002:a17:906:c0c6:: with SMTP id bn6mr38503568ejb.436.1620847597510; Wed, 12 May 2021 12:26:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620847597; cv=none; d=google.com; s=arc-20160816; b=aioU7B7DhQykSboo1tTVTDbDWm0MSCzzOmgwTYvme1s8xGCpk7utD17BxDJ0cAaEq1 KtSc3SHxxxQh308DlHybMb2Z20gUxqsS5lD9JdQqIx8RwbmwPVvZFJOVpdDurnFG/XOV jjjDlO7Z+ToMFGhne7rIC8cNGKcqYc91YRvc4b0CbnqZV3Zn6+KPX1bkMvfAxHACcYhP o7ZRuaAopFWgaT/VpKrJtMgWMYJsB9IkbPAmKPpxB7OsYwXHuH6jmnXXPG4rkkVjwI8V EXrJjgsnFY8iPxmrq6a0eNv1Q7pV8cQ+CTrvdIlYygXvN3oiKsp8ZY/jHQ3MAS5LJOUO G4KA== 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=knpybCaq2ug+8IouzoWbNTLaA8T2kmk3J9FVLCSMYpI=; b=Pjn0uivM22gp8k9Ubi6iVNH89Enq9zkIjCv3HgeoNzRnMYA6agXAXQDSlZmQ+OGVde zKHxsRZ3vCHhYISKrMRM0FSzhVAiElF1YJZ+2JEvo/ZUzEOhealvC7ngb7OkL/ndh6lO kt7XjkV54+jAMYqEnxZlubb23feA1XmPE3cWETY2e40F9b0DldyCkTMb3iH3fgzfFjxU 6nV7dqxM/ART16btjfe73OuizLTqduSuD2I1pCH3Y3nz7g4L+6B1r4nuXqk6num79dds Tomk3Qn9PQOR1QvbD7qYqLryZ6UZEv/VyBGSoQ6Xv/AQxz1hHmeFRKAkrvnz7J4E0b3C iI+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=zrLSiZEK; 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 l1si508750edf.254.2021.05.12.12.26.14; Wed, 12 May 2021 12:26:37 -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=zrLSiZEK; 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 S1344368AbhELTZx (ORCPT + 99 others); Wed, 12 May 2021 15:25:53 -0400 Received: from mail.kernel.org ([198.145.29.99]:41654 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238069AbhELQtf (ORCPT ); Wed, 12 May 2021 12:49:35 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id C7F7D61E88; Wed, 12 May 2021 16:16:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620836170; bh=Tbn9h4SMOYPwZpNyoDnvhtH+HSGF65npXXTH3EK8veQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zrLSiZEKPYatkSf7SWBosGmcVMbJTyBhAhAg4oZcbzx9ROLo8A/ouY48LXH25n3aW a8LlJPvScJLyO6UevI8fXhbKku2IxLcQpIbCPFOpKth3HaVqjF5Eh5QO2V9BZdh02D BQG5aqejISPUGQjgO1f4EBTGSjCNm1xgVc1dxLOM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Dan Carpenter , Sindhu Devale , Shiraz Saleem , Jason Gunthorpe , Sasha Levin Subject: [PATCH 5.12 604/677] RDMA/i40iw: Fix error unwinding when i40iw_hmc_sd_one fails Date: Wed, 12 May 2021 16:50:50 +0200 Message-Id: <20210512144857.430443159@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144837.204217980@linuxfoundation.org> References: <20210512144837.204217980@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: Sindhu Devale [ Upstream commit 783a11bf2400e5d5c42a943c3083dc0330751842 ] When i40iw_hmc_sd_one fails, chunk is freed without the deletion of chunk entry in the PBLE info list. Fix it by adding the chunk entry to the PBLE info list only after successful addition of SD in i40iw_hmc_sd_one. This fixes a static checker warning reported here: https://lore.kernel.org/linux-rdma/YHV4CFXzqTm23AOZ@mwanda/ Fixes: 9715830157be ("i40iw: add pble resource files") Link: https://lore.kernel.org/r/20210416002104.323-1-shiraz.saleem@intel.com Reported-by: Dan Carpenter Signed-off-by: Sindhu Devale Signed-off-by: Shiraz Saleem Signed-off-by: Jason Gunthorpe Signed-off-by: Sasha Levin --- drivers/infiniband/hw/i40iw/i40iw_pble.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/drivers/infiniband/hw/i40iw/i40iw_pble.c b/drivers/infiniband/hw/i40iw/i40iw_pble.c index 53e5cd1a2bd6..146a4148219b 100644 --- a/drivers/infiniband/hw/i40iw/i40iw_pble.c +++ b/drivers/infiniband/hw/i40iw/i40iw_pble.c @@ -393,12 +393,9 @@ static enum i40iw_status_code add_pble_pool(struct i40iw_sc_dev *dev, i40iw_debug(dev, I40IW_DEBUG_PBLE, "next_fpm_addr = %llx chunk_size[%u] = 0x%x\n", pble_rsrc->next_fpm_addr, chunk->size, chunk->size); pble_rsrc->unallocated_pble -= (chunk->size >> 3); - list_add(&chunk->list, &pble_rsrc->pinfo.clist); sd_reg_val = (sd_entry_type == I40IW_SD_TYPE_PAGED) ? sd_entry->u.pd_table.pd_page_addr.pa : sd_entry->u.bp.addr.pa; - if (sd_entry->valid) - return 0; - if (dev->is_pf) { + if (dev->is_pf && !sd_entry->valid) { ret_code = i40iw_hmc_sd_one(dev, hmc_info->hmc_fn_id, sd_reg_val, idx->sd_idx, sd_entry->entry_type, true); @@ -409,6 +406,7 @@ static enum i40iw_status_code add_pble_pool(struct i40iw_sc_dev *dev, } sd_entry->valid = true; + list_add(&chunk->list, &pble_rsrc->pinfo.clist); return 0; error: kfree(chunk); -- 2.30.2