From mboxrd@z Thu Jan 1 00:00:00 1970 From: Johannes Weiner Subject: Re: [RFC][patch 2/5] mm: Node-setup agnostic free_bootmem() References: <20080416113629.947746497@skyscraper.fehenstaub.lan> <20080416113719.092060936@skyscraper.fehenstaub.lan> <86802c440804161054h6f0cfc3dmde49006afb7889b2@mail.gmail.com> Date: Wed, 16 Apr 2008 21:19:33 +0200 In-Reply-To: <86802c440804161054h6f0cfc3dmde49006afb7889b2@mail.gmail.com> (Yinghai Lu's message of "Wed, 16 Apr 2008 10:54:57 -0700") Message-ID: <873aplfvzu.fsf@saeurebad.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Sender: owner-linux-mm@kvack.org Return-Path: To: Yinghai Lu Cc: LKML , Linux MM , Ingo Molnar , Andi Kleen , Yasunori Goto , KAMEZAWA Hiroyuki , Christoph Lameter , Andrew Morton List-ID: Hi, "Yinghai Lu" writes: > 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. Alright, I will. Hannes -- 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