Received: by 2002:ab2:620c:0:b0:1ef:ffd0:ce49 with SMTP id o12csp247348lqt; Mon, 18 Mar 2024 06:58:19 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWToR89f4fpqiEZqYg/Kp3ASRLpdSptu/0/0ObX1Y8mwpIQF+zQPtszEv6nkCfjqNuGvV0AOm43E2s4LR80plCy1yghq3A9TzvOwP7FSQ== X-Google-Smtp-Source: AGHT+IH/BPKIs6FAwz+yChoovmsA0F1RCy0omp6X3jR4mvILW6eLS5u6R4a9p4iRz1mVh3emJ7SF X-Received: by 2002:a17:902:d584:b0:1de:fbe1:bea9 with SMTP id k4-20020a170902d58400b001defbe1bea9mr8742648plh.19.1710770298781; Mon, 18 Mar 2024 06:58:18 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710770298; cv=pass; d=google.com; s=arc-20160816; b=Ig/0Aq5jO3c7NkVRHFQDDvoN+zhQ8q1TVQqgx+SE2+7kgAbBMpSCsymESgySFbxfuk DQQvb/H4Yf7E3mz6Up9U8EAFBW3/TSZjdZ3cWcXdhhPv3pIammozbYGRn4RXT6dPLKmI ATZ2iHY6jNxmkw1au2HZIUUJGcCWq/Jm57BXnfreQqgWuyqjTZiohFSGrdUviRB8U7dY fGl26+nLN8cvUmQVftyekV5Ix4Hri+HWy1tBpmB4tccfL8zxvqJyfyah05XmIEA2kXIZ WtJL4f5khytRgzkHr09ssINMWzRoRiNt2O8YumxevJKWhgyBRmEgsKWlG646k8w8xpIh cJKQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:dkim-signature:message-id; bh=muvpwz7a96M6/2doTJBM5VlsnMcGZ+AFVmWiFaXOnls=; fh=JRxYl51YAdd7Oo5hMaxaPISnuOjrPFosyzQOxoxhHjE=; b=x8K4XZhfjD4pxe+Y7chxd4EhEN15U6Fia10QCpuAHJ8F3diRk9Jwmlzf2FPVKJCNZU WgGqHoNzqQX8INWcYyQseL0kXhSru8i7r9kTZ0ZfuH3BdUoJ18okqRosdL4zV8Nt2SOd 55jBOyHJyHPmj2Voc9XlMml6kFKd0Z6YoW0U8MLa8+G2D6iu052hkw2burXDuE7hFEUo u1m70gPzvnZBKlYC6HRFyfNQ6fY17MmXOvPuE7d2MjN3Sl0VsU89whAzoFyPQ6TzOnRe fKvCH9j0lOjGujoawBkmNTyBLbXIDhmcxYHGRYnidcuOIaep8FNL+eOAC63uhJOt2e7U KzJQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linux.dev header.s=key1 header.b=kfiTWVdT; arc=pass (i=1 spf=pass spfdomain=linux.dev dkim=pass dkdomain=linux.dev dmarc=pass fromdomain=linux.dev); spf=pass (google.com: domain of linux-kernel+bounces-106184-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-106184-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.dev Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id mc3-20020a1709032b0300b001e038619e1csi459005plb.567.2024.03.18.06.58.18 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Mar 2024 06:58:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-106184-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@linux.dev header.s=key1 header.b=kfiTWVdT; arc=pass (i=1 spf=pass spfdomain=linux.dev dkim=pass dkdomain=linux.dev dmarc=pass fromdomain=linux.dev); spf=pass (google.com: domain of linux-kernel+bounces-106184-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-106184-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.dev Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id C1944B21CA4 for ; Mon, 18 Mar 2024 13:57:00 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8762F4AEDD; Mon, 18 Mar 2024 13:56:51 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=linux.dev header.i=@linux.dev header.b="kfiTWVdT" Received: from out-186.mta1.migadu.com (out-186.mta1.migadu.com [95.215.58.186]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 623F548CFC for ; Mon, 18 Mar 2024 13:56:47 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=95.215.58.186 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710770210; cv=none; b=L3HeYnQ44ixvMEkrd04bZEI02D7f2jTvsE+E+5lbAksldroOl2r3RZEHLUTkXNH8NDMdKJ65JMi2DARVOODJpcjuKXs3Iowc3YhSeV7+ft/oBjqlzJyx7AbgwcSeXevKVBVtRfqqsYCja+Fea8sFMq5vdSKmIZ8JkN2NKLX4NKs= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710770210; c=relaxed/simple; bh=ERVnSpjVdDsO/HGZdby1785ElVvvS6M95VHMrvBbUs4=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=gCS1CdocgE20rCsEbt9Ctg6J4/+YeOtPJm/bmqei6SBueRBPe+vurxvYlpb9eEHwy+pm/0PJRi9B1aw/RQ/TJxk2bZzmpJddpr9NRLgSif5S2uspzrndTYt7JhIeFtuWJe1zPxkIW5jvUSdR4UnJmR90JUpNd6QGSa3L+Vxa8yA= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linux.dev; spf=pass smtp.mailfrom=linux.dev; dkim=pass (1024-bit key) header.d=linux.dev header.i=@linux.dev header.b=kfiTWVdT; arc=none smtp.client-ip=95.215.58.186 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linux.dev Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linux.dev Message-ID: <6f0a86cd-dd01-40b1-87ed-39f8d655e18a@linux.dev> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.dev; s=key1; t=1710770205; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=muvpwz7a96M6/2doTJBM5VlsnMcGZ+AFVmWiFaXOnls=; b=kfiTWVdT8ReLHqMbkUM8dB16NUYpUQUu9Yfp8lnzUy1+Tt/BID2KvcFeq1kyyd8XZNw+kF qBPpBYMR2nJqFecICQ2n+oHEsQPz6kmT96Pf3Wm3CD8l/HvSrrP2hiOdKlKcGuxRd/3fw3 7hjvwA236ed1PCoUQV/oqXVOJQlnIYs= Date: Mon, 18 Mar 2024 14:56:42 +0100 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Subject: Re: [EXTERNAL] Re: [PATCH rdma-next 1/4] RDMA/mana_ib: Introduce helpers to create and destroy mana queues To: Konstantin Taranov , Konstantin Taranov , "sharmaajay@microsoft.com" , Long Li , "jgg@ziepe.ca" , "leon@kernel.org" Cc: "linux-rdma@vger.kernel.org" , "linux-kernel@vger.kernel.org" References: <1710336299-27344-1-git-send-email-kotaranov@linux.microsoft.com> <1710336299-27344-2-git-send-email-kotaranov@linux.microsoft.com> <7956dd4b-3002-4073-aff7-f85ea436e6e0@linux.dev> Content-Language: en-US X-Report-Abuse: Please report any abuse attempt to abuse@migadu.com and include these headers. From: Zhu Yanjun In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Migadu-Flow: FLOW_OUT On 18.03.24 10:31, Konstantin Taranov wrote: >>> From: Konstantin Taranov >>> >>> Intoduce helpers to work with mana ib queues (struct mana_ib_queue). >>> A queue always consists of umem, gdma_region, and id. >>> A queue can be used for a WQ or a CQ. >>> >>> Signed-off-by: Konstantin Taranov >>> --- >>> drivers/infiniband/hw/mana/main.c | 40 >> ++++++++++++++++++++++++++++ >>> drivers/infiniband/hw/mana/mana_ib.h | 10 +++++++ >>> 2 files changed, 50 insertions(+) >>> >>> diff --git a/drivers/infiniband/hw/mana/main.c >>> b/drivers/infiniband/hw/mana/main.c >>> index 71e33feee..0ec940b97 100644 >>> --- a/drivers/infiniband/hw/mana/main.c >>> +++ b/drivers/infiniband/hw/mana/main.c >>> @@ -237,6 +237,46 @@ void mana_ib_dealloc_ucontext(struct >> ib_ucontext *ibcontext) >>> ibdev_dbg(ibdev, "Failed to destroy doorbell page %d\n", ret); >>> } >>> >>> +int mana_ib_create_queue(struct mana_ib_dev *mdev, u64 addr, u32 size, >>> + struct mana_ib_queue *queue) { >>> + struct ib_umem *umem; >>> + int err; >>> + >>> + queue->umem = NULL; >>> + queue->id = INVALID_QUEUE_ID; >>> + queue->gdma_region = GDMA_INVALID_DMA_REGION; >>> + >>> + umem = ib_umem_get(&mdev->ib_dev, addr, size, >> IB_ACCESS_LOCAL_WRITE); >>> + if (IS_ERR(umem)) { >>> + err = PTR_ERR(umem); >>> + ibdev_dbg(&mdev->ib_dev, "Failed to get umem, %d\n", err); >>> + return err; >>> + } >>> + >>> + err = mana_ib_create_zero_offset_dma_region(mdev, umem, &queue- >>> gdma_region); >>> + if (err) { >>> + ibdev_dbg(&mdev->ib_dev, "Failed to create dma region, %d\n", >> err); >>> + goto free_umem; >>> + } >>> + queue->umem = umem; >>> + >>> + ibdev_dbg(&mdev->ib_dev, >>> + "create_dma_region ret %d gdma_region 0x%llx\n", >>> + err, queue->gdma_region); >>> + >>> + return 0; >>> +free_umem: >>> + ib_umem_release(umem); >>> + return err; >>> +} >>> + >>> +void mana_ib_destroy_queue(struct mana_ib_dev *mdev, struct >>> +mana_ib_queue *queue) { >>> + mana_ib_gd_destroy_dma_region(mdev, queue->gdma_region); >> The function mana_ib_gd_destroy_dma_region will call >> mana_gd_destroy_dma_region. In the function >> mana_gd_destroy_dma_region, the function mana_gd_send_request will >> return the error -EPROTO. >> The procedure is as below. So the function mana_ib_destroy_queue should >> also handle this error? > Thanks for the comment! > This error can be ignored and it was ignored before this commit. > I checked the corresponding Windows driver code, and it is also intentionally ignored there. > I can add a comment that the error is ignored intentionally if you want. Sure. Thanks a lot. Zhu Yanjun > >> mana_ib_gd_destroy_dma_region --- > mana_gd_destroy_dma_region >> >> 693 int mana_gd_destroy_dma_region(struct gdma_context *gc, u64 >> dma_region_handle) >> 694 { >> >> ... >> >> 706 err = mana_gd_send_request(gc, sizeof(req), &req, >> sizeof(resp), &resp); >> 707 if (err || resp.hdr.status) { >> 708 dev_err(gc->dev, "Failed to destroy DMA region: >> %d, 0x%x\n", >> 709 err, resp.hdr.status); >> 710 return -EPROTO; >> 711 } >> >> ... >> >> 714 } >> >> Zhu Yanjun >> >>> + ib_umem_release(queue->umem); >>> +} >>> + >>> static int >>> mana_ib_gd_first_dma_region(struct mana_ib_dev *dev, >>> struct gdma_context *gc, diff --git >>> a/drivers/infiniband/hw/mana/mana_ib.h >>> b/drivers/infiniband/hw/mana/mana_ib.h >>> index f83390eeb..859fd3bfc 100644 >>> --- a/drivers/infiniband/hw/mana/mana_ib.h >>> +++ b/drivers/infiniband/hw/mana/mana_ib.h >>> @@ -45,6 +45,12 @@ struct mana_ib_adapter_caps { >>> u32 max_inline_data_size; >>> }; >>> >>> +struct mana_ib_queue { >>> + struct ib_umem *umem; >>> + u64 gdma_region; >>> + u64 id; >>> +}; >>> + >>> struct mana_ib_dev { >>> struct ib_device ib_dev; >>> struct gdma_dev *gdma_dev; >>> @@ -169,6 +175,10 @@ int mana_ib_create_dma_region(struct >> mana_ib_dev *dev, struct ib_umem *umem, >>> int mana_ib_gd_destroy_dma_region(struct mana_ib_dev *dev, >>> mana_handle_t gdma_region); >>> >>> +int mana_ib_create_queue(struct mana_ib_dev *mdev, u64 addr, u32 size, >>> + struct mana_ib_queue *queue); void >>> +mana_ib_destroy_queue(struct mana_ib_dev *mdev, struct >> mana_ib_queue >>> +*queue); >>> + >>> struct ib_wq *mana_ib_create_wq(struct ib_pd *pd, >>> struct ib_wq_init_attr *init_attr, >>> struct ib_udata *udata);