Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp300742rwi; Tue, 18 Oct 2022 18:07:17 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5fKQRK6XfNCWj+CGl+d6a8AAcFNRkH7aifVkyeeUsn4Ys56Q7bbtU14J+55MtgRUgaS+r5 X-Received: by 2002:a05:6402:378c:b0:458:8053:6c5f with SMTP id et12-20020a056402378c00b0045880536c5fmr4918471edb.9.1666141636923; Tue, 18 Oct 2022 18:07:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666141636; cv=none; d=google.com; s=arc-20160816; b=y+uAQSIIaHqx9kJPJqSPeC4vYKuCv3hCV3tfMcKkPokxA1+zJNEiZgO0SUNIZ69Q6f yv1ipy6l2C07eXa9ZOJv0dbfjVoD6B4492/y68wMDuOQ3kPA4PfU6XrA965/173N9PF6 mq+i8ToXOSsuWOtsU7E2/hzxyULtpWPMl7Mv80ES1EWa4t80k/4NyOrf5ZIqHTqVRJOh otXr7/kBHWnEaPFitETHRBuflDMY59t6bAzy7xkNu8zh4KRDWalLaxDvTaz066SVzLfC L+7e+8Kd3EoQIhMcN7u2mkfJdxqeGEEPxv5UYERtfcoP5rZ/Iw9QVzpDlel19k6YrKOP vjSw== 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=034WE+YP4PFiS4NsUJdfqIo0+d2f2U6a55Zg+X//p6w=; b=K7CTum7RJ8HExC9cSlP0Z7MdiAAAnTQuWagiRzTBneB1FIgBOmnbX+CE/HCUIXqggd NLiAu8YGEl5ksOqrkthERzo64fYZ+mZx734gaJmji4hn1ROs3osj92n9VIhwq5hpo9cj zgCVtGolEs+eJYmxQ7GK15adWjQRbM42Cv3Uiu/bNCSBW8/InyXaboxiynMkj/ghrfsX GI94OiwPsSJZuyJ9Ew8mIj5bAnoaWipdp+WSQCyIc6fgmqfR9O5psYdDrzsuN8znWxgP X9F2nho+fZkbOwOiPDgkjyjZupaFvYv/zqXg9MQJ3ZmX667wvlXsKtfrAYB10hFJZMqk W0xg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id gb22-20020a170907961600b00734b2821879si14497835ejc.898.2022.10.18.18.06.49; Tue, 18 Oct 2022 18:07:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229767AbiJSAcb (ORCPT + 99 others); Tue, 18 Oct 2022 20:32:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40224 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229552AbiJSAc3 (ORCPT ); Tue, 18 Oct 2022 20:32:29 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 75971D73F1; Tue, 18 Oct 2022 17:32:28 -0700 (PDT) Received: from dggpemm500022.china.huawei.com (unknown [172.30.72.56]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4MsWnJ3B0FzpVcY; Wed, 19 Oct 2022 08:29:08 +0800 (CST) Received: from dggpemm500005.china.huawei.com (7.185.36.74) by dggpemm500022.china.huawei.com (7.185.36.162) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Wed, 19 Oct 2022 08:32:26 +0800 Received: from [10.69.30.204] (10.69.30.204) by dggpemm500005.china.huawei.com (7.185.36.74) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Wed, 19 Oct 2022 08:32:26 +0800 Subject: Re: [Patch v7 10/12] net: mana: Define data structures for allocating doorbell page from GDMA To: , "K. Y. Srinivasan" , "Haiyang Zhang" , Stephen Hemminger , Wei Liu , Dexuan Cui , "David S. Miller" , Jakub Kicinski , Paolo Abeni , Jason Gunthorpe , Leon Romanovsky , , , "Ajay Sharma" CC: , , , References: <1666034441-15424-1-git-send-email-longli@linuxonhyperv.com> <1666034441-15424-11-git-send-email-longli@linuxonhyperv.com> From: Yunsheng Lin Message-ID: Date: Wed, 19 Oct 2022 08:32:25 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.2.0 MIME-Version: 1.0 In-Reply-To: <1666034441-15424-11-git-send-email-longli@linuxonhyperv.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.69.30.204] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To dggpemm500005.china.huawei.com (7.185.36.74) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2022/10/18 3:20, longli@linuxonhyperv.com wrote: > From: Long Li > > The RDMA device needs to allocate doorbell pages for each user context. > Define the GDMA data structures for use by the RDMA driver. > > Reviewed-by: Dexuan Cui > Signed-off-by: Long Li > Acked-by: Haiyang Zhang > --- > Change log: > v4: use EXPORT_SYMBOL_NS > v7: move mana_gd_allocate_doorbell_page() and mana_gd_destroy_doorbell_page() to the RDMA driver > > include/net/mana/gdma.h | 25 +++++++++++++++++++++++++ > 1 file changed, 25 insertions(+) > > diff --git a/include/net/mana/gdma.h b/include/net/mana/gdma.h > index a9b7930dfbf8..bc060b6fa54c 100644 > --- a/include/net/mana/gdma.h > +++ b/include/net/mana/gdma.h > @@ -24,11 +24,15 @@ enum gdma_request_type { > GDMA_GENERATE_TEST_EQE = 10, > GDMA_CREATE_QUEUE = 12, > GDMA_DISABLE_QUEUE = 13, > + GDMA_ALLOCATE_RESOURCE_RANGE = 22, > + GDMA_DESTROY_RESOURCE_RANGE = 24, > GDMA_CREATE_DMA_REGION = 25, > GDMA_DMA_REGION_ADD_PAGES = 26, > GDMA_DESTROY_DMA_REGION = 27, > }; > > +#define GDMA_RESOURCE_DOORBELL_PAGE 27 > + > enum gdma_queue_type { > GDMA_INVALID_QUEUE, > GDMA_SQ, > @@ -587,6 +591,26 @@ struct gdma_register_device_resp { > u32 db_id; > }; /* HW DATA */ > > +struct gdma_allocate_resource_range_req { > + struct gdma_req_hdr hdr; > + u32 resource_type; > + u32 num_resources; > + u32 alignment; > + u32 allocated_resources; > +}; > + > +struct gdma_allocate_resource_range_resp { > + struct gdma_resp_hdr hdr; > + u32 allocated_resources; > +}; > + > +struct gdma_destroy_resource_range_req { > + struct gdma_req_hdr hdr; > + u32 resource_type; > + u32 num_resources; > + u32 allocated_resources; > +}; > + > /* GDMA_CREATE_QUEUE */ > struct gdma_create_queue_req { > struct gdma_req_hdr hdr; > @@ -695,4 +719,5 @@ void mana_gd_free_memory(struct gdma_mem_info *gmi); > > int mana_gd_send_request(struct gdma_context *gc, u32 req_len, const void *req, > u32 resp_len, void *resp); > + Unrelated change. > #endif /* _GDMA_H */ >