Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp79257rwb; Thu, 6 Oct 2022 14:52:33 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4RNPdK5iZT7IywgJa7yWLphAX+8mcM8/5yba3i8PFp2fpOfgKyT849erJCc1jJGWaeb1HT X-Received: by 2002:a17:907:6d91:b0:78d:36d8:b799 with SMTP id sb17-20020a1709076d9100b0078d36d8b799mr1489044ejc.573.1665093152731; Thu, 06 Oct 2022 14:52:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1665093152; cv=none; d=google.com; s=arc-20160816; b=biizUuImi/JiKbCh+j8MNfr6BWTjapyuZavNoVQh0sSgI2OHLnZEDkaBfv/IxRdQ00 b/lxRPKD3HNshc9tdenaTTQbo0oOJzC4zzb2wzW6hjEdd8zom7kw1rbDDETsncD+FtTc k/yBYHUd95G5Gwno+/3Ymr6w+wpE4T9JYGzfzZSEQnfAAsjKx7u8dYCi4Wwzb3nCaBhi WnPVCCrG2v+55140xZwoj8f+fb3X6qjttDLfe8r98SCkkY2qaqE62CHe/WXjIMAUak6V fux9WynpcNmWvHzNmw35nfgEZ8gAjvQShRWMGHpZlyumLg42U63oxZJp2CTwgSx1yUso NG5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=10OWtucJr95xAXqq/kQhrTeDW/DzA+7mwoCnOhBtP5c=; b=ybYCsveS/yfoC8bkFY8qW8JSTGguYcJnKg2K9CShUc7AAOi5APR107KVTqSREsMjMe 1ybv7+O+s4JvctlIg2aswUBgjDEHxWYVQPRjHwMvgPRu0bZPi0kEBv1QkAwNt7j/k7rz i64GrY6XPCXadxr7ri4EeqngXuAVye9ZmA/uIpA4w098igigkamvk1XXsktPHkIkK6F7 UhwkVVKcAYjhihFCoiA3pO4tAcSl1hZZjPC2zl0fLsoQ7a/+I292yOx2iD1eunfRYNvK S45SzU+Z2gIkE7F111kzUnF4mbYHSI1S2GQBwZkzWWLLQ7Y1j1zeJgvRwg9r9wZKXUPn P7ow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=qCd9tC6T; 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=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v5-20020a056402348500b00459b6b52c33si440008edc.559.2022.10.06.14.52.06; Thu, 06 Oct 2022 14:52: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; dkim=pass header.i=@ibm.com header.s=pp1 header.b=qCd9tC6T; 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=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231997AbiJFVDZ (ORCPT + 99 others); Thu, 6 Oct 2022 17:03:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49924 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231416AbiJFVDX (ORCPT ); Thu, 6 Oct 2022 17:03:23 -0400 Received: from mx0a-001b2d01.pphosted.com (mx0a-001b2d01.pphosted.com [148.163.156.1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1145DC2CA3; Thu, 6 Oct 2022 14:03:20 -0700 (PDT) Received: from pps.filterd (m0187473.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 296JfcmE011093; Thu, 6 Oct 2022 21:03:09 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=message-id : date : mime-version : subject : to : cc : references : from : in-reply-to : content-type : content-transfer-encoding; s=pp1; bh=10OWtucJr95xAXqq/kQhrTeDW/DzA+7mwoCnOhBtP5c=; b=qCd9tC6TYk7WwnPn89SRMou2z+VqGstEKH2iCBMxAS+ItDHZ4sm3FKi2LN6ekuXpdFLQ C8d56qQn2dCSVvm33wvhtcLKDMGIRpKGPyAObfW89TJISBM1IJMgC7SxpxXozjy8b+Le 24p86Uei1XFqyX/Lyaw2MkpFSXM2HYhkp+3ckCXHcoHjoJ0iRZINrnqoJJ1X9wtuCgya AOGM+8gVrYwVIk51RyDyp01ANswXtmmpPetn04yoRAomY6+fRnHSpdE+HAiccf53iE10 CXnskntlQuCcb45aj10IUzZaUebSlEVTi3T3mqCWPGs7TxE2MSl1FUoTAW1Mcb9ZTR2i EA== Received: from ppma03wdc.us.ibm.com (ba.79.3fa9.ip4.static.sl-reverse.com [169.63.121.186]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 3k25daab1g-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 06 Oct 2022 21:03:09 +0000 Received: from pps.filterd (ppma03wdc.us.ibm.com [127.0.0.1]) by ppma03wdc.us.ibm.com (8.16.1.2/8.16.1.2) with SMTP id 296KpObN017132; Thu, 6 Oct 2022 21:03:08 GMT Received: from b01cxnp23032.gho.pok.ibm.com (b01cxnp23032.gho.pok.ibm.com [9.57.198.27]) by ppma03wdc.us.ibm.com with ESMTP id 3jxd69vuxr-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 06 Oct 2022 21:03:08 +0000 Received: from smtpav01.wdc07v.mail.ibm.com ([9.208.128.113]) by b01cxnp23032.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 296L36Mj64618880 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 6 Oct 2022 21:03:07 GMT Received: from smtpav01.wdc07v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 76CC558065; Thu, 6 Oct 2022 21:03:06 +0000 (GMT) Received: from smtpav01.wdc07v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id B02795804B; Thu, 6 Oct 2022 21:03:04 +0000 (GMT) Received: from [9.65.202.26] (unknown [9.65.202.26]) by smtpav01.wdc07v.mail.ibm.com (Postfix) with ESMTP; Thu, 6 Oct 2022 21:03:04 +0000 (GMT) Message-ID: <33573393-3b75-5c71-6f62-8b207f46fd16@linux.ibm.com> Date: Thu, 6 Oct 2022 17:03:04 -0400 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.3.0 Subject: Re: [PATCH v5 6/6] iommu/s390: Implement map_pages()/unmap_pages() instead of map()/unmap() Content-Language: en-US To: Niklas Schnelle , Pierre Morel , iommu@lists.linux.dev Cc: linux-s390@vger.kernel.org, borntraeger@linux.ibm.com, hca@linux.ibm.com, gor@linux.ibm.com, gerald.schaefer@linux.ibm.com, agordeev@linux.ibm.com, svens@linux.ibm.com, joro@8bytes.org, will@kernel.org, robin.murphy@arm.com, jgg@nvidia.com, linux-kernel@vger.kernel.org References: <20221006144700.3380098-1-schnelle@linux.ibm.com> <20221006144700.3380098-7-schnelle@linux.ibm.com> From: Matthew Rosato In-Reply-To: <20221006144700.3380098-7-schnelle@linux.ibm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-TM-AS-GCONF: 00 X-Proofpoint-GUID: dfVBkdg1zQo_lSG0eKwLKDW4UvHuoC-D X-Proofpoint-ORIG-GUID: dfVBkdg1zQo_lSG0eKwLKDW4UvHuoC-D X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.895,Hydra:6.0.528,FMLib:17.11.122.1 definitions=2022-10-06_04,2022-10-06_02,2022-06-22_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 suspectscore=0 bulkscore=0 adultscore=0 mlxlogscore=999 spamscore=0 mlxscore=0 phishscore=0 lowpriorityscore=0 priorityscore=1501 malwarescore=0 impostorscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2209130000 definitions=main-2210060124 X-Spam-Status: No, score=-3.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_MSPIKE_H2,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 10/6/22 10:47 AM, Niklas Schnelle wrote: > While s390-iommu currently implements the map_page()/unmap_page() > operations which only map/unmap a single page at a time the internal > s390_iommu_update_trans() API already supports mapping/unmapping a range > of pages at once. Take advantage of this by implementing the > map_pages()/unmap_pages() operations instead thus allowing users of the > IOMMU drivers to map multiple pages in a single call followed by > a single I/O TLB flush if needed. > > Signed-off-by: Niklas Schnelle > --- > drivers/iommu/s390-iommu.c | 48 +++++++++++++++++++++++++------------- > 1 file changed, 32 insertions(+), 16 deletions(-) > > diff --git a/drivers/iommu/s390-iommu.c b/drivers/iommu/s390-iommu.c > index ac200f0b81fa..7b92855135ac 100644 > --- a/drivers/iommu/s390-iommu.c > +++ b/drivers/iommu/s390-iommu.c > @@ -189,20 +189,15 @@ static void s390_iommu_release_device(struct device *dev) > > static int s390_iommu_update_trans(struct s390_domain *s390_domain, > phys_addr_t pa, dma_addr_t dma_addr, > - size_t size, int flags) > + unsigned long nr_pages, int flags) > { > phys_addr_t page_addr = pa & PAGE_MASK; > dma_addr_t start_dma_addr = dma_addr; > - unsigned long irq_flags, nr_pages, i; > + unsigned long irq_flags, i; > struct zpci_dev *zdev; > unsigned long *entry; > int rc = 0; > > - if (dma_addr < s390_domain->domain.geometry.aperture_start || > - (dma_addr + size - 1) > s390_domain->domain.geometry.aperture_end) > - return -EINVAL; > - > - nr_pages = PAGE_ALIGN(size) >> PAGE_SHIFT; > if (!nr_pages) > return 0; > > @@ -245,11 +240,24 @@ static int s390_iommu_update_trans(struct s390_domain *s390_domain, > return rc; > } > > -static int s390_iommu_map(struct iommu_domain *domain, unsigned long iova, > - phys_addr_t paddr, size_t size, int prot, gfp_t gfp) > +static int s390_iommu_map_pages(struct iommu_domain *domain, > + unsigned long iova, phys_addr_t paddr, > + size_t pgsize, size_t pgcount, > + int prot, gfp_t gfp, size_t *mapped) > { > struct s390_domain *s390_domain = to_s390_domain(domain); > int flags = ZPCI_PTE_VALID, rc = 0; > + size_t size = pgcount << __ffs(pgsize); > + > + if (pgsize != SZ_4K) > + return -EINVAL; > + > + if (iova < s390_domain->domain.geometry.aperture_start || > + (iova + size - 1) > s390_domain->domain.geometry.aperture_end) > + return -EINVAL; > + > + if (!IS_ALIGNED(iova | paddr, pgsize)) > + return -EINVAL; > > if (!(prot & IOMMU_READ)) > return -EINVAL; > @@ -258,7 +266,9 @@ static int s390_iommu_map(struct iommu_domain *domain, unsigned long iova, > flags |= ZPCI_TABLE_PROTECTED; > > rc = s390_iommu_update_trans(s390_domain, paddr, iova, > - size, flags); > + pgcount, flags); > + if (!rc) > + *mapped = size; > > return rc; > } > @@ -294,21 +304,27 @@ static phys_addr_t s390_iommu_iova_to_phys(struct iommu_domain *domain, > return phys; > } > > -static size_t s390_iommu_unmap(struct iommu_domain *domain, > - unsigned long iova, size_t size, > - struct iommu_iotlb_gather *gather) > +static size_t s390_iommu_unmap_pages(struct iommu_domain *domain, > + unsigned long iova, > + size_t pgsize, size_t pgcount, > + struct iommu_iotlb_gather *gather) > { > struct s390_domain *s390_domain = to_s390_domain(domain); > + size_t size = pgcount << __ffs(pgsize); > int flags = ZPCI_PTE_INVALID; > phys_addr_t paddr; > int rc; > > + if (iova < s390_domain->domain.geometry.aperture_start || > + (iova + size - 1) > s390_domain->domain.geometry.aperture_end) > + return 0; > + Overall this LGTM and runs well with my testing. But I'm curious why we silently ignore an egregiously bad unmap request here? We've already done an -EINVAL for an attempt to map_pages() something outside of the aperture. If something still tries to unmap_pages() outside of the aperture, that seems like a bug? Maybe this should be surrounded by a if (WARN_ON(... || ...) to signify the unexpected behavior and then still return 0? Otherwise: Reviewed-by: Matthew Rosato > paddr = s390_iommu_iova_to_phys(domain, iova); > if (!paddr) > return 0; > > rc = s390_iommu_update_trans(s390_domain, paddr, iova, > - size, flags); > + pgcount, flags); > if (rc) > return 0; > > @@ -354,8 +370,8 @@ static const struct iommu_ops s390_iommu_ops = { > .default_domain_ops = &(const struct iommu_domain_ops) { > .attach_dev = s390_iommu_attach_device, > .detach_dev = s390_iommu_detach_device, > - .map = s390_iommu_map, > - .unmap = s390_iommu_unmap, > + .map_pages = s390_iommu_map_pages, > + .unmap_pages = s390_iommu_unmap_pages, > .iova_to_phys = s390_iommu_iova_to_phys, > .free = s390_domain_free, > }