From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757658Ab3ILFnf (ORCPT ); Thu, 12 Sep 2013 01:43:35 -0400 Received: from hrndva-omtalb.mail.rr.com ([71.74.56.122]:31776 "EHLO hrndva-omtalb.mail.rr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754947Ab3ILFkq (ORCPT ); Thu, 12 Sep 2013 01:40:46 -0400 X-Authority-Analysis: v=2.0 cv=fJG7LOme c=1 sm=0 a=Sro2XwOs0tJUSHxCKfOySw==:17 a=Drc5e87SC40A:10 a=Ciwy3NGCPMMA:10 a=z2nwowCSNEkA:10 a=5SG0PmZfjMsA:10 a=bbbx4UPp9XUA:10 a=meVymXHHAAAA:8 a=KGjhK52YXX0A:10 a=zV0AqNJpeP8A:10 a=jIQo8A4GAAAA:8 a=OLL_FvSJAAAA:8 a=1XWaLZrsAAAA:8 a=20KFwNOVAAAA:8 a=JfrnYn6hAAAA:8 a=7CQSdrXTAAAA:8 a=pGLkceISAAAA:8 a=Z4Rwk6OoAAAA:8 a=xWgSoR3eXJWkwanzJ1YA:9 a=xYQ-p_llWMoA:10 a=jiJFkoeR32oA:10 a=0kPLrQdw3YYA:10 a=UTB_XpHje0EA:10 a=jEp0ucaQiEUA:10 a=3Rfx1nUSh_UA:10 a=ESTKKtUg-DoA:10 a=MSl-tDqOz04A:10 a=jbrJJM5MRmoA:10 a=jeBq3FmKZ4MA:10 a=Sro2XwOs0tJUSHxCKfOySw==:117 X-Cloudmark-Score: 0 X-Authenticated-User: X-Originating-IP: 67.255.60.225 Message-Id: <20130911042904.849128305@goodmis.org> User-Agent: quilt/0.60-1 Date: Wed, 11 Sep 2013 00:28:22 -0400 From: Steven Rostedt To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Vineet Gupta , Mel Gorman , Hugh Dickins , Rik van Riel , David Rientjes , Peter Zijlstra , Catalin Marinas , Max Filippov , Andrew Morton Subject: [075/251] mm: fix the TLB range flushed when __tlb_remove_page() runs out of slots References: <20130911042707.738353451@goodmis.org> Content-Disposition: inline; filename=0075-mm-fix-the-TLB-range-flushed-when-__tlb_remove_page-.patch Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.6.11.9-rc1 stable review patch. If anyone has any objections, please let me know. ------------------ From: Vineet Gupta [ Upstream commit e6c495a96ce02574e765d5140039a64c8d4e8c9e ] zap_pte_range loops from @addr to @end. In the middle, if it runs out of batching slots, TLB entries needs to be flushed for @start to @interim, NOT @interim to @end. Since ARC port doesn't use page free batching I can't test it myself but this seems like the right thing to do. Observed this when working on a fix for the issue at thread: http://www.spinics.net/lists/linux-arch/msg21736.html Signed-off-by: Vineet Gupta Cc: Mel Gorman Cc: Hugh Dickins Cc: Rik van Riel Cc: David Rientjes Cc: Peter Zijlstra Acked-by: Catalin Marinas Cc: Max Filippov Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Steven Rostedt --- mm/memory.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/mm/memory.c b/mm/memory.c index 06ff7fb..e526880 100644 --- a/mm/memory.c +++ b/mm/memory.c @@ -1106,6 +1106,7 @@ static unsigned long zap_pte_range(struct mmu_gather *tlb, spinlock_t *ptl; pte_t *start_pte; pte_t *pte; + unsigned long range_start = addr; again: init_rss_vec(rss); @@ -1211,12 +1212,14 @@ again: force_flush = 0; #ifdef HAVE_GENERIC_MMU_GATHER - tlb->start = addr; - tlb->end = end; + tlb->start = range_start; + tlb->end = addr; #endif tlb_flush_mmu(tlb); - if (addr != end) + if (addr != end) { + range_start = addr; goto again; + } } return addr; -- 1.7.10.4