Commit 636cc40c authored by Johannes Weiner's avatar Johannes Weiner Committed by Linus Torvalds

bootmem: revisit bootmem descriptor list handling

link_bootmem handles an insertion of a new descriptor into the sorted list
in more or less three explicit branches; empty list, insert in between and
append.  These cases can be expressed implicite.

Also mark the sorted list as initdata as it can be thrown away after boot
as well.
Signed-off-by: default avatarJohannes Weiner <hannes@saeurebad.de>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent df049a5f
...@@ -23,7 +23,6 @@ unsigned long max_low_pfn; ...@@ -23,7 +23,6 @@ unsigned long max_low_pfn;
unsigned long min_low_pfn; unsigned long min_low_pfn;
unsigned long max_pfn; unsigned long max_pfn;
static LIST_HEAD(bdata_list);
#ifdef CONFIG_CRASH_DUMP #ifdef CONFIG_CRASH_DUMP
/* /*
* If we have booted due to a crash, max_pfn will be a very low value. We need * If we have booted due to a crash, max_pfn will be a very low value. We need
...@@ -34,6 +33,8 @@ unsigned long saved_max_pfn; ...@@ -34,6 +33,8 @@ unsigned long saved_max_pfn;
bootmem_data_t bootmem_node_data[MAX_NUMNODES] __initdata; bootmem_data_t bootmem_node_data[MAX_NUMNODES] __initdata;
static struct list_head bdata_list __initdata = LIST_HEAD_INIT(bdata_list);
static int bootmem_debug; static int bootmem_debug;
static int __init bootmem_debug_setup(char *buf) static int __init bootmem_debug_setup(char *buf)
...@@ -73,20 +74,16 @@ unsigned long __init bootmem_bootmap_pages(unsigned long pages) ...@@ -73,20 +74,16 @@ unsigned long __init bootmem_bootmap_pages(unsigned long pages)
*/ */
static void __init link_bootmem(bootmem_data_t *bdata) static void __init link_bootmem(bootmem_data_t *bdata)
{ {
struct list_head *iter;
list_for_each(iter, &bdata_list) {
bootmem_data_t *ent; bootmem_data_t *ent;
if (list_empty(&bdata_list)) { ent = list_entry(iter, bootmem_data_t, list);
list_add(&bdata->list, &bdata_list); if (bdata->node_boot_start < ent->node_boot_start)
return; break;
}
/* insert in order */
list_for_each_entry(ent, &bdata_list, list) {
if (bdata->node_boot_start < ent->node_boot_start) {
list_add_tail(&bdata->list, &ent->list);
return;
}
} }
list_add_tail(&bdata->list, &bdata_list); list_add_tail(&bdata->list, iter);
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment