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