x86, mm: Move init_memory_mapping calling out of setup.c
Now init_memory_mapping is called two times, later will be called for every
ram ranges.
Could put all related init_mem calling together and out of setup.c.
Actually, it reverts commit 1bbbbe7
x86: Exclude E820_RESERVED regions and memory holes above 4 GB from direct mapping.
will address that later with complete solution include handling hole under 4g.
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
Link: http://lkml.kernel.org/r/1353123563-3103-5-git-send-email-yinghai@kernel.org
Reviewed-by: Pekka Enberg <penberg@kernel.org>
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
This commit is contained in:
parent
2086fe1159
commit
22ddfcaa0d
|
@ -12,7 +12,6 @@ kernel_physical_mapping_init(unsigned long start,
|
||||||
unsigned long end,
|
unsigned long end,
|
||||||
unsigned long page_size_mask);
|
unsigned long page_size_mask);
|
||||||
|
|
||||||
|
|
||||||
extern unsigned long __initdata pgt_buf_start;
|
extern unsigned long __initdata pgt_buf_start;
|
||||||
extern unsigned long __meminitdata pgt_buf_end;
|
extern unsigned long __meminitdata pgt_buf_end;
|
||||||
extern unsigned long __meminitdata pgt_buf_top;
|
extern unsigned long __meminitdata pgt_buf_top;
|
||||||
|
|
|
@ -602,7 +602,7 @@ static inline int pgd_none(pgd_t pgd)
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
extern int direct_gbpages;
|
extern int direct_gbpages;
|
||||||
void probe_page_size_mask(void);
|
void init_mem_mapping(void);
|
||||||
|
|
||||||
/* local pte updates need not use xchg for locking */
|
/* local pte updates need not use xchg for locking */
|
||||||
static inline pte_t native_local_ptep_get_and_clear(pte_t *ptep)
|
static inline pte_t native_local_ptep_get_and_clear(pte_t *ptep)
|
||||||
|
|
|
@ -913,34 +913,9 @@ void __init setup_arch(char **cmdline_p)
|
||||||
setup_real_mode();
|
setup_real_mode();
|
||||||
|
|
||||||
init_gbpages();
|
init_gbpages();
|
||||||
probe_page_size_mask();
|
|
||||||
|
|
||||||
/* max_pfn_mapped is updated here */
|
init_mem_mapping();
|
||||||
max_low_pfn_mapped = init_memory_mapping(0, max_low_pfn<<PAGE_SHIFT);
|
|
||||||
max_pfn_mapped = max_low_pfn_mapped;
|
|
||||||
|
|
||||||
#ifdef CONFIG_X86_64
|
|
||||||
if (max_pfn > max_low_pfn) {
|
|
||||||
int i;
|
|
||||||
unsigned long start, end;
|
|
||||||
unsigned long start_pfn, end_pfn;
|
|
||||||
|
|
||||||
for_each_mem_pfn_range(i, MAX_NUMNODES, &start_pfn, &end_pfn,
|
|
||||||
NULL) {
|
|
||||||
|
|
||||||
end = PFN_PHYS(end_pfn);
|
|
||||||
if (end <= (1UL<<32))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
start = PFN_PHYS(start_pfn);
|
|
||||||
max_pfn_mapped = init_memory_mapping(
|
|
||||||
max((1UL<<32), start), end);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* can we preseve max_low_pfn ?*/
|
|
||||||
max_low_pfn = max_pfn;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
memblock.current_limit = get_max_mapped();
|
memblock.current_limit = get_max_mapped();
|
||||||
dma_contiguous_reserve(0);
|
dma_contiguous_reserve(0);
|
||||||
|
|
||||||
|
|
|
@ -37,7 +37,7 @@ struct map_range {
|
||||||
|
|
||||||
static int page_size_mask;
|
static int page_size_mask;
|
||||||
|
|
||||||
void probe_page_size_mask(void)
|
static void __init probe_page_size_mask(void)
|
||||||
{
|
{
|
||||||
#if !defined(CONFIG_DEBUG_PAGEALLOC) && !defined(CONFIG_KMEMCHECK)
|
#if !defined(CONFIG_DEBUG_PAGEALLOC) && !defined(CONFIG_KMEMCHECK)
|
||||||
/*
|
/*
|
||||||
|
@ -315,6 +315,23 @@ unsigned long __init_refok init_memory_mapping(unsigned long start,
|
||||||
return ret >> PAGE_SHIFT;
|
return ret >> PAGE_SHIFT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __init init_mem_mapping(void)
|
||||||
|
{
|
||||||
|
probe_page_size_mask();
|
||||||
|
|
||||||
|
/* max_pfn_mapped is updated here */
|
||||||
|
max_low_pfn_mapped = init_memory_mapping(0, max_low_pfn<<PAGE_SHIFT);
|
||||||
|
max_pfn_mapped = max_low_pfn_mapped;
|
||||||
|
|
||||||
|
#ifdef CONFIG_X86_64
|
||||||
|
if (max_pfn > max_low_pfn) {
|
||||||
|
max_pfn_mapped = init_memory_mapping(1UL<<32,
|
||||||
|
max_pfn<<PAGE_SHIFT);
|
||||||
|
/* can we preseve max_low_pfn ?*/
|
||||||
|
max_low_pfn = max_pfn;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* devmem_is_allowed() checks to see if /dev/mem access to a certain address
|
* devmem_is_allowed() checks to see if /dev/mem access to a certain address
|
||||||
|
|
Loading…
Reference in New Issue