Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp9083338pxu; Mon, 28 Dec 2020 06:14:02 -0800 (PST) X-Google-Smtp-Source: ABdhPJxGeqj8FRGSqEdcuUdz5hie/wmCtrWlDd5aef6RhoFizWkFRXXz/RoJx9ew83zeX377JUj7 X-Received: by 2002:a17:906:8587:: with SMTP id v7mr40775569ejx.381.1609164842563; Mon, 28 Dec 2020 06:14:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609164842; cv=none; d=google.com; s=arc-20160816; b=0wZvlAALkNvPt9J7dgz7u5CnA6qGaivZZkH1F1GRwUNmudG8eLDJNW3KDWeZsm3qxp 6JNj52ezkt7y4BMwJ3RbFzN4tkE0qH8/r1l0jOVTWGxbGBv3Ws2ngqHjJ2oXiN4U+SKZ co15p1cpjtuXaGQdvPnc9NaiUFzir/Sf7zHgjkGoak0IAx+0YHOJma/CiwtDRKjYvxzi xNEjwCoEBT4jRXRIQPbfiTGTPq37Y+I9kNEQHGn62q7FbEHOnaPTH+TWQNZtCMaKi8Ip e4RXLWTNKxmK8Yhq3paJEcWkYibBQ6iedVTs/lvAQmYV3MfsGj4/uTcwEix7VmfJiLx8 2O7A== 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=TV40z/JYahCfvGedqKfoxJvM63LvkgqMYXdmw1VyMRs=; b=K6Ed4Vcd9D2mRVvmtnyNqnox27Us6uCX3yzwgkIZjh1nhNGppaiCqjsO6t20IqV0yl j5IcfD1H+LKPQ23/Y6r0Ogw4n1ZTXMnvUBbOSQ9kwY8LuR0iBKN/BHUKf4HJ4x24wXiE zcWsdY7EClpsnOfXdTcN4hdyxO4W2FKT04OstTwSeI9Ug5TFBJ1BnFPDELOgNkRNGXXE W/KKKAnbcUfZTaIBgx+vn3O9kHJBRQ8s3hyV2HQnaIm9nadqxQuZ28GxmQZTLKwnHa4/ 3oV+V4maYdvaF8kC3d9ZQLl/L0omklHyb+29wufYXVP2/m/0dqsjZrl+mF8HvT8/pDUo LzMw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=qQ1YjirW; 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 mj22si20051712ejb.215.2020.12.28.06.13.39; Mon, 28 Dec 2020 06:14:02 -0800 (PST) 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=qQ1YjirW; 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 S2439717AbgL1OLs (ORCPT + 99 others); Mon, 28 Dec 2020 09:11:48 -0500 Received: from mail.kernel.org ([198.145.29.99]:46114 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2438262AbgL1OLe (ORCPT ); Mon, 28 Dec 2020 09:11:34 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4E0FC2063A; Mon, 28 Dec 2020 14:10:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1609164653; bh=J7uXcimMyrLG0k4XiOsYBhJdZDeCruM9JJ28bnHkbC4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qQ1YjirWUeWa4TNZBmh20mtANg/P4yKV45omUv/3ulL4BnaUqWxl/7Ws0hg9+2Zq8 alyx0XSK2zjpG3zpePtS1sGEJRfeJUwVC5N24whGh7lQ/YMm7SPZ7STegwi/y4ZBOr ixmJ1I4lcW9BYkR/6NKyKib07BRr5tATjtHXFd3Y= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lang Cheng , Weihang Li , Leon Romanovsky , Jason Gunthorpe , Sasha Levin Subject: [PATCH 5.10 251/717] RDMA/hns: Fix 0-length sge calculation error Date: Mon, 28 Dec 2020 13:44:09 +0100 Message-Id: <20201228125033.014391388@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201228125020.963311703@linuxfoundation.org> References: <20201228125020.963311703@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: Lang Cheng [ Upstream commit 0fd0175e30e487f8d70ecb2cdd67fbb514fdf50f ] One RC SQ WQE can store 2 sges but UD can't, so ignore 2 valid sges of wr.sglist for RC which have been filled in WQE before setting extended sge. Either of RC and UD can not contain 0-length sges, so these 0-length sges should be skipped. Fixes: 54d6638765b0 ("RDMA/hns: Optimize WQE buffer size calculating process") Link: https://lore.kernel.org/r/1606558959-48510-2-git-send-email-liweihang@huawei.com Signed-off-by: Lang Cheng Signed-off-by: Weihang Li Reviewed-by: Leon Romanovsky Signed-off-by: Jason Gunthorpe Signed-off-by: Sasha Levin --- drivers/infiniband/hw/hns/hns_roce_hw_v2.c | 24 +++++++++------------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/drivers/infiniband/hw/hns/hns_roce_hw_v2.c b/drivers/infiniband/hw/hns/hns_roce_hw_v2.c index 4db7eea3dcec5..c287dbd2f384d 100644 --- a/drivers/infiniband/hw/hns/hns_roce_hw_v2.c +++ b/drivers/infiniband/hw/hns/hns_roce_hw_v2.c @@ -214,25 +214,20 @@ static int fill_ext_sge_inl_data(struct hns_roce_qp *qp, return 0; } -static void set_extend_sge(struct hns_roce_qp *qp, const struct ib_send_wr *wr, - unsigned int *sge_ind, unsigned int valid_num_sge) +static void set_extend_sge(struct hns_roce_qp *qp, struct ib_sge *sge, + unsigned int *sge_ind, unsigned int cnt) { struct hns_roce_v2_wqe_data_seg *dseg; - unsigned int cnt = valid_num_sge; - struct ib_sge *sge = wr->sg_list; unsigned int idx = *sge_ind; - if (qp->ibqp.qp_type == IB_QPT_RC || qp->ibqp.qp_type == IB_QPT_UC) { - cnt -= HNS_ROCE_SGE_IN_WQE; - sge += HNS_ROCE_SGE_IN_WQE; - } - while (cnt > 0) { dseg = hns_roce_get_extend_sge(qp, idx & (qp->sge.sge_cnt - 1)); - set_data_seg_v2(dseg, sge); - idx++; + if (likely(sge->length)) { + set_data_seg_v2(dseg, sge); + idx++; + cnt--; + } sge++; - cnt--; } *sge_ind = idx; @@ -340,7 +335,8 @@ static int set_rwqe_data_seg(struct ib_qp *ibqp, const struct ib_send_wr *wr, } } - set_extend_sge(qp, wr, sge_ind, valid_num_sge); + set_extend_sge(qp, wr->sg_list + i, sge_ind, + valid_num_sge - HNS_ROCE_SGE_IN_WQE); } roce_set_field(rc_sq_wqe->byte_16, @@ -511,7 +507,7 @@ static inline int set_ud_wqe(struct hns_roce_qp *qp, memcpy(&ud_sq_wqe->dgid[0], &ah->av.dgid[0], GID_LEN_V2); - set_extend_sge(qp, wr, &curr_idx, valid_num_sge); + set_extend_sge(qp, wr->sg_list, &curr_idx, valid_num_sge); *sge_idx = curr_idx; -- 2.27.0