From patchwork Sat Jun 8 06:46:07 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Lijun Ou X-Patchwork-Id: 10983025 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 5131C924 for ; Sat, 8 Jun 2019 06:43:22 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 3B9E528BF8 for ; Sat, 8 Jun 2019 06:43:22 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 2F3E928C02; Sat, 8 Jun 2019 06:43:22 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-7.9 required=2.0 tests=BAYES_00,MAILING_LIST_MULTI, RCVD_IN_DNSWL_HI autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 7D16628BF8 for ; Sat, 8 Jun 2019 06:43:21 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726924AbfFHGnU (ORCPT ); Sat, 8 Jun 2019 02:43:20 -0400 Received: from szxga04-in.huawei.com ([45.249.212.190]:18100 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726876AbfFHGnU (ORCPT ); Sat, 8 Jun 2019 02:43:20 -0400 Received: from DGGEMS410-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 125485E67E7D8C94D80D; Sat, 8 Jun 2019 14:43:18 +0800 (CST) Received: from linux-ioko.site (10.71.200.31) by DGGEMS410-HUB.china.huawei.com (10.3.19.210) with Microsoft SMTP Server id 14.3.439.0; Sat, 8 Jun 2019 14:43:11 +0800 From: Lijun Ou To: , CC: , , Subject: [PATCH V5 for-next 0/3] Add mix multihop addressing for supporting 32K Date: Sat, 8 Jun 2019 14:46:07 +0800 Message-ID: <1559976370-46306-1-git-send-email-oulijun@huawei.com> X-Mailer: git-send-email 1.9.1 MIME-Version: 1.0 X-Originating-IP: [10.71.200.31] X-CFilter-Loop: Reflected Sender: linux-rdma-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-rdma@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP This patch series mainly adds a mix multihop addressing for support the 32K specification of send wqe from UM. It adds the MTR (memory translate region) design for unified management of MTT (memory translate table). The MTT design requires that the hopnum of the address space must be the same and cannot meet the requirements of the current max hopnum of the hip08. The hopnum of sqwqe up to 3 level and the extend sge up to 1 level. As a result, we add an MTR based on mtt to solve this problem. The MTR allows a contiguous address space to use different hopnums, so that the driver supports the mixed hop feature in UM. Change from V4: 1. Remove the unnecessary mb(). Change from V3: 1. Remove the simple wrapper around kernel functions from Leon Romanovsky's reviews. Change from V2: 1. Remove building error. Change from V1: 1. Use new API named rdma_for_each_block instead of for_each_sg from Jason Gunthorpe's reviews. Lijun Ou (3): RDMA/hns: Add mtr support for mixed multihop addressing RDMA/hns: Add a group interfaces for optimizing buffers getting flow RDMA/hns: Fix bug when wqe num is larger than 16K drivers/infiniband/hw/hns/hns_roce_alloc.c | 99 ++++++ drivers/infiniband/hw/hns/hns_roce_device.h | 59 ++++ drivers/infiniband/hw/hns/hns_roce_hem.c | 460 ++++++++++++++++++++++++++++ drivers/infiniband/hw/hns/hns_roce_hem.h | 14 + drivers/infiniband/hw/hns/hns_roce_hw_v2.c | 118 ++++--- drivers/infiniband/hw/hns/hns_roce_mr.c | 118 +++++++ drivers/infiniband/hw/hns/hns_roce_qp.c | 189 +++++++++--- 7 files changed, 974 insertions(+), 83 deletions(-)