aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/x86/Kconfig10
-rw-r--r--arch/x86/kernel/setup.c4
-rw-r--r--arch/x86/mm/init_32.c56
-rw-r--r--arch/x86/mm/init_64.c41
-rw-r--r--arch/x86/mm/memblock.c29
-rw-r--r--arch/x86/mm/numa_32.c3
-rw-r--r--arch/x86/mm/numa_64.c47
7 files changed, 1 insertions, 189 deletions
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig
index 542bb2610cbb..ce07615f1cde 100644
--- a/arch/x86/Kconfig
+++ b/arch/x86/Kconfig
@@ -585,15 +585,7 @@ config PARAVIRT_DEBUG
585 a paravirt_op is missing when it is called. 585 a paravirt_op is missing when it is called.
586 586
587config NO_BOOTMEM 587config NO_BOOTMEM
588 default y 588 def_bool y
589 bool "Disable Bootmem code"
590 ---help---
591 Use memblock directly instead of bootmem before slab is ready.
592 - allocator (buddy) [generic]
593 - early allocator (bootmem) [generic]
594 - very early allocator (memblock) [some generic]
595 - very very early allocator (early brk model) [x86]
596 So reduce one layer between early allocator to final allocator
597 589
598config MEMTEST 590config MEMTEST
599 bool "Memtest" 591 bool "Memtest"
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
index 924c8f78e98e..1d114ff6a078 100644
--- a/arch/x86/kernel/setup.c
+++ b/arch/x86/kernel/setup.c
@@ -1014,10 +1014,6 @@ void __init setup_arch(char **cmdline_p)
1014 1014
1015 initmem_init(0, max_pfn, acpi, k8); 1015 initmem_init(0, max_pfn, acpi, k8);
1016 memblock_find_dma_reserve(); 1016 memblock_find_dma_reserve();
1017#ifndef CONFIG_NO_BOOTMEM
1018 memblock_x86_to_bootmem(0, max_low_pfn<<PAGE_SHIFT);
1019#endif
1020
1021 dma32_reserve_bootmem(); 1017 dma32_reserve_bootmem();
1022 1018
1023#ifdef CONFIG_KVM_CLOCK 1019#ifdef CONFIG_KVM_CLOCK
diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c
index 63b09bae2509..c2385d7ae313 100644
--- a/arch/x86/mm/init_32.c
+++ b/arch/x86/mm/init_32.c
@@ -751,68 +751,12 @@ static void __init zone_sizes_init(void)
751 free_area_init_nodes(max_zone_pfns); 751 free_area_init_nodes(max_zone_pfns);
752} 752}
753 753
754#ifndef CONFIG_NO_BOOTMEM
755static unsigned long __init setup_node_bootmem(int nodeid,
756 unsigned long start_pfn,
757 unsigned long end_pfn,
758 unsigned long bootmap)
759{
760 unsigned long bootmap_size;
761
762 /* don't touch min_low_pfn */
763 bootmap_size = init_bootmem_node(NODE_DATA(nodeid),
764 bootmap >> PAGE_SHIFT,
765 start_pfn, end_pfn);
766 printk(KERN_INFO " node %d low ram: %08lx - %08lx\n",
767 nodeid, start_pfn<<PAGE_SHIFT, end_pfn<<PAGE_SHIFT);
768 printk(KERN_INFO " node %d bootmap %08lx - %08lx\n",
769 nodeid, bootmap, bootmap + bootmap_size);
770 free_bootmem_with_active_regions(nodeid, end_pfn);
771
772 return bootmap + bootmap_size;
773}
774#endif
775
776void __init setup_bootmem_allocator(void) 754void __init setup_bootmem_allocator(void)
777{ 755{
778#ifndef CONFIG_NO_BOOTMEM
779 int nodeid;
780 phys_addr_t bootmap_size, bootmap;
781 /*
782 * Initialize the boot-time allocator (with low memory only):
783 */
784 bootmap_size = bootmem_bootmap_pages(max_low_pfn)<<PAGE_SHIFT;
785 bootmap = memblock_find_in_range(0, max_pfn_mapped<<PAGE_SHIFT, bootmap_size,
786 PAGE_SIZE);
787 if (bootmap == MEMBLOCK_ERROR)
788 panic("Cannot find bootmem map of size %ld\n", bootmap_size);
789 memblock_x86_reserve_range(bootmap, bootmap + bootmap_size, "BOOTMAP");
790#endif
791
792 printk(KERN_INFO " mapped low ram: 0 - %08lx\n", 756 printk(KERN_INFO " mapped low ram: 0 - %08lx\n",
793 max_pfn_mapped<<PAGE_SHIFT); 757 max_pfn_mapped<<PAGE_SHIFT);
794 printk(KERN_INFO " low ram: 0 - %08lx\n", max_low_pfn<<PAGE_SHIFT); 758 printk(KERN_INFO " low ram: 0 - %08lx\n", max_low_pfn<<PAGE_SHIFT);
795 759
796#ifndef CONFIG_NO_BOOTMEM
797 for_each_online_node(nodeid) {
798 unsigned long start_pfn, end_pfn;
799
800#ifdef CONFIG_NEED_MULTIPLE_NODES
801 start_pfn = node_start_pfn[nodeid];
802 end_pfn = node_end_pfn[nodeid];
803 if (start_pfn > max_low_pfn)
804 continue;
805 if (end_pfn > max_low_pfn)
806 end_pfn = max_low_pfn;
807#else
808 start_pfn = 0;
809 end_pfn = max_low_pfn;
810#endif
811 bootmap = setup_node_bootmem(nodeid, start_pfn, end_pfn,
812 bootmap);
813 }
814#endif
815
816 after_bootmem = 1; 760 after_bootmem = 1;
817} 761}
818 762
diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c
index d6d408467c46..690b8d13971d 100644
--- a/arch/x86/mm/init_64.c
+++ b/arch/x86/mm/init_64.c
@@ -572,23 +572,7 @@ kernel_physical_mapping_init(unsigned long start,
572void __init initmem_init(unsigned long start_pfn, unsigned long end_pfn, 572void __init initmem_init(unsigned long start_pfn, unsigned long end_pfn,
573 int acpi, int k8) 573 int acpi, int k8)
574{ 574{
575#ifndef CONFIG_NO_BOOTMEM
576 unsigned long bootmap_size, bootmap;
577
578 bootmap_size = bootmem_bootmap_pages(end_pfn)<<PAGE_SHIFT;
579 bootmap = memblock_find_in_range(0, end_pfn<<PAGE_SHIFT, bootmap_size,
580 PAGE_SIZE);
581 if (bootmap == MEMBLOCK_ERROR)
582 panic("Cannot find bootmem map of size %ld\n", bootmap_size);
583 memblock_x86_reserve_range(bootmap, bootmap + bootmap_size, "BOOTMAP");
584 /* don't touch min_low_pfn */
585 bootmap_size = init_bootmem_node(NODE_DATA(0), bootmap >> PAGE_SHIFT,
586 0, end_pfn);
587 memblock_x86_register_active_regions(0, start_pfn, end_pfn); 575 memblock_x86_register_active_regions(0, start_pfn, end_pfn);
588 free_bootmem_with_active_regions(0, end_pfn);
589#else
590 memblock_x86_register_active_regions(0, start_pfn, end_pfn);
591#endif
592} 576}
593#endif 577#endif
594 578
@@ -798,31 +782,6 @@ void mark_rodata_ro(void)
798 782
799#endif 783#endif
800 784
801#ifndef CONFIG_NO_BOOTMEM
802int __init reserve_bootmem_generic(unsigned long phys, unsigned long len,
803 int flags)
804{
805 unsigned long pfn = phys >> PAGE_SHIFT;
806
807 if (pfn >= max_pfn) {
808 /*
809 * This can happen with kdump kernels when accessing
810 * firmware tables:
811 */
812 if (pfn < max_pfn_mapped)
813 return -EFAULT;
814
815 printk(KERN_ERR "reserve_bootmem: illegal reserve %lx %lu\n",
816 phys, len);
817 return -EFAULT;
818 }
819
820 reserve_bootmem(phys, len, flags);
821
822 return 0;
823}
824#endif
825
826int kern_addr_valid(unsigned long addr) 785int kern_addr_valid(unsigned long addr)
827{ 786{
828 unsigned long above = ((long)addr) >> __VIRTUAL_MASK_SHIFT; 787 unsigned long above = ((long)addr) >> __VIRTUAL_MASK_SHIFT;
diff --git a/arch/x86/mm/memblock.c b/arch/x86/mm/memblock.c
index aaff3932588e..50ecbc59757f 100644
--- a/arch/x86/mm/memblock.c
+++ b/arch/x86/mm/memblock.c
@@ -109,7 +109,6 @@ static __init struct range *find_range_array(int count)
109 return range; 109 return range;
110} 110}
111 111
112#ifdef CONFIG_NO_BOOTMEM
113static void __init memblock_x86_subtract_reserved(struct range *range, int az) 112static void __init memblock_x86_subtract_reserved(struct range *range, int az)
114{ 113{
115 u64 final_start, final_end; 114 u64 final_start, final_end;
@@ -182,34 +181,6 @@ int __init get_free_all_memory_range(struct range **rangep, int nodeid)
182 *rangep = range; 181 *rangep = range;
183 return nr_range; 182 return nr_range;
184} 183}
185#else
186void __init memblock_x86_to_bootmem(u64 start, u64 end)
187{
188 int count;
189 u64 final_start, final_end;
190 struct memblock_region *r;
191
192 /* Take out region array itself */
193 memblock_free_reserved_regions();
194
195 count = memblock.reserved.cnt;
196 memblock_dbg("(%d early reservations) ==> bootmem [%#010llx-%#010llx]\n", count, start, end - 1);
197 for_each_memblock(reserved, r) {
198 memblock_dbg(" [%#010llx-%#010llx] ", (u64)r->base, (u64)r->base + r->size - 1);
199 final_start = max(start, r->base);
200 final_end = min(end, r->base + r->size);
201 if (final_start >= final_end) {
202 memblock_dbg("\n");
203 continue;
204 }
205 memblock_dbg(" ==> [%#010llx-%#010llx]\n", final_start, final_end - 1);
206 reserve_bootmem_generic(final_start, final_end - final_start, BOOTMEM_DEFAULT);
207 }
208
209 /* Put region array back ? */
210 memblock_reserve_reserved_regions();
211}
212#endif
213 184
214static u64 __init __memblock_x86_memory_in_range(u64 addr, u64 limit, bool get_free) 185static u64 __init __memblock_x86_memory_in_range(u64 addr, u64 limit, bool get_free)
215{ 186{
diff --git a/arch/x86/mm/numa_32.c b/arch/x86/mm/numa_32.c
index ddf9730b2061..70ddeb75ba25 100644
--- a/arch/x86/mm/numa_32.c
+++ b/arch/x86/mm/numa_32.c
@@ -420,9 +420,6 @@ void __init initmem_init(unsigned long start_pfn, unsigned long end_pfn,
420 for_each_online_node(nid) { 420 for_each_online_node(nid) {
421 memset(NODE_DATA(nid), 0, sizeof(struct pglist_data)); 421 memset(NODE_DATA(nid), 0, sizeof(struct pglist_data));
422 NODE_DATA(nid)->node_id = nid; 422 NODE_DATA(nid)->node_id = nid;
423#ifndef CONFIG_NO_BOOTMEM
424 NODE_DATA(nid)->bdata = &bootmem_node_data[nid];
425#endif
426 } 423 }
427 424
428 setup_bootmem_allocator(); 425 setup_bootmem_allocator();
diff --git a/arch/x86/mm/numa_64.c b/arch/x86/mm/numa_64.c
index 984b1ff7db44..aef0ff74f7dd 100644
--- a/arch/x86/mm/numa_64.c
+++ b/arch/x86/mm/numa_64.c
@@ -199,10 +199,6 @@ setup_node_bootmem(int nodeid, unsigned long start, unsigned long end)
199 unsigned long start_pfn, last_pfn, nodedata_phys; 199 unsigned long start_pfn, last_pfn, nodedata_phys;
200 const int pgdat_size = roundup(sizeof(pg_data_t), PAGE_SIZE); 200 const int pgdat_size = roundup(sizeof(pg_data_t), PAGE_SIZE);
201 int nid; 201 int nid;
202#ifndef CONFIG_NO_BOOTMEM
203 unsigned long bootmap_start, bootmap_pages, bootmap_size;
204 void *bootmap;
205#endif
206 202
207 if (!end) 203 if (!end)
208 return; 204 return;
@@ -239,47 +235,6 @@ setup_node_bootmem(int nodeid, unsigned long start, unsigned long end)
239 NODE_DATA(nodeid)->node_start_pfn = start_pfn; 235 NODE_DATA(nodeid)->node_start_pfn = start_pfn;
240 NODE_DATA(nodeid)->node_spanned_pages = last_pfn - start_pfn; 236 NODE_DATA(nodeid)->node_spanned_pages = last_pfn - start_pfn;
241 237
242#ifndef CONFIG_NO_BOOTMEM
243 NODE_DATA(nodeid)->bdata = &bootmem_node_data[nodeid];
244
245 /*
246 * Find a place for the bootmem map
247 * nodedata_phys could be on other nodes by alloc_bootmem,
248 * so need to sure bootmap_start not to be small, otherwise
249 * early_node_mem will get that with memblock_find_in_range instead
250 * of alloc_bootmem, that could clash with reserved range
251 */
252 bootmap_pages = bootmem_bootmap_pages(last_pfn - start_pfn);
253 bootmap_start = roundup(nodedata_phys + pgdat_size, PAGE_SIZE);
254 /*
255 * SMP_CACHE_BYTES could be enough, but init_bootmem_node like
256 * to use that to align to PAGE_SIZE
257 */
258 bootmap = early_node_mem(nodeid, bootmap_start, end,
259 bootmap_pages<<PAGE_SHIFT, PAGE_SIZE);
260 if (bootmap == NULL) {
261 memblock_x86_free_range(nodedata_phys, nodedata_phys + pgdat_size);
262 node_data[nodeid] = NULL;
263 return;
264 }
265 bootmap_start = __pa(bootmap);
266 memblock_x86_reserve_range(bootmap_start, bootmap_start+(bootmap_pages<<PAGE_SHIFT),
267 "BOOTMAP");
268
269 bootmap_size = init_bootmem_node(NODE_DATA(nodeid),
270 bootmap_start >> PAGE_SHIFT,
271 start_pfn, last_pfn);
272
273 printk(KERN_INFO " bootmap [%016lx - %016lx] pages %lx\n",
274 bootmap_start, bootmap_start + bootmap_size - 1,
275 bootmap_pages);
276 nid = phys_to_nid(bootmap_start);
277 if (nid != nodeid)
278 printk(KERN_INFO " bootmap(%d) on node %d\n", nodeid, nid);
279
280 free_bootmem_with_active_regions(nodeid, end);
281#endif
282
283 node_set_online(nodeid); 238 node_set_online(nodeid);
284} 239}
285 240
@@ -704,9 +659,7 @@ unsigned long __init numa_free_all_bootmem(void)
704 for_each_online_node(i) 659 for_each_online_node(i)
705 pages += free_all_bootmem_node(NODE_DATA(i)); 660 pages += free_all_bootmem_node(NODE_DATA(i));
706 661
707#ifdef CONFIG_NO_BOOTMEM
708 pages += free_all_memory_core_early(MAX_NUMNODES); 662 pages += free_all_memory_core_early(MAX_NUMNODES);
709#endif
710 663
711 return pages; 664 return pages;
712} 665}