Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1670332imm; Thu, 27 Sep 2018 00:10:27 -0700 (PDT) X-Google-Smtp-Source: ACcGV62zGzK7AE/t2kPjaojaU9K+gv9z0u44cekwe2XAMaOLMM9glvY0bGvtPX2XoChE5cFvxlZB X-Received: by 2002:a63:a441:: with SMTP id c1-v6mr8919140pgp.182.1538032227379; Thu, 27 Sep 2018 00:10:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538032227; cv=none; d=google.com; s=arc-20160816; b=BhTN4znHuCaTvbTJkzmu+zW0Qj1Bz/aybhC/wIZY4QJ3ynOPapgDvWSRk02JcQLEEV AG5YMoI5wFH+9jiE5rWsVA9i+Eg02Sy+pQKIXLqInAartnzoRTWP3Khnhzn+P+Y/RDlI U1eTUQfJGjIzJPzAAHqvUd0JfLTc9vL/WhuNluzerBq+4O9epWhZhvZMCX22U8sUNQOj gb+BI2Lav9PtfLdfsqeuqdEItFGxbSCEVuVZGv5R95AnK7RD++WgIw6fKUg5qox+CsXs ISdBeKm02KNp4NixJLTM9X+Ms6Z9xQJuhBDqutTUmhP+zEui3rtzgHYzNO/1EkHIoslC U5Fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=W/M2C/EenKG6L8h8nExvJlpxCRNdVmxu1ik9wEaaKXI=; b=MjPRCh8qH/siJ0xkjNOtx2hBDQmFU+pIuVbYeukeV65HIU+2p815wq+U4jnZj6/GVI ASsiIyta6JeVTNAMM580DtC617A7cU+7X2fLaQFamKwpN5MT3fP39tfBY8hsYbl2GSXv jPJGdzrn9q8jS1RyETKaZ9k5ybaATnVH2YWhdV1t3hd7pjH7u5FKo4gIWVkKkAlUlzYU sKsp1YaaD5WigTeBLF4AJtZD0fv2yrs1yDN9M7so098NkIHrz2aI9+ONaX+xf4K1VJEy RmfFRQRdIvQZBUXghllJ33dJIpg3G9ESMCMnOHjlluOFR+FcoSeG4g2drV/EVAmIgF/s QfDw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=merlin.20170209 header.b=Axe2n6T1; 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 v13-v6si1442246pfc.257.2018.09.27.00.10.11; Thu, 27 Sep 2018 00:10:27 -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; dkim=fail header.i=@infradead.org header.s=merlin.20170209 header.b=Axe2n6T1; 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 S1727249AbeI0N0v (ORCPT + 99 others); Thu, 27 Sep 2018 09:26:51 -0400 Received: from merlin.infradead.org ([205.233.59.134]:60750 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726929AbeI0N0v (ORCPT ); Thu, 27 Sep 2018 09:26:51 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=merlin.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=W/M2C/EenKG6L8h8nExvJlpxCRNdVmxu1ik9wEaaKXI=; b=Axe2n6T12lZSjyYNyHQHhxWjx 2pXOiVthOFXxp+aWDVBDeI3ytlsSf/tCCIFC/wYWeKh4yqJm1z0GIVIgCbbk0GfzFrmi4UK0uUGDP aRre9JeqIiuvxKKdDO33oXRJDqPQ87vu3dTykjc6gAdEEM+YWdWf7RMm09HgOlKVI0C+JXTfxcdpC F032ac73nBC1VFBja1qCuF42KVJI8Kmg2F1szaO54y/QCWa1Wr3Fwy2KM7tCnAcmos3yoM9CP7urT 3As89ldQrz+kxlUE0XzqIB1R3KeVLW/dlK2MIkkPl8HenYBXsDuGFXe38JpyCQmOXp4v/HppAAHsl Wbh6T7oyA==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=hirez.programming.kicks-ass.net) by merlin.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1g5QQI-0005JD-97; Thu, 27 Sep 2018 07:09:39 +0000 Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id 5E5B420696FC6; Thu, 27 Sep 2018 09:08:59 +0200 (CEST) Date: Thu, 27 Sep 2018 09:08:59 +0200 From: Peter Zijlstra To: Guo Ren Cc: akpm@linux-foundation.org, arnd@arndb.de, daniel.lezcano@linaro.org, davem@davemloft.net, gregkh@linuxfoundation.org, jason@lakedaemon.net, marc.zyngier@arm.com, mark.rutland@arm.com, mchehab+samsung@kernel.org, robh@kernel.org, robh+dt@kernel.org, tglx@linutronix.de, linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org, devicetree@vger.kernel.org, c-sky_gcc_upstream@c-sky.com, gnu-csky@mentor.com, green.hu@gmail.com, palmer@sifive.com Subject: Re: [PATCH V5 06/30] csky: Cache and TLB routines Message-ID: <20180927070859.GC5254@hirez.programming.kicks-ass.net> References: <7cd7abcd2acf5c61435589338ff80a75a13173ca.1537789737.git.ren_guo@c-sky.com> <20180925072407.GA6999@hirez.programming.kicks-ass.net> <20180927052737.GA28407@guoren> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180927052737.GA28407@guoren> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Sep 27, 2018 at 01:27:38PM +0800, Guo Ren wrote: > On Tue, Sep 25, 2018 at 09:24:07AM +0200, Peter Zijlstra wrote: > > On Mon, Sep 24, 2018 at 10:36:22PM +0800, Guo Ren wrote: > > > diff --git a/arch/csky/abiv1/inc/abi/cacheflush.h b/arch/csky/abiv1/inc/abi/cacheflush.h > > > new file mode 100644 > > > index 0000000..f0de49c > > > --- /dev/null > > > +++ b/arch/csky/abiv1/inc/abi/cacheflush.h > > > +#define flush_cache_range(mm,start,end) cache_wbinv_range(start, end) > > ^^^ should be vma > Yes, I'll change it to: > #define flush_cache_range(mm,start,end) cache_wbinv_all() > > I'll improve it later after test. That's not what I meant; I meant you need something like: #define flush_cache_range(vma, start, end) cache_wbinv_range(start, end) The first argument is a vma, not an mm. > > > +#endif /* __ABI_CSKY_CACHEFLUSH_H */ > > > > > > > diff --git a/arch/csky/abiv1/inc/abi/tlb.h b/arch/csky/abiv1/inc/abi/tlb.h > > > new file mode 100644 > > > index 0000000..6d461f3 > > > --- /dev/null > > > +++ b/arch/csky/abiv1/inc/abi/tlb.h > > > @@ -0,0 +1,12 @@ > > > +// SPDX-License-Identifier: GPL-2.0 > > > +// Copyright (C) 2018 Hangzhou C-SKY Microsystems co.,ltd. > > > + > > > +#ifndef __ABI_CSKY_TLB_H > > > +#define __ABI_CSKY_TLB_H > > > + > > > +#define tlb_start_vma(tlb, vma) \ > > > + do { \ > > > + if (!tlb->fullmm) \ > > > + cache_wbinv_all(); \ > > > + } while (0) > > > +#endif /* __ABI_CSKY_TLB_H */ > > > > That should be: > > > > if (!tlb->fullmm) > > flush_cache_range(vma, vma->vm_start, vma->vm_end); > > > > Because as per the whole abiv1 vs abiv2, you don't need write back > > invalidation for v2 at all, also, you only need to invalidate the vma > > range, no reason to shoot everything down. > > > > Also, I'll be shortly removing this: > > > > https://lkml.kernel.org/r/20180913092812.071989585@infradead.org > Ok, I'll follow the rules. > > > diff --git a/arch/csky/abiv2/inc/abi/cacheflush.h b/arch/csky/abiv2/inc/abi/cacheflush.h > > > new file mode 100644 > > > index 0000000..756beb7 > > > --- /dev/null > > > +++ b/arch/csky/abiv2/inc/abi/cacheflush.h > > > @@ -0,0 +1,40 @@ > > > +#define flush_cache_range(vma, start, end) do { } while (0) > > ^^^ like here.. > #define flush_cache_range(vma, start, end) \ > do { \ > if (vma->vm_flags & VM_EXEC) \ > icache_inv_all(); \ > } > > Hmm ? > For v2, which IIUC is PIPT (as opposed to v1 which is VIPT), what you had was correct. I was merely pointing out that the flush_cache_range() definition was inconsitent between v1 and v2; v1 using @mm and v2 using @vma for the first argument.