diff options
| author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-11-26 19:05:19 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-11-26 19:05:19 -0800 | 
| commit | 552d2f841e3f0f45eac86ff93e230db0b0a67a99 (patch) | |
| tree | c47fabd409b3dd92965017dfc1c82df1d35579a0 /arch/mips/kernel/setup.c | |
| parent | 09cfd929860532f95c9944d39abbb043b8082f36 (diff) | |
| parent | b1e3afa001db8845eb60981f6ab925503ed94e53 (diff) | |
Merge branch 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus
* 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus:
  [MIPS] vpe: Add missing "space"
  [MIPS] Compliment va_start() with va_end().
  [MIPS] IP22: Fix broken eeprom access by using __raw_readl/__raw_writel
  [MIPS] IP22: Fix broken EISA interrupt setup by switching to generic i8259
  [MIPS] 64-bit Sibyte kernels need DMA32.
  [MIPS] Only build r4k clocksource for systems that work ok with it.
  [MIPS] Handle R4000/R4400 mfc0 from count register.
  [MIPS] Fix possible hang in LL/SC futex loops.
  [MIPS] Fix context DSP context / TLS pointer switching bug for new threads.
  [MIPS] IP32: More interrupt renumbering fixes.
  [MIPS] time: MIPSsim's plat_time_init doesn't need to be irq safe.
  [MIPS] time: Fix negated condition in cevt-r4k driver.
  [MIPS] Fix pcspeaker build.
Diffstat (limited to 'arch/mips/kernel/setup.c')
| -rw-r--r-- | arch/mips/kernel/setup.c | 31 | 
1 files changed, 30 insertions, 1 deletions
| diff --git a/arch/mips/kernel/setup.c b/arch/mips/kernel/setup.c index a06a27d6cfcd..7f6ddcb5d485 100644 --- a/arch/mips/kernel/setup.c +++ b/arch/mips/kernel/setup.c @@ -269,7 +269,7 @@ static void __init bootmem_init(void)  static void __init bootmem_init(void)  { -	unsigned long reserved_end; +	unsigned long init_begin, reserved_end;  	unsigned long mapstart = ~0UL;  	unsigned long bootmap_size;  	int i; @@ -342,6 +342,35 @@ static void __init bootmem_init(void)  	 */  	bootmap_size = init_bootmem_node(NODE_DATA(0), mapstart,  					 min_low_pfn, max_low_pfn); + + +	init_begin = PFN_UP(__pa_symbol(&__init_begin)); +	for (i = 0; i < boot_mem_map.nr_map; i++) { +		unsigned long start, end; + +		start = PFN_UP(boot_mem_map.map[i].addr); +		end = PFN_DOWN(boot_mem_map.map[i].addr +				+ boot_mem_map.map[i].size); + +		if (start <= init_begin) +			start = init_begin; +		if (start >= end) +			continue; + +#ifndef CONFIG_HIGHMEM +		if (end > max_low_pfn) +			end = max_low_pfn; + +		/* +		 * ... finally, is the area going away? +		 */ +		if (end <= start) +			continue; +#endif + +		add_active_range(0, start, end); +	} +  	/*  	 * Register fully available low RAM pages with the bootmem allocator.  	 */ | 
