Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp5429257ybp; Mon, 14 Oct 2019 22:35:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqwJMRWJA0hEcLoqOxTYf36mOXVBbfXRQ1SK2WW2RnfHkFd/ddEmLOL05SVW2pxXPrK0l9vI X-Received: by 2002:a50:f198:: with SMTP id x24mr33371656edl.238.1571117703029; Mon, 14 Oct 2019 22:35:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571117703; cv=none; d=google.com; s=arc-20160816; b=W6VyGHzTLVBtU0xjd1uaYSXb4e9LroqhUzM6vaJUVOmD2BhqTX4n25BS763Wl/Ha6T hP4+0wW/1yHTM/ir072XHyDW5HhNfXlCHve6bGCdK+wiAusP9ba3lPX19cJLuvIZDXWh u49ILB6KxsQx7OIHwrN3ot+LxBUshhN/taajbeDK0u2vrI4q3a3z5PvtCZoR0Uap2EuR 4T96aojsfRUpeOUGywDauMYSxLKw8zUuXo4/7+1FxGmomaHT21Ek3LA8woPWfo4/0wPy /TiEIA0M76E7Gnhm1nTYC46qCUarF9D1xbacnGImFt7QP9lyip47HfCHPZVmViXnBurR dApA== 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:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id; bh=hzUn6Ta+uckTqdrLkpXE0sL3FToReTKkQMsJFC0k00Y=; b=BaTPoxEi3EUggTZr3XgPQ9oC1Lq8V1fnlvqAoseEnkY7wnAh/R080c3oy69H0ehzF5 3FrcIOjzbuYd/X4CKrOvJnKSrEs9KRwYfkYdsgXHVVmt85khlOFDsO1S8MyPjV4YiRGb xi0vAVLkqL0hmwuGGOZGiERFrrIaI7UjoRYqYCaeLIMYxbrHNxapJbGcyXS7MRuJwElM zL/6ftqnmiMpFSeff5lbhsBjpDYmZJmJuFiPNcNfK1sh4mYxAi/VKyJZQhUiJT+ekuFI UsqtyNs//LnpgvE8kRAZAI9R2T5m0GEgny3X5nwMEUH0vYfJICjrAIrDpyjgpht0RzbM m7iQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b44si14557157ede.451.2019.10.14.22.34.34; Mon, 14 Oct 2019 22:35:03 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727493AbfJOBvx (ORCPT + 99 others); Mon, 14 Oct 2019 21:51:53 -0400 Received: from Mailgw01.mediatek.com ([1.203.163.78]:30209 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726450AbfJOBvx (ORCPT ); Mon, 14 Oct 2019 21:51:53 -0400 X-UUID: f6970995dbc8493bb4365a0938f2f170-20191015 X-UUID: f6970995dbc8493bb4365a0938f2f170-20191015 Received: from mtkcas36.mediatek.inc [(172.27.4.253)] by mailgw01.mediatek.com (envelope-from ) (mailgw01.mediatek.com ESMTP with TLS) with ESMTP id 468638640; Tue, 15 Oct 2019 09:51:38 +0800 Received: from MTKCAS32.mediatek.inc (172.27.4.184) by MTKMBS32N2.mediatek.inc (172.27.4.72) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Tue, 15 Oct 2019 09:51:36 +0800 Received: from [10.17.3.153] (172.27.4.253) by MTKCAS32.mediatek.inc (172.27.4.170) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Tue, 15 Oct 2019 09:51:35 +0800 Message-ID: <1571104296.19130.67.camel@mhfsdcap03> Subject: Re: [PATCH v2 3/4] iommu/mediatek: Use writel for TLB range invalidation From: Yong Wu To: Will Deacon CC: Matthias Brugger , Joerg Roedel , Will Deacon , Evan Green , Robin Murphy , Tomasz Figa , , , , , , , Nicolas Boichat , , , Date: Tue, 15 Oct 2019 09:51:36 +0800 In-Reply-To: <20191014211113.jq5qwe5pfonyocr3@willie-the-truck> References: <1570627143-29441-1-git-send-email-yong.wu@mediatek.com> <1570627143-29441-3-git-send-email-yong.wu@mediatek.com> <20191011162950.yg4o77mlaicacne5@willie-the-truck> <1570861427.19130.65.camel@mhfsdcap03> <20191014211113.jq5qwe5pfonyocr3@willie-the-truck> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.10.4-0ubuntu2 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-TM-SNTS-SMTP: 2A0569C4EE061B0093306730CED8C43106D58A6D2203E5BAA9BAE2B73DFF6B432000:8 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2019-10-14 at 22:11 +0100, Will Deacon wrote: > On Sat, Oct 12, 2019 at 02:23:47PM +0800, Yong Wu wrote: > > On Fri, 2019-10-11 at 17:29 +0100, Will Deacon wrote: > > > On Wed, Oct 09, 2019 at 09:19:02PM +0800, Yong Wu wrote: > > > > Use writel for the register F_MMU_INV_RANGE which is for triggering the > > > > HW work. We expect all the setting(iova_start/iova_end...) have already > > > > been finished before F_MMU_INV_RANGE. > > > > > > > > Signed-off-by: Anan.Sun > > > > Signed-off-by: Yong Wu > > > > --- > > > > This is a improvement rather than fixing a issue. > > > > --- > > > > drivers/iommu/mtk_iommu.c | 3 +-- > > > > 1 file changed, 1 insertion(+), 2 deletions(-) > > > > > > > > diff --git a/drivers/iommu/mtk_iommu.c b/drivers/iommu/mtk_iommu.c > > > > index 24a13a6..607f92c 100644 > > > > --- a/drivers/iommu/mtk_iommu.c > > > > +++ b/drivers/iommu/mtk_iommu.c > > > > @@ -187,8 +187,7 @@ static void mtk_iommu_tlb_add_flush(unsigned long iova, size_t size, > > > > writel_relaxed(iova, data->base + REG_MMU_INVLD_START_A); > > > > writel_relaxed(iova + size - 1, > > > > data->base + REG_MMU_INVLD_END_A); > > > > - writel_relaxed(F_MMU_INV_RANGE, > > > > - data->base + REG_MMU_INVALIDATE); > > > > + writel(F_MMU_INV_RANGE, data->base + REG_MMU_INVALIDATE); > > > > > > I don't understand this change. > > > > > > Why is it an "improvement" and which accesses are you ordering with the > > > writel? > > > > The register(F_MMU_INV_RANGE) will trigger HW to begin flush range. HW > > expect the other register iova_start/end/flush_type always is ready > > before trigger. thus I'd like use writel to guarantee the previous > > register has been finished. > > Given that these are all MMIO writes to the same device, then > writel_relaxed() should give you the ordering you need. If you look at > memory_barriers.txt, it says: > > | they [readX_relaxed() and writeX_relaxed()] are still guaranteed to > | be ordered with respect to other accesses from the same CPU thread > | to the same peripheral when operating on __iomem pointers mapped > | with the default I/O attributes. Thanks for this info. See it now. then I will delete this patch in next version. > > > I didn't see the writel_relaxed cause some error in practice, we only > > think writel is necessary here in theory. so call it "improvement". > > Ok, but I don't think it's needed in this case. > > Will