From mboxrd@z Thu Jan 1 00:00:00 1970 Received: by wr-out-0506.google.com with SMTP id c37so1954361wra.26 for ; Wed, 16 Apr 2008 10:54:57 -0700 (PDT) Message-ID: <86802c440804161054h6f0cfc3dmde49006afb7889b2@mail.gmail.com> Date: Wed, 16 Apr 2008 10:54:57 -0700 From: "Yinghai Lu" Subject: Re: [RFC][patch 2/5] mm: Node-setup agnostic free_bootmem() In-Reply-To: <20080416113719.092060936@skyscraper.fehenstaub.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Content-Disposition: inline References: <20080416113629.947746497@skyscraper.fehenstaub.lan> <20080416113719.092060936@skyscraper.fehenstaub.lan> Sender: owner-linux-mm@kvack.org Return-Path: To: Johannes Weiner Cc: LKML , Linux MM , Ingo Molnar , Andi Kleen , Yasunori Goto , KAMEZAWA Hiroyuki , Christoph Lameter , Andrew Morton List-ID: On Wed, Apr 16, 2008 at 4:36 AM, Johannes Weiner wrote: > Make free_bootmem() look up the node holding the specified address > range which lets it work transparently on single-node and multi-node > configurations. > > If the address range exceeds the node range, it well be marked free > across node boundaries, too. > > Signed-off-by: Johannes Weiner > CC: Ingo Molnar > CC: Andi Kleen > CC: Yinghai Lu > CC: Yasunori Goto > CC: KAMEZAWA Hiroyuki > CC: Christoph Lameter > CC: Andrew Morton > --- > mm/bootmem.c | 10 +++++++++- > 1 files changed, 9 insertions(+), 1 deletions(-) > > Index: tree-linus/mm/bootmem.c > =================================================================== > --- tree-linus.orig/mm/bootmem.c > +++ tree-linus/mm/bootmem.c > @@ -421,7 +421,32 @@ int __init reserve_bootmem(unsigned long > > void __init free_bootmem(unsigned long addr, unsigned long size) > { > - free_bootmem_core(NODE_DATA(0)->bdata, addr, size); > + bootmem_data_t *bdata; > + unsigned long pos = addr; > + unsigned long partsize = size; > + > + list_for_each_entry(bdata, &bdata_list, list) { > + unsigned long remainder = 0; > + > + if (pos < bdata->node_boot_start) > + continue; > + > + if (PFN_DOWN(pos + partsize) > bdata->node_low_pfn) { > + remainder = PFN_DOWN(pos + partsize) - bdata->node_low_pfn; > + partsize -= remainder; > + } > + > + free_bootmem_core(bdata, pos, partsize); > + > + if (!remainder) > + return; > + > + pos = PFN_PHYS(bdata->node_low_pfn + 1); > + } > + printk(KERN_ERR "free_bootmem: request: addr=%lx, size=%lx, " > + "state: pos=%lx, partsize=%lx\n", addr, size, > + pos, partsize); > + BUG(); > } > > unsigned long __init free_all_bootmem(void) > > -- Yes, it should work well with cross nodes case. but please add boundary check on free_bootmem_node too. YH -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org