From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758043AbcBXICv (ORCPT ); Wed, 24 Feb 2016 03:02:51 -0500 Received: from bes.se.axis.com ([195.60.68.10]:57099 "EHLO bes.se.axis.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750718AbcBXICt (ORCPT ); Wed, 24 Feb 2016 03:02:49 -0500 Message-ID: <56CD63A6.5090305@axis.com> Date: Wed, 24 Feb 2016 09:02:46 +0100 From: Lars Persson User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Icedove/31.8.0 MIME-Version: 1.0 To: Paul Burton , , Ralf Baechle CC: Lars Persson , , Andrew Morton , Jerome Marchand , "Kirill A. Shutemov" Subject: Re: [PATCH 2/2] MIPS: Flush highmem pages from dcache in __flush_icache_page References: <1456164585-26910-1-git-send-email-paul.burton@imgtec.com> <1456164585-26910-2-git-send-email-paul.burton@imgtec.com> In-Reply-To: <1456164585-26910-2-git-send-email-paul.burton@imgtec.com> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.0.5.55] X-ClientProxiedBy: XBOX04.axis.com (10.0.5.18) To XBOX02.axis.com (10.0.5.16) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/22/2016 07:09 PM, Paul Burton wrote: > When a page is to be mapped executable for userspace, we can presume > that the icache doesn't contain anything valid for its address range but > we cannot be sure that its content has been written back from the dcache > to L2 or memory further out. If the icache fills from those memories, > ie. does not fill from the dcache, then we need to ensure that content > has been flushed from the dcache. This was being done for lowmem pages > but not for highmem pages. Fix this by mapping the page & flushing its > content from the dcache in __flush_icache_page, before the page is > provided to userland. > Reviewed-by: Lars Persson > Signed-off-by: Paul Burton > > --- > > arch/mips/mm/cache.c | 9 +++++++-- > 1 file changed, 7 insertions(+), 2 deletions(-) > > diff --git a/arch/mips/mm/cache.c b/arch/mips/mm/cache.c > index 3f159ca..734cb2f 100644 > --- a/arch/mips/mm/cache.c > +++ b/arch/mips/mm/cache.c > @@ -16,6 +16,7 @@ > #include > > #include > +#include > #include > #include > #include > @@ -124,10 +125,14 @@ void __flush_icache_page(struct vm_area_struct *vma, struct page *page) > unsigned long addr; > > if (PageHighMem(page)) > - return; > + addr = (unsigned long)kmap_atomic(page); > + else > + addr = (unsigned long)page_address(page); > > - addr = (unsigned long) page_address(page); > flush_data_cache_page(addr); > + > + if (PageHighMem(page)) > + __kunmap_atomic((void *)addr); > } > EXPORT_SYMBOL_GPL(__flush_icache_page); > >