Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2992568AbWKAPDq (ORCPT ); Wed, 1 Nov 2006 10:03:46 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S2992569AbWKAPDq (ORCPT ); Wed, 1 Nov 2006 10:03:46 -0500 Received: from mailrelay1.uni-mannheim.de ([134.155.96.50]:16015 "EHLO mailrelay1.uni-mannheim.de") by vger.kernel.org with ESMTP id S2992568AbWKAPDq (ORCPT ); Wed, 1 Nov 2006 10:03:46 -0500 Message-ID: <4548B7EC.7060006@ti.uni-mannheim.de> Date: Wed, 01 Nov 2006 16:06:20 +0100 From: Guillermo Marcus Martinez User-Agent: Thunderbird 1.5.0.7 (Windows/20060909) MIME-Version: 1.0 To: linux-kernel@vger.kernel.org Subject: Re: mmaping a kernel buffer to user space References: <4547150F.8070408@ti.uni-mannheim.de> <454899E9.1090900@ti.uni-mannheim.de> In-Reply-To: X-Enigmail-Version: 0.94.0.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2936 Lines: 75 yogeshwar sonawane schrieb: > On 11/1/06, Guillermo Marcus Martinez wrote: >> Rolf Offermanns schrieb: >> > Guillermo Marcus ti.uni-mannheim.de> writes: >> >> Note: I am using kernel 2.6.9 for these tests, as it is required by my >> >> current setup. Maybe this issue has already been addressed in newer >> >> kernel. If that is the case, please let me know. >> > >> > Have a look at this article: >> > >> > "The evolution of driver page remapping" >> > http://lwn.net/Articles/162860/ >> > >> > It should make things clearer. >> > >> > The "API changes in the 2.6 kernel series" page is also a very good >> read: >> > http://lwn.net/Articles/2.6-kernel-api/ >> > >> > HTH, >> > Rolf >> >> Thanks for the links! >> >> Yes, it looks like a step in the right direction. However, the article >> says about vm_insert_page(): "...What it does require is that the page >> be an order-zero allocation obtained for this purpose...", therefore >> making it also unusable for this case (mmaping a pci_alloc_consistent). >> >> I think the limitation (being order zero), is related to the page >> counting, as I understand that for bigger order allocations, only the >> first-page counter is incremented (not every page). If that is a >> problem, I guess I would also see a problem with my workaround, and I >> see none (yet). So I may try in a newer kernel and see if I can use it >> to walk the pages on the mmap without using the nopage(). > > Setting 'PG_reserved' bit of all allocated pages & then calling > remap_page/pfn_range() > will do the things for 2.6.9. > I will give it a try. I guess it may not be equivalent to setting VM_RESERVED before calling remap_page/pfn_range(). Is this platform specific, or is intended behavior/usage of remap_page/pfn_range()? >> >> My suggestion would be to add two functions: pci_map_consistent() and >> dma_map_coherent() to address this issue, and their corresponding >> unmap's. That will make sure all that is needed is done, is a clean and >> consistent with the pci_ and dma_ APIs, and fills a mmap requirement not >> covered by the other functions. >> >> Best wishes, >> Guillermo >> >> - >> 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/ >> > - > 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/ - 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/