Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp1876898ybp; Fri, 11 Oct 2019 23:28:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqxAQ6avmnWOirL0abo9rua0i7KjHFLTliT4Vy+XtUhSOnjZyq+IV24E0tbspWrHXBSV4NXO X-Received: by 2002:a17:906:7e0c:: with SMTP id e12mr17715887ejr.20.1570861698437; Fri, 11 Oct 2019 23:28:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570861698; cv=none; d=google.com; s=arc-20160816; b=bgHelonH9IKb8bsmGPX9p8LgisGMPMTpTDeIclfC+HgLAm9gv1CYO5vFtt6a9qKcQM c1uAfCQ2+lkvBwhWKE0CNFK4shP6krSUadgE1H6sTXpVO3GqJrG3NaSM8uRPsnBD0fol HAAEMjwzMCzBQEX0QqGYYRYLB1kX2XCbNAV+fH3DkGmxq6DkiwJ6SozBqLfsNEb+EG+D s6Qv0/b5gOmFA5J3R5zq0IDuz8hw8r7cF/6MOiFCtyA7tfbiFl39AqLqVv+lzoOsQtCj pIQtmLUs7msI+qDCLRnw5sh94152hlK0k8DGt4BRaH2Bl7XvbPNfnGQRNowhSftCciC6 DJdQ== 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=dIApquPdSA1ewbZ8puRgYPRam/uHO6C3Fq/6gqbhgvs=; b=fdD5z8mVtx791G82foLMqhDDdrpJUkjF4VJsWW/tXZXd9xfk+fcVMFep2ff/RCtKcX WkF26XtgQeJ2n+P6aLqYqo6R+nDeHeX9hqvkMoo+o+DXOr2FU+HePpq4dfDqvFCrw3Pr SACGYuCMGNnjNMhQvSc5aHA3Ccft+SgOVJKRF24aPCG/rvZVM6mRbzvwqUW/hnnfeRKL Kc0Pl4rdharXYvd0sHemk3NtRFDA9eiZEA25+Lc0loydiCO5BBR3RdlI8eLX1DvPMdFK 900mnW2mhru/k5HbHMhzux1ECXmJYQE0WLxbLg7mvmzq/Lnzg1knMeJg/YttRm1QECuS i6SA== 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 e5si6866140ejj.70.2019.10.11.23.27.53; Fri, 11 Oct 2019 23:28:18 -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 S1728171AbfJLGX6 (ORCPT + 99 others); Sat, 12 Oct 2019 02:23:58 -0400 Received: from Mailgw01.mediatek.com ([1.203.163.78]:42583 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726821AbfJLGX6 (ORCPT ); Sat, 12 Oct 2019 02:23:58 -0400 X-UUID: b0f39b91104846af8790ca0483b51fe1-20191012 X-UUID: b0f39b91104846af8790ca0483b51fe1-20191012 Received: from mtkcas34.mediatek.inc [(172.27.4.253)] by mailgw01.mediatek.com (envelope-from ) (mailgw01.mediatek.com ESMTP with TLS) with ESMTP id 1320974668; Sat, 12 Oct 2019 14:23:48 +0800 Received: from MTKCAS36.mediatek.inc (172.27.4.186) by MTKMBS32N1.mediatek.inc (172.27.4.71) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Sat, 12 Oct 2019 14:23:46 +0800 Received: from [10.17.3.153] (172.27.4.253) by MTKCAS36.mediatek.inc (172.27.4.170) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Sat, 12 Oct 2019 14:23:45 +0800 Message-ID: <1570861427.19130.65.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: Sat, 12 Oct 2019 14:23:47 +0800 In-Reply-To: <20191011162950.yg4o77mlaicacne5@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> 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: 0A33034A89B0C9BB9E3E78D19D549891FCC7ABDAE5C14ED4B95401F2380F2F052000:8 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. 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". > > Will