diff options
Diffstat (limited to 'arch/x86/mm')
-rw-r--r-- | arch/x86/mm/discontig_32.c | 22 | ||||
-rw-r--r-- | arch/x86/mm/init_32.c | 25 |
2 files changed, 16 insertions, 31 deletions
diff --git a/arch/x86/mm/discontig_32.c b/arch/x86/mm/discontig_32.c index 3e75be46c4f2..1dfff700264c 100644 --- a/arch/x86/mm/discontig_32.c +++ b/arch/x86/mm/discontig_32.c | |||
@@ -309,11 +309,10 @@ static void init_remap_allocator(int nid) | |||
309 | (ulong) node_remap_end_vaddr[nid]); | 309 | (ulong) node_remap_end_vaddr[nid]); |
310 | } | 310 | } |
311 | 311 | ||
312 | unsigned long __init initmem_init(unsigned long start_pfn, | 312 | void __init initmem_init(unsigned long start_pfn, |
313 | unsigned long end_pfn) | 313 | unsigned long end_pfn) |
314 | { | 314 | { |
315 | int nid; | 315 | int nid; |
316 | unsigned long system_start_pfn, system_max_low_pfn; | ||
317 | long kva_target_pfn; | 316 | long kva_target_pfn; |
318 | 317 | ||
319 | /* | 318 | /* |
@@ -324,17 +323,11 @@ unsigned long __init initmem_init(unsigned long start_pfn, | |||
324 | * and ZONE_HIGHMEM. | 323 | * and ZONE_HIGHMEM. |
325 | */ | 324 | */ |
326 | 325 | ||
327 | /* call find_max_low_pfn at first, it could update max_pfn */ | ||
328 | system_max_low_pfn = max_low_pfn = find_max_low_pfn(); | ||
329 | |||
330 | remove_all_active_ranges(); | 326 | remove_all_active_ranges(); |
331 | get_memcfg_numa(); | 327 | get_memcfg_numa(); |
332 | 328 | ||
333 | kva_pages = round_up(calculate_numa_remap_pages(), PTRS_PER_PTE); | 329 | kva_pages = round_up(calculate_numa_remap_pages(), PTRS_PER_PTE); |
334 | 330 | ||
335 | /* partially used pages are not usable - thus round upwards */ | ||
336 | system_start_pfn = min_low_pfn = PFN_UP(init_pg_tables_end); | ||
337 | |||
338 | kva_target_pfn = round_down(max_low_pfn - kva_pages, PTRS_PER_PTE); | 331 | kva_target_pfn = round_down(max_low_pfn - kva_pages, PTRS_PER_PTE); |
339 | do { | 332 | do { |
340 | kva_start_pfn = find_e820_area(kva_target_pfn<<PAGE_SHIFT, | 333 | kva_start_pfn = find_e820_area(kva_target_pfn<<PAGE_SHIFT, |
@@ -357,19 +350,19 @@ unsigned long __init initmem_init(unsigned long start_pfn, | |||
357 | "KVA PG"); | 350 | "KVA PG"); |
358 | #ifdef CONFIG_HIGHMEM | 351 | #ifdef CONFIG_HIGHMEM |
359 | highstart_pfn = highend_pfn = max_pfn; | 352 | highstart_pfn = highend_pfn = max_pfn; |
360 | if (max_pfn > system_max_low_pfn) | 353 | if (max_pfn > max_low_pfn) |
361 | highstart_pfn = system_max_low_pfn; | 354 | highstart_pfn = max_low_pfn; |
362 | printk(KERN_NOTICE "%ldMB HIGHMEM available.\n", | 355 | printk(KERN_NOTICE "%ldMB HIGHMEM available.\n", |
363 | pages_to_mb(highend_pfn - highstart_pfn)); | 356 | pages_to_mb(highend_pfn - highstart_pfn)); |
364 | num_physpages = highend_pfn; | 357 | num_physpages = highend_pfn; |
365 | high_memory = (void *) __va(highstart_pfn * PAGE_SIZE - 1) + 1; | 358 | high_memory = (void *) __va(highstart_pfn * PAGE_SIZE - 1) + 1; |
366 | #else | 359 | #else |
367 | num_physpages = system_max_low_pfn; | 360 | num_physpages = max_low_pfn; |
368 | high_memory = (void *) __va(system_max_low_pfn * PAGE_SIZE - 1) + 1; | 361 | high_memory = (void *) __va(max_low_pfn * PAGE_SIZE - 1) + 1; |
369 | #endif | 362 | #endif |
370 | printk(KERN_NOTICE "%ldMB LOWMEM available.\n", | 363 | printk(KERN_NOTICE "%ldMB LOWMEM available.\n", |
371 | pages_to_mb(system_max_low_pfn)); | 364 | pages_to_mb(max_low_pfn)); |
372 | printk("min_low_pfn = %ld, max_low_pfn = %ld, highstart_pfn = %ld\n", | 365 | printk("min_low_pfn = %ld, max_low_pfn = %ld, highstart_pfn = %ld\n", |
373 | min_low_pfn, max_low_pfn, highstart_pfn); | 366 | min_low_pfn, max_low_pfn, highstart_pfn); |
374 | 367 | ||
375 | printk("Low memory ends at vaddr %08lx\n", | 368 | printk("Low memory ends at vaddr %08lx\n", |
@@ -387,7 +380,6 @@ unsigned long __init initmem_init(unsigned long start_pfn, | |||
387 | memset(NODE_DATA(0), 0, sizeof(struct pglist_data)); | 380 | memset(NODE_DATA(0), 0, sizeof(struct pglist_data)); |
388 | NODE_DATA(0)->bdata = &node0_bdata; | 381 | NODE_DATA(0)->bdata = &node0_bdata; |
389 | setup_bootmem_allocator(); | 382 | setup_bootmem_allocator(); |
390 | return max_low_pfn; | ||
391 | } | 383 | } |
392 | 384 | ||
393 | void __init zone_sizes_init(void) | 385 | void __init zone_sizes_init(void) |
diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c index d1017336f1b5..27b829312944 100644 --- a/arch/x86/mm/init_32.c +++ b/arch/x86/mm/init_32.c | |||
@@ -561,9 +561,15 @@ early_param("highmem", parse_highmem); | |||
561 | /* | 561 | /* |
562 | * Determine low and high memory ranges: | 562 | * Determine low and high memory ranges: |
563 | */ | 563 | */ |
564 | unsigned long __init find_max_low_pfn(void) | 564 | void __init find_low_pfn_range(void) |
565 | { | 565 | { |
566 | unsigned long max_low_pfn; | 566 | /* it could update max_pfn */ |
567 | |||
568 | /* | ||
569 | * partially used pages are not usable - thus | ||
570 | * we are rounding upwards: | ||
571 | */ | ||
572 | min_low_pfn = PFN_UP(init_pg_tables_end); | ||
567 | 573 | ||
568 | max_low_pfn = max_pfn; | 574 | max_low_pfn = max_pfn; |
569 | if (max_low_pfn > MAXMEM_PFN) { | 575 | if (max_low_pfn > MAXMEM_PFN) { |
@@ -625,21 +631,12 @@ unsigned long __init find_max_low_pfn(void) | |||
625 | " kernel!\n"); | 631 | " kernel!\n"); |
626 | #endif | 632 | #endif |
627 | } | 633 | } |
628 | return max_low_pfn; | ||
629 | } | 634 | } |
630 | 635 | ||
631 | #ifndef CONFIG_NEED_MULTIPLE_NODES | 636 | #ifndef CONFIG_NEED_MULTIPLE_NODES |
632 | unsigned long __init initmem_init(unsigned long start_pfn, | 637 | void __init initmem_init(unsigned long start_pfn, |
633 | unsigned long end_pfn) | 638 | unsigned long end_pfn) |
634 | { | 639 | { |
635 | /* | ||
636 | * partially used pages are not usable - thus | ||
637 | * we are rounding upwards: | ||
638 | */ | ||
639 | min_low_pfn = PFN_UP(init_pg_tables_end); | ||
640 | |||
641 | max_low_pfn = find_max_low_pfn(); | ||
642 | |||
643 | #ifdef CONFIG_HIGHMEM | 640 | #ifdef CONFIG_HIGHMEM |
644 | highstart_pfn = highend_pfn = max_pfn; | 641 | highstart_pfn = highend_pfn = max_pfn; |
645 | if (max_pfn > max_low_pfn) | 642 | if (max_pfn > max_low_pfn) |
@@ -661,8 +658,6 @@ unsigned long __init initmem_init(unsigned long start_pfn, | |||
661 | pages_to_mb(max_low_pfn)); | 658 | pages_to_mb(max_low_pfn)); |
662 | 659 | ||
663 | setup_bootmem_allocator(); | 660 | setup_bootmem_allocator(); |
664 | |||
665 | return max_low_pfn; | ||
666 | } | 661 | } |
667 | 662 | ||
668 | void __init zone_sizes_init(void) | 663 | void __init zone_sizes_init(void) |
@@ -699,8 +694,6 @@ void __init setup_bootmem_allocator(void) | |||
699 | panic("Cannot find bootmem map of size %ld\n", bootmap_size); | 694 | panic("Cannot find bootmem map of size %ld\n", bootmap_size); |
700 | reserve_early(bootmap, bootmap + bootmap_size, "BOOTMAP"); | 695 | reserve_early(bootmap, bootmap + bootmap_size, "BOOTMAP"); |
701 | 696 | ||
702 | reserve_initrd(); | ||
703 | |||
704 | bootmap_size = init_bootmem(bootmap >> PAGE_SHIFT, max_low_pfn); | 697 | bootmap_size = init_bootmem(bootmap >> PAGE_SHIFT, max_low_pfn); |
705 | printk(KERN_INFO " mapped low ram: 0 - %08lx\n", | 698 | printk(KERN_INFO " mapped low ram: 0 - %08lx\n", |
706 | max_pfn_mapped<<PAGE_SHIFT); | 699 | max_pfn_mapped<<PAGE_SHIFT); |