Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1750735AbWHKI2i (ORCPT ); Fri, 11 Aug 2006 04:28:38 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1750805AbWHKI2i (ORCPT ); Fri, 11 Aug 2006 04:28:38 -0400 Received: from hellhawk.shadowen.org ([80.68.90.175]:17683 "EHLO hellhawk.shadowen.org") by vger.kernel.org with ESMTP id S1750735AbWHKI2h (ORCPT ); Fri, 11 Aug 2006 04:28:37 -0400 Message-ID: <44DC3F47.70508@shadowen.org> Date: Fri, 11 Aug 2006 09:26:47 +0100 From: Andy Whitcroft User-Agent: Thunderbird 1.5.0.2 (X11/20060516) MIME-Version: 1.0 To: moreau francis CC: KAMEZAWA Hiroyuki , alan@lxorguk.ukuu.org.uk, linux-kernel@vger.kernel.org Subject: Re: Re : Re : sparsemem usage References: <20060810153731.22728.qmail@web25808.mail.ukl.yahoo.com> In-Reply-To: <20060810153731.22728.qmail@web25808.mail.ukl.yahoo.com> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4945 Lines: 115 moreau francis wrote: > Andy Whitcroft wrote: >> moreau francis wrote: >>> KAMEZAWA Hiroyuki wrote: >>>> On Thu, 10 Aug 2006 14:40:52 +0200 (CEST) >>>> moreau francis wrote: >>>>>> BTW, ioresouce information (see kernel/resouce.c) >>>>>> >>>>>> [kamezawa@aworks Development]$ cat /proc/iomem | grep RAM >>>>>> 00000000-0009fbff : System RAM >>>>>> 000a0000-000bffff : Video RAM area >>>>>> 00100000-2dfeffff : System RAM >>>>>> >>>>>> is not enough ? >>>>>> >>>>> well actually you show that to get a really simple information, ie does >>>>> a page exist ?, we need to parse some kernel data structures like >>>>> ioresource (which is, IMHO, hackish) or duplicate in each architecture >>>>> some data to keep track of existing pages. >>>>> >>>> becasue memory map from e820(x86) or efi(ia64) are registered to >>>> iomem_resource, >>>> we should avoid duplicates that information. kdump and memory hotplug >>>> uses >>>> this information. (memory hotplug updates this iomem_resource.) >>>> >>>> Implementing "page_is_exist" function based on ioresouce is one of >>>> generic >>>> and rubust way to go, I think. >>>> (if performance of list walking is problem, enhancing ioresouce code is >>>> better.) >>>> >>> Why not implementing page_exist() by simply using mem_map[] ? When >>> allocating mem_map[], we can just fill it with a special value. And >>> then when registering memory area, we clear this special value with >>> the "reserved" value. Hence for flatmem model, we can have: >>> >>> #define page_exist(pfn) (mem_map[pfn] != SPECIAL_VALUE) >>> >>> and it should work for sparsemem too and other models that will use >>> mem_map[]. >> The mem_map isn't a pointer, its a physical structure. We have a > > ok > >> special value to tell you if the page is usable within that, thats >> called PG_reserved. If this page is reserved the kernel can't touch it, >> can't look at it. > > can't we introduce a new special value, such as "PG_real" ? > >>> Another point, is page_exist() going to replace page_valid() ? >>> I mean page_exist() is going to be something more accurate than >>> page_valid(). All tests on page_valid() _only_ will be fine to test >>> page_exist(). But all tests such: >>> >>> if (page_valid(x) && page_is_ram(x)) >>> >>> can be replaced by >>> >>> if (page_exist(x)) >>> >>> So, again, why not simply improving page_valid() definition rather >>> than introduce a new service ? >> Whilst I can understand that not knowing if a page is real or not is >> perhaps unappealing, I've yet to see any case where we need or care. >> Changing things to make things 'nicer' interlectually is sometimes >> worthwhile. But what is the user here. >> >> The only consumer you have shown is show_mem() which is a debug >> function, and that only dumps out the current memory counts. Its not >> clear it cares to really know if a page is real or not. >> > > I understand your point of view, but even if it's a debug function, > it must exist and report correct information. And my point is that > I think it should be really easy to implement :) that by using > a new "special value". Can you confirm that it's really easy to > implement that ? It does produce real numbers, it tells you how many reserved pages you have. The places that this is triggered we are interested in why we have no memory left. We are not interested in how many pages are known but reserved as against how many pages are backed by page*'s but are really holes; they are mearly pages we can't use out of the total we are tracking. We care about how many are not reserved, and how many of those are available. It would be 'as simple' as adding a PG_real page bit except for two things: 1) page flags bits are seriously short supply; there are some 24 available of which 22 are in use. Any new user of a bit would have to be an extremely valuable change with major benefit to the kernel, and 2) if you were to try and populate a PG_real flag it would need to be populated for _all_ architectures (and there are a lot) for it to be of any use. As you have already noted there is no consistent way to find out whether a page is ram so it would be major exercise to get these bits setup during boot. I think we should take (2) as a hint here. If we don't have a consistent interface for finding whether a page is real or not, we obviously have no general need of that information in the kernel. Yes we obviously care if we can use a page, but we do not care if the page is unusable because it contains an ACPI table or the video driver BIOS or there is a memory hole. Its either usable (!PG_reserved) or its not (PG_reserved). -apw - 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/