Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp374575pxb; Thu, 7 Apr 2022 07:54:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwlOvbhYB95CX1pWJG5fClKCWq2SUMZacogMbgILuOOrVdRune0+m33PzTUpVIWqK3ATgTN X-Received: by 2002:a17:906:6a1d:b0:6e8:4127:6bc3 with SMTP id qw29-20020a1709066a1d00b006e841276bc3mr1522217ejc.633.1649343272559; Thu, 07 Apr 2022 07:54:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649343272; cv=none; d=google.com; s=arc-20160816; b=aHOBIA9RuAh3ATPP5d6K1GgWFp2FPlRgDI6T6SC5/6qaeG9Hu1VIL3ZyiMZIfwaC+d NpEr5u1Cks+w2E5H6wfkQz/yEZ4XvMxkrJ89utd86riWPtZYr9w5YjMUnfTb8GSAnlc3 SP4r/C+AY3U0uEhFCzDUGq658XtplhxVBAwdobrrP2W4mSSTt3OMAeWVrGmJjCQWtRTl 2F+aLh+ERDYbousCsnFkzLdDpyXcSnuYuGAswicn2tceLBUkQdnm2l9+B+dCXqj0wH0L 8DDEANjnLkrbuAywdOdsVblQVyLXBpRb7uhaJuT0pxhlkwHmiyvb1P9dp9UN++ll16iZ 0aQA== 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=2u1mkRQaAZqlt2PDPmBuw99rrsxRKZUuzHRDmUofJdM=; b=uIYHYOSbwXrePnkuK1G1W75+/na8IISvhQ6pod+pcfbY6HwzfseaypIG8kYKfs63F+ h3ntygMCfZZCLZDW7zjUCPKCYlVUdh/dhE4axTh/MWOJHQaB7SqBZK8hPk3lmHbz6cXN Gm4ex5H1MA52psWcaX/O6KPZEJ0YxgqGQqFAVVrIQ8hYh81oYc8puhfMSDW34t8xSkP4 w53Efc5s2UpTrdjvIdx6vPVTsl+OhzNxjV/lA33lUJeWnZUian6TrZZX+Uzm6khYsV6e JfCtXs4yVKwHJFmkAxU3B2YoThsyQ4ER3XB59W6TteT8SzXrXxaPgBxgXJLms4alv8u/ unKQ== 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 j6-20020a509d46000000b00418efc97cf9si14210794edk.7.2022.04.07.07.54.06; Thu, 07 Apr 2022 07:54:32 -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 S229907AbiDGI3Y (ORCPT + 99 others); Thu, 7 Apr 2022 04:29:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47442 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231202AbiDGI3V (ORCPT ); Thu, 7 Apr 2022 04:29:21 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2BEF87CB16 for ; Thu, 7 Apr 2022 01:27:21 -0700 (PDT) Received: from dggpemm500020.china.huawei.com (unknown [172.30.72.55]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4KYvZM5L19zFpYl; Thu, 7 Apr 2022 16:24:59 +0800 (CST) Received: from dggpemm500006.china.huawei.com (7.185.36.236) by dggpemm500020.china.huawei.com (7.185.36.49) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.21; Thu, 7 Apr 2022 16:27:19 +0800 Received: from [10.174.178.55] (10.174.178.55) by dggpemm500006.china.huawei.com (7.185.36.236) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.21; Thu, 7 Apr 2022 16:27:18 +0800 Subject: Re: [PATCH RESEND v5 5/5] iova: Add iova_len argument to iova_domain_init_rcaches() To: John Garry , , , CC: , , , , , , , References: <1649071634-188535-1-git-send-email-john.garry@huawei.com> <1649071634-188535-6-git-send-email-john.garry@huawei.com> From: "Leizhen (ThunderTown)" Message-ID: Date: Thu, 7 Apr 2022 16:27:18 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: <1649071634-188535-6-git-send-email-john.garry@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.178.55] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To dggpemm500006.china.huawei.com (7.185.36.236) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE 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/4/4 19:27, John Garry wrote: > Add max opt argument to iova_domain_init_rcaches(), and use it to set the > rcaches range. > > Also fix up all users to set this value (at 0, meaning use default), > including a wrapper for that, iova_domain_init_rcaches_default(). > > For dma-iommu.c we derive the iova_len argument from the IOMMU group > max opt DMA size. > > Signed-off-by: John Garry > --- > drivers/iommu/dma-iommu.c | 15 ++++++++++++++- > drivers/iommu/iova.c | 19 ++++++++++++++++--- > drivers/vdpa/vdpa_user/iova_domain.c | 4 ++-- > include/linux/iova.h | 3 ++- > 4 files changed, 34 insertions(+), 7 deletions(-) > > diff --git a/drivers/iommu/dma-iommu.c b/drivers/iommu/dma-iommu.c > index 42ca42ff1b5d..19f35624611c 100644 > --- a/drivers/iommu/dma-iommu.c > +++ b/drivers/iommu/dma-iommu.c > @@ -525,6 +525,8 @@ static int iommu_dma_init_domain(struct iommu_domain *domain, dma_addr_t base, > struct iommu_dma_cookie *cookie = domain->iova_cookie; > unsigned long order, base_pfn; > struct iova_domain *iovad; > + size_t max_opt_dma_size; > + unsigned long iova_len = 0; > int ret; > > if (!cookie || cookie->type != IOMMU_DMA_IOVA_COOKIE) > @@ -560,7 +562,18 @@ static int iommu_dma_init_domain(struct iommu_domain *domain, dma_addr_t base, > } > > init_iova_domain(iovad, 1UL << order, base_pfn); > - ret = iova_domain_init_rcaches(iovad); > + > + max_opt_dma_size = iommu_group_get_max_opt_dma_size(dev->iommu_group); > + if (max_opt_dma_size) { > + unsigned long shift = __ffs(1UL << order); > + > + iova_len = roundup_pow_of_two(max_opt_dma_size); > + iova_len >>= shift; > + if (!iova_len) > + iova_len = 1; How about move "iovad->rcache_max_size = iova_len_to_rcache_max(iova_len);" here? So that, iova_domain_init_rcaches() can remain the same. And iova_domain_init_rcaches_default() does not need to be added. > + } > + > + ret = iova_domain_init_rcaches(iovad, iova_len); > if (ret) > return ret; > > diff --git a/drivers/iommu/iova.c b/drivers/iommu/iova.c > index 5c22b9187b79..d65e79e132ee 100644 > --- a/drivers/iommu/iova.c > +++ b/drivers/iommu/iova.c > @@ -706,12 +706,20 @@ static void iova_magazine_push(struct iova_magazine *mag, unsigned long pfn) > mag->pfns[mag->size++] = pfn; > } > > -int iova_domain_init_rcaches(struct iova_domain *iovad) > +static unsigned long iova_len_to_rcache_max(unsigned long iova_len) > +{ > + return order_base_2(iova_len) + 1; > +} > + > +int iova_domain_init_rcaches(struct iova_domain *iovad, unsigned long iova_len) > { > unsigned int cpu; > int i, ret; > > - iovad->rcache_max_size = 6; /* Arbitrarily high default */ > + if (iova_len) > + iovad->rcache_max_size = iova_len_to_rcache_max(iova_len); > + else > + iovad->rcache_max_size = 6; /* Arbitrarily high default */ > > iovad->rcaches = kcalloc(iovad->rcache_max_size, > sizeof(struct iova_rcache), > @@ -755,7 +763,12 @@ int iova_domain_init_rcaches(struct iova_domain *iovad) > free_iova_rcaches(iovad); > return ret; > } > -EXPORT_SYMBOL_GPL(iova_domain_init_rcaches); > + > +int iova_domain_init_rcaches_default(struct iova_domain *iovad) > +{ > + return iova_domain_init_rcaches(iovad, 0); > +} > +EXPORT_SYMBOL_GPL(iova_domain_init_rcaches_default); > > /* > * Try inserting IOVA range starting with 'iova_pfn' into 'rcache', and > diff --git a/drivers/vdpa/vdpa_user/iova_domain.c b/drivers/vdpa/vdpa_user/iova_domain.c > index 6daa3978d290..3a2acef98a4a 100644 > --- a/drivers/vdpa/vdpa_user/iova_domain.c > +++ b/drivers/vdpa/vdpa_user/iova_domain.c > @@ -514,12 +514,12 @@ vduse_domain_create(unsigned long iova_limit, size_t bounce_size) > spin_lock_init(&domain->iotlb_lock); > init_iova_domain(&domain->stream_iovad, > PAGE_SIZE, IOVA_START_PFN); > - ret = iova_domain_init_rcaches(&domain->stream_iovad); > + ret = iova_domain_init_rcaches_default(&domain->stream_iovad); > if (ret) > goto err_iovad_stream; > init_iova_domain(&domain->consistent_iovad, > PAGE_SIZE, bounce_pfns); > - ret = iova_domain_init_rcaches(&domain->consistent_iovad); > + ret = iova_domain_init_rcaches_default(&domain->consistent_iovad); > if (ret) > goto err_iovad_consistent; > > diff --git a/include/linux/iova.h b/include/linux/iova.h > index 02f7222fa85a..56281434ce0c 100644 > --- a/include/linux/iova.h > +++ b/include/linux/iova.h > @@ -95,7 +95,8 @@ struct iova *reserve_iova(struct iova_domain *iovad, unsigned long pfn_lo, > unsigned long pfn_hi); > void init_iova_domain(struct iova_domain *iovad, unsigned long granule, > unsigned long start_pfn); > -int iova_domain_init_rcaches(struct iova_domain *iovad); > +int iova_domain_init_rcaches(struct iova_domain *iovad, unsigned long iova_len); > +int iova_domain_init_rcaches_default(struct iova_domain *iovad); > struct iova *find_iova(struct iova_domain *iovad, unsigned long pfn); > void put_iova_domain(struct iova_domain *iovad); > #else > -- Regards, Zhen Lei