Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757481AbZCQQYG (ORCPT ); Tue, 17 Mar 2009 12:24:06 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754960AbZCQQXy (ORCPT ); Tue, 17 Mar 2009 12:23:54 -0400 Received: from waste.org ([66.93.16.53]:50219 "EHLO waste.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752570AbZCQQXy (ORCPT ); Tue, 17 Mar 2009 12:23:54 -0400 Subject: Re: [PATCH] acquire mmap semaphore in pagemap_read. From: Matt Mackall To: Martin Schwidefsky Cc: Alexey Dobriyan , linux-kernel@vger.kernel.org, linux-mm@kvack.org, Gerald Schaefer , akpm@linux-foundation.org In-Reply-To: <20090317130410.7dd8daa5@skybase> References: <20090312113308.6fe18a93@skybase> <20090312114533.GA2407@x200.localdomain> <20090312125410.25400d18@skybase> <1236871414.3213.50.camel@calx> <20090312165451.1a7ef22f@skybase> <20090317130410.7dd8daa5@skybase> Content-Type: text/plain Date: Tue, 17 Mar 2009 11:21:41 -0500 Message-Id: <1237306901.3213.251.camel@calx> Mime-Version: 1.0 X-Mailer: Evolution 2.22.3.1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2039 Lines: 46 On Tue, 2009-03-17 at 13:04 +0100, Martin Schwidefsky wrote: > On Thu, 12 Mar 2009 16:54:51 +0100 > Martin Schwidefsky wrote: > > > On Thu, 12 Mar 2009 10:23:34 -0500 > > Matt Mackall wrote: > > > > > Well it means we may have to reintroduce the very annoying double > > > buffering from various earlier implementations. But let's leave this > > > discussion until after we've figured out what to do about the walker > > > code. > > > > About the walker code. I've realized that there is another way to fix > > this. The TASK_SIZE definition is currently used for two things: 1) as > > a maximum mappable address, 2) the size of the address space for a > > process. And there lies a problem: while a process is using a reduced > > page table 1) and 2) differ. If I make TASK_SIZE give you the current > > size of the address space then it is not possible to mmap an object > > beyond 4TB and the page table upgrade never happens. If I make > > TASK_SIZE return the maximum mappable address the page table walker > > breaks. The solution could be to introduce MAX_TASK_SIZE and use that > > in the mmap code to find out what can be mapped. > > I got around the TASK_SIZE checks with arch code only. In total I'll > need two fixes, one that makes TASK_SIZE to reflect the size of the > current address space and another one to get the page table upgrades > working again. I'll push these patches via git390 as no common code > changes are required. Thanks, Martin. > Which leaves the mmap_sem issue as the only problem left. Yeah, this one needs more thought. I'd really rather not go back to double-buffering here as it was much more complicated, not to mention slow. -- http://selenic.com : development and support for Mercurial and Linux -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/