Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3529301yba; Mon, 29 Apr 2019 04:09:30 -0700 (PDT) X-Google-Smtp-Source: APXvYqxxNygTm5irfDMEiyC382zdYxfV/1yFLJIs/Bja51hRRI9NguUqN6U0IYV/0T558clBzJl3 X-Received: by 2002:a63:e956:: with SMTP id q22mr39526919pgj.277.1556536170319; Mon, 29 Apr 2019 04:09:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556536170; cv=none; d=google.com; s=arc-20160816; b=ioCx478e9JcoaMYyYfGloV8cOgLkRxHPrBHosxXUn+0oSVNhhYoMy+C4CK2zoUFf5Q 7sEdDMCdGaMF0boNi0j6gmLHfxRtFe6r8l4Cw1eIvNxsAbIRW4uM+PBW7CWWWZx2tMOd EQ1Cz8twS8NcSSqCPnUKOPrGLYnpE7wGA9wVWjCFTEsFqQTFZ3h2XEAQxBdAW770U3tk f6tlsBhaR4R0tKFS4DL2PBrHupK5XCXV8UZyzVQb1DHUDxG2JjM7NASNNZ26SZ/gX+DA lzBVF/Un5MTxf3PXNRaxXzUjVzziSlq9CulWew/INb2UqeRzyyQxyUkBSOFHa0cnbnh+ 26qA== 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; bh=z850a+53/AGCtZzgIjcd2YULM+wCq5tkwvVZD4TJpTM=; b=qbnQilaEJSbUk/DHsMvTOMEj40LQ1XHO45jz7FN33DQarBMznat7repPncTKeXGdfI 2OTqnwjvFqNczOxGWxk7QiqMoFPYyXA8t9NYW2me/8X9kDSLv2x9STXHYoJrT6564oxI Ja6jEqMSEaMzNxCb0RjQzwEZzgz0mxualbefJXO0z/k4EUcWJ8kuJgqbt0ci06nk5l8l +U+HBLz90p+RrYKKUFu2UOLwZJBwS2x4NyvB6HcHqFo8/C1m2bIgkeL2BlAruBjXBJFU fcuP9rt/Y0FfBKJUrNubrw39kd/2/PbpsCmINg/UO6GxC0+pYMMI2Yb7xEme0e/rHBdO vQ6A== 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 l6si29793478pgq.213.2019.04.29.04.09.14; Mon, 29 Apr 2019 04:09:30 -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 S1727846AbfD2LG6 (ORCPT + 99 others); Mon, 29 Apr 2019 07:06:58 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:53646 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727710AbfD2LG5 (ORCPT ); Mon, 29 Apr 2019 07:06:57 -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 F026280D; Mon, 29 Apr 2019 04:06:56 -0700 (PDT) Received: from [10.1.196.75] (e110467-lin.cambridge.arm.com [10.1.196.75]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id AE03A3F5AF; Mon, 29 Apr 2019 04:06:53 -0700 (PDT) Subject: Re: [PATCH v3 02/10] swiotlb: Factor out slot allocation and free To: Lu Baolu , Christoph Hellwig Cc: David Woodhouse , Joerg Roedel , ashok.raj@intel.com, jacob.jun.pan@intel.com, alan.cox@intel.com, kevin.tian@intel.com, mika.westerberg@linux.intel.com, pengfei.xu@intel.com, Konrad Rzeszutek Wilk , Marek Szyprowski , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org References: <20190421011719.14909-1-baolu.lu@linux.intel.com> <20190421011719.14909-3-baolu.lu@linux.intel.com> <20190422164555.GA31181@lst.de> <0c6e5983-312b-0d6b-92f5-64861cd6804d@linux.intel.com> <20190423061232.GB12762@lst.de> <20190424144532.GA21480@lst.de> <20190426150433.GA19930@lst.de> <93b3d627-782d-cae0-2175-77a5a8b3fe6e@linux.intel.com> From: Robin Murphy Message-ID: <90182d27-5764-7676-8ca6-b2773a40cfe1@arm.com> Date: Mon, 29 Apr 2019 12:06:52 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <93b3d627-782d-cae0-2175-77a5a8b3fe6e@linux.intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29/04/2019 06:10, Lu Baolu wrote: > Hi Christoph, > > On 4/26/19 11:04 PM, Christoph Hellwig wrote: >> On Thu, Apr 25, 2019 at 10:07:19AM +0800, Lu Baolu wrote: >>> This is not VT-d specific. It's just how generic IOMMU works. >>> >>> Normally, IOMMU works in paging mode. So if a driver issues DMA with >>> IOVA  0xAAAA0123, IOMMU can remap it with a physical address 0xBBBB0123. >>> But we should never expect IOMMU to remap 0xAAAA0123 with physical >>> address of 0xBBBB0000. That's the reason why I said that IOMMU will not >>> work there. >> >> Well, with the iommu it doesn't happen.  With swiotlb it obviosuly >> can happen, so drivers are fine with it.  Why would that suddenly >> become an issue when swiotlb is called from the iommu code? >> > > I would say IOMMU is DMA remapping, not DMA engine. :-) I'm not sure I really follow the issue here - if we're copying the buffer to the bounce page(s) there's no conceptual difference from copying it to SWIOTLB slot(s), so there should be no need to worry about the original in-page offset. From the reply up-thread I guess you're trying to include an optimisation to only copy the head and tail of the buffer if it spans multiple pages, and directly map the ones in the middle, but AFAICS that's going to tie you to also using strict mode for TLB maintenance, which may not be a win overall depending on the balance between invalidation bandwidth vs. memcpy bandwidth. At least if we use standard SWIOTLB logic to always copy the whole thing, we should be able to release the bounce pages via the flush queue to allow 'safe' lazy unmaps. Either way I think it would be worth just implementing the straightforward version first, then coming back to consider optimisations later. Robin.