Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp624963rwb; Tue, 4 Oct 2022 08:28:49 -0700 (PDT) X-Google-Smtp-Source: AMsMyM6G2RfMlaRC54Umzs2c+MjpCQmcORnt891XvSLa4soCrV0Qfhu8DhOXwh8OFYdBdi1Zx/LB X-Received: by 2002:a05:6a00:2402:b0:52c:81cf:8df8 with SMTP id z2-20020a056a00240200b0052c81cf8df8mr28459043pfh.60.1664897328878; Tue, 04 Oct 2022 08:28:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664897328; cv=none; d=google.com; s=arc-20160816; b=J3atRbwiPSf+W+XGRYsZDU/GaxZ2qja3TxjuOu1qInug9TR/xnsIWJthRmuzpAtHVk cQ9/kqjNW5KChGKnq3fe5j/LLZK0asHfhJGFEslUPvJMoyu1CJrqI940omgks8UX5akg HVbKyyPHA6tCTcYFTyxDgKZ5OVvyyhhR+oVSJD86PVKFivHvrNUrQvsFIUTR4rRC72Ta H4o+Wza+g2Y4SBMslG1UkLNx8EXOxin4q0Rot65HAwxC1Vn//t+c3jB+U8ihsUAsnMLR 5odRKV9jPn4LkBAmMTWJrc96YwcWonUqRC73s9YDmwAllwxkPXABnH++z3rbj+POkijk DOTA== 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; bh=M7dfKB8zPzRokkD8pCHnAVtW5gqryDGgX7Z0Rwaccdk=; b=Mj5pj9DFOH//Rt0g6DSWTis+GN5YjMQHwRm5KLsSrqapfXooKAeERpSRapj1zt+rcj 9l3kNnvipK7SXCzxYKXhN36jsUQ9Y1lsqSl8J5XF/6kVafIGcUmmYSj3vdfPNYCjUtUn NDZ7y8/8Z6WaSw2tpYFsNUmga7HdkFUFIsU2PZnIRkPvxdeM7/d7ydUE4pMWVEumFHoQ tsqtfIagy3v2v+g6acXX1skpxD3BPUme1WRSStvGU3dcpE7u0R17O4GHT03bCMVJHTEu Ou45uwgKvtReesoqrd2Odn8h7wHl79/0Z5AtUINaTMkD27NlyyzSpjpjrwbZnKK+hMH4 oOVw== 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=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nv11-20020a17090b1b4b00b00200919a55b1si3117201pjb.180.2022.10.04.08.28.35; Tue, 04 Oct 2022 08:28:48 -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=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229656AbiJDPCc (ORCPT + 99 others); Tue, 4 Oct 2022 11:02:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50030 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229507AbiJDPCa (ORCPT ); Tue, 4 Oct 2022 11:02:30 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B0D7D2E68D; Tue, 4 Oct 2022 08:02:27 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 99C081063; Tue, 4 Oct 2022 08:02:33 -0700 (PDT) Received: from [10.57.65.170] (unknown [10.57.65.170]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 895D73F792; Tue, 4 Oct 2022 08:02:24 -0700 (PDT) Message-ID: Date: Tue, 4 Oct 2022 16:02:18 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; rv:102.0) Gecko/20100101 Thunderbird/102.3.1 Subject: Re: [PATCH v4 5/5] iommu/s390: Fix incorrect pgsize_bitmap Content-Language: en-GB To: Niklas Schnelle , Matthew Rosato , 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, jgg@nvidia.com, linux-kernel@vger.kernel.org References: <20221004120706.2957492-1-schnelle@linux.ibm.com> <20221004120706.2957492-6-schnelle@linux.ibm.com> From: Robin Murphy In-Reply-To: <20221004120706.2957492-6-schnelle@linux.ibm.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-5.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_LOW,SPF_HELO_NONE,SPF_NONE 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-04 13:07, Niklas Schnelle wrote: > The .pgsize_bitmap property of struct iommu_ops is not a page mask but > rather has a bit set for each size of pages the IOMMU supports. As the > comment correctly pointed out at this moment the code only support 4K > pages so simply use SZ_4K here. Unless it's already been done somewhere else, you'll want to switch over to the {map,unmap}_pages() interfaces as well to avoid taking a hit on efficiency here. The "page mask" thing was an old hack to trick the core API into making fewer map/unmap calls where the driver could map arbitrary numbers of pages at once anyway. The multi-page interfaces now do that more honestly and generally better (since they work for non-power-of-two sizes as well). Robin. > Reviewed-by: Jason Gunthorpe > Signed-off-by: Niklas Schnelle > --- > drivers/iommu/s390-iommu.c | 9 +-------- > 1 file changed, 1 insertion(+), 8 deletions(-) > > diff --git a/drivers/iommu/s390-iommu.c b/drivers/iommu/s390-iommu.c > index 94c444b909bd..6bf23e7830a2 100644 > --- a/drivers/iommu/s390-iommu.c > +++ b/drivers/iommu/s390-iommu.c > @@ -12,13 +12,6 @@ > #include > #include > > -/* > - * Physically contiguous memory regions can be mapped with 4 KiB alignment, > - * we allow all page sizes that are an order of 4KiB (no special large page > - * support so far). > - */ > -#define S390_IOMMU_PGSIZES (~0xFFFUL) > - > static const struct iommu_ops s390_iommu_ops; > > struct s390_domain { > @@ -350,7 +343,7 @@ static const struct iommu_ops s390_iommu_ops = { > .probe_device = s390_iommu_probe_device, > .release_device = s390_iommu_release_device, > .device_group = generic_device_group, > - .pgsize_bitmap = S390_IOMMU_PGSIZES, > + .pgsize_bitmap = SZ_4K, > .get_resv_regions = s390_iommu_get_resv_regions, > .default_domain_ops = &(const struct iommu_domain_ops) { > .attach_dev = s390_iommu_attach_device,