diff options
| author | Olof Johansson <olof@lixom.net> | 2012-11-25 21:34:34 -0800 | 
|---|---|---|
| committer | Olof Johansson <olof@lixom.net> | 2012-11-25 21:34:34 -0800 | 
| commit | 0f9cb211ba5db93d488fe6b154138231fdd0e22d (patch) | |
| tree | 293871b042e9ebc49b1d783f1b110eef541ddc97 /arch/mips/kernel/setup.c | |
| parent | 007108a2279123ad6639b6c653ad1a731febb60f (diff) | |
| parent | 9489e9dcae718d5fde988e4a684a0f55b5f94d17 (diff) | |
| download | olio-linux-3.10-0f9cb211ba5db93d488fe6b154138231fdd0e22d.tar.xz olio-linux-3.10-0f9cb211ba5db93d488fe6b154138231fdd0e22d.zip  | |
Merge tag 'v3.7-rc7' into next/cleanup
Merging in mainline back to next/cleanup since it has collected a few
conflicts between fixes going upstream and some of the cleanup patches.
Git doesn't auto-resolve some of them, and they're mostly noise so let's
take care of it locally.
Conflicts are in:
	arch/arm/mach-omap2/omap_hwmod_44xx_data.c
	arch/arm/plat-omap/i2c.c
	drivers/video/omap2/dss/dss.c
Signed-off-by: Olof Johansson <olof@lixom.net>
Diffstat (limited to 'arch/mips/kernel/setup.c')
| -rw-r--r-- | arch/mips/kernel/setup.c | 26 | 
1 files changed, 20 insertions, 6 deletions
diff --git a/arch/mips/kernel/setup.c b/arch/mips/kernel/setup.c index a53f8ec37aa..290dc6a1d7a 100644 --- a/arch/mips/kernel/setup.c +++ b/arch/mips/kernel/setup.c @@ -79,7 +79,7 @@ static struct resource data_resource = { .name = "Kernel data", };  void __init add_memory_region(phys_t start, phys_t size, long type)  {  	int x = boot_mem_map.nr_map; -	struct boot_mem_map_entry *prev = boot_mem_map.map + x - 1; +	int i;  	/* Sanity check */  	if (start + size < start) { @@ -88,15 +88,29 @@ void __init add_memory_region(phys_t start, phys_t size, long type)  	}  	/* -	 * Try to merge with previous entry if any.  This is far less than -	 * perfect but is sufficient for most real world cases. +	 * Try to merge with existing entry, if any.  	 */ -	if (x && prev->addr + prev->size == start && prev->type == type) { -		prev->size += size; +	for (i = 0; i < boot_mem_map.nr_map; i++) { +		struct boot_mem_map_entry *entry = boot_mem_map.map + i; +		unsigned long top; + +		if (entry->type != type) +			continue; + +		if (start + size < entry->addr) +			continue;			/* no overlap */ + +		if (entry->addr + entry->size < start) +			continue;			/* no overlap */ + +		top = max(entry->addr + entry->size, start + size); +		entry->addr = min(entry->addr, start); +		entry->size = top - entry->addr; +  		return;  	} -	if (x == BOOT_MEM_MAP_MAX) { +	if (boot_mem_map.nr_map == BOOT_MEM_MAP_MAX) {  		pr_err("Ooops! Too many entries in the memory map!\n");  		return;  	}  |