memblock: Add find_memory_core_early()
According to node range in early_node_map[] with __memblock_find_in_range to find free range. Will be used by memblock_x86_find_in_range_node() memblock_x86_find_in_range_node will be used to find right buffer for NODE_DATA Signed-off-by: Yinghai Lu <yinghai@kernel.org> Signed-off-by: H. Peter Anvin <hpa@zytor.com>
This commit is contained in:
		
					parent
					
						
							
								88ba088c18
							
						
					
				
			
			
				commit
				
					
						edbe7d23b4
					
				
			
		
					 2 changed files with 38 additions and 0 deletions
				
			
		|  | @ -1164,6 +1164,8 @@ extern void free_bootmem_with_active_regions(int nid, | ||||||
| 						unsigned long max_low_pfn); | 						unsigned long max_low_pfn); | ||||||
| int add_from_early_node_map(struct range *range, int az, | int add_from_early_node_map(struct range *range, int az, | ||||||
| 				   int nr_range, int nid); | 				   int nr_range, int nid); | ||||||
|  | u64 __init find_memory_core_early(int nid, u64 size, u64 align, | ||||||
|  | 					u64 goal, u64 limit); | ||||||
| void *__alloc_memory_core_early(int nodeid, u64 size, u64 align, | void *__alloc_memory_core_early(int nodeid, u64 size, u64 align, | ||||||
| 				 u64 goal, u64 limit); | 				 u64 goal, u64 limit); | ||||||
| typedef int (*work_fn_t)(unsigned long, unsigned long, void *); | typedef int (*work_fn_t)(unsigned long, unsigned long, void *); | ||||||
|  |  | ||||||
|  | @ -21,6 +21,7 @@ | ||||||
| #include <linux/pagemap.h> | #include <linux/pagemap.h> | ||||||
| #include <linux/jiffies.h> | #include <linux/jiffies.h> | ||||||
| #include <linux/bootmem.h> | #include <linux/bootmem.h> | ||||||
|  | #include <linux/memblock.h> | ||||||
| #include <linux/compiler.h> | #include <linux/compiler.h> | ||||||
| #include <linux/kernel.h> | #include <linux/kernel.h> | ||||||
| #include <linux/kmemcheck.h> | #include <linux/kmemcheck.h> | ||||||
|  | @ -3612,6 +3613,41 @@ void __init free_bootmem_with_active_regions(int nid, | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #ifdef CONFIG_HAVE_MEMBLOCK | ||||||
|  | u64 __init find_memory_core_early(int nid, u64 size, u64 align, | ||||||
|  | 					u64 goal, u64 limit) | ||||||
|  | { | ||||||
|  | 	int i; | ||||||
|  | 
 | ||||||
|  | 	/* Need to go over early_node_map to find out good range for node */ | ||||||
|  | 	for_each_active_range_index_in_nid(i, nid) { | ||||||
|  | 		u64 addr; | ||||||
|  | 		u64 ei_start, ei_last; | ||||||
|  | 		u64 final_start, final_end; | ||||||
|  | 
 | ||||||
|  | 		ei_last = early_node_map[i].end_pfn; | ||||||
|  | 		ei_last <<= PAGE_SHIFT; | ||||||
|  | 		ei_start = early_node_map[i].start_pfn; | ||||||
|  | 		ei_start <<= PAGE_SHIFT; | ||||||
|  | 
 | ||||||
|  | 		final_start = max(ei_start, goal); | ||||||
|  | 		final_end = min(ei_last, limit); | ||||||
|  | 
 | ||||||
|  | 		if (final_start >= final_end) | ||||||
|  | 			continue; | ||||||
|  | 
 | ||||||
|  | 		addr = memblock_find_in_range(final_start, final_end, size, align); | ||||||
|  | 
 | ||||||
|  | 		if (addr == MEMBLOCK_ERROR) | ||||||
|  | 			continue; | ||||||
|  | 
 | ||||||
|  | 		return addr; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return MEMBLOCK_ERROR; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| int __init add_from_early_node_map(struct range *range, int az, | int __init add_from_early_node_map(struct range *range, int az, | ||||||
| 				   int nr_range, int nid) | 				   int nr_range, int nid) | ||||||
| { | { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Yinghai Lu
				Yinghai Lu