Received: by 2002:a4a:311b:0:0:0:0:0 with SMTP id k27-v6csp4226682ooa; Tue, 14 Aug 2018 03:04:33 -0700 (PDT) X-Google-Smtp-Source: AA+uWPz0SUGilbMPJBbraSAZnExWiKuCa9J5JMBzELCvlGAugKhNYur/OpFSsBs6S/drdjN4CHnx X-Received: by 2002:a65:5545:: with SMTP id t5-v6mr20552373pgr.157.1534241073206; Tue, 14 Aug 2018 03:04:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534241073; cv=none; d=google.com; s=arc-20160816; b=gnxowJl2M6FTPiqJ6BfX7sx6q3DivUp53JLbEaqc/Kujkuxp/i3R1/G5E2K9FQJ1fw UaTkxtp091HQR9v8Vvu/iVbhPnYTo6IanFEmRDr9nya94E8/XcE9kWKVbOyBXafJNiHy GTtujRvTiU0XeIyUgBH3ZAprhRLZGzT+X9pot/Holm0dudVtzp01IDToJj2wOARKrMto HdDh8OTkJpzs4u4T+xNPytC6DiQj5/vfT3a0VxZav+vdgKnRnDWL1KFrCTGi/pX+qabs BMST6PuMc4ruUH8LqM74Z/FHorxc+gHIb5vyELvmq7wDsNcu0eome6sFkBlBRgKEe4cZ BEdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=IJ8hoFKjy2JQoDmv3C23E4s202aVX+7ureVwllZohJQ=; b=zw0sM2t1URs9XozzHFmZ1d0u9kaUXBCfa3jzzPyM9qBqlk5yjGO6IHKCGLwgWLyJ9s M/9iR4pA5a0y5sktwL7Tg+29TNXv0QS0hQJiWN+DWcnCQLyb5B/DBFXUtirdleQ2MJMA RJTCv8/CYy+pPuAe4DXStoNeRxt8Jzests1bcUsUA3oV8ICcCSg6pqo/3CMA9ROHT2tj 6UDx127H9gb3C/hYSafG8gIFf7FUnG/CwXSLDXFXNIz3NNrkGj5K2458lBNyPV39fuEC rYz8J9C/HOWZKIHQWeLREMAnbHELfQVR+hxn2gU3LQKFK06O2iDI6an3jlzro6H9X0g+ 1uDQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r189-v6si19851808pgr.634.2018.08.14.03.04.18; Tue, 14 Aug 2018 03:04:33 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731835AbeHNMtX (ORCPT + 99 others); Tue, 14 Aug 2018 08:49:23 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:40822 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728483AbeHNMtX (ORCPT ); Tue, 14 Aug 2018 08:49:23 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 98B9080D; Tue, 14 Aug 2018 03:02:55 -0700 (PDT) Received: from [10.4.12.131] (e110467-lin.emea.arm.com [10.4.12.131]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 3F9443F5D0; Tue, 14 Aug 2018 03:02:54 -0700 (PDT) Subject: Re: [PATCH v3 4/6] iommu/io-pgtable-arm: add support for non-strict mode To: Will Deacon , "Leizhen (ThunderTown)" Cc: "Yang, Shunyong" , Jean-Philippe Brucker , Joerg Roedel , linux-arm-kernel , iommu , linux-kernel References: <1531376312-2192-1-git-send-email-thunder.leizhen@huawei.com> <1531376312-2192-5-git-send-email-thunder.leizhen@huawei.com> <89cc2201-99ab-3f3b-a2d1-1766515d4375@arm.com> <5B597628.2020103@huawei.com> <04239cfa-bcf2-a33a-e662-ebc75e66782b@arm.com> <1d24541340334954969c58980ef85444@HXTBJIDCEMVIW01.hxtcorp.net> <5B7293E5.7040702@huawei.com> <20180814083500.GA28101@arm.com> From: Robin Murphy Message-ID: Date: Tue, 14 Aug 2018 11:02:52 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180814083500.GA28101@arm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 14/08/18 09:35, Will Deacon wrote: > On Tue, Aug 14, 2018 at 04:33:41PM +0800, Leizhen (ThunderTown) wrote: >> On 2018/8/6 9:32, Yang, Shunyong wrote: >>> On 2018/7/26 22:37, Robin Murphy wrote: >>>> Because DMA code is not the only caller of iommu_map/unmap. It's >>>> perfectly legal in the IOMMU API to partially unmap a previous mapping >>>> such that a block entry needs to be split. The DMA API, however, is a >>>> lot more constrined, and thus by construction the iommu-dma layer will >>>> never generate a block-splitting iommu_unmap() except as a result of >>>> illegal DMA API usage, and we obviously do not need to optimise for that >>>> (you will get a warning about mismatched unmaps under dma-debug, but >>>> it's a bit too expensive to police in the general case). >>>> >>> >>> When I was reading the code around arm_lpae_split_blk_unmap(), I was >>> curious in which scenario a block will be split. Now with your comments >>> "Because DMA code is not the only caller of iommu_map/unmap", it seems >>> depending on the user. >>> >>> Would you please explain this further? I mean besides DMA, which user >>> will use iommu_map/umap and how it split a block. >> >> I also think that arm_lpae_split_blk_unmap() scenario is not exist, maybe >> we should remove it, and give a warning for this wrong usage. > > Can't it happen with VFIO? ...or GPU drivers, or anyone else managing their own IOMMU domain directly. A sequence like this is perfectly legal: iommu_map(domain, iova, paddr, SZ_8M, prot); ... iommu_unmap(domain, iova + SZ_1M * 5, SZ_1M * 3); where if iova and paddr happen to be suitably aligned, the map will lay down blocks, and the unmap will then have to split one of them into pages to remove half of it. We don't tear our hair out maintaining split_blk_unmap() for the fun of it :( Robin.