Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 79df1b69 authored by Mike Frysinger's avatar Mike Frysinger
Browse files

Blackfin: override default uClinux MTD addr/size



Due to a processor anomaly (05000263 to be exact), most Blackfin parts
cannot keep the embedded filesystem image directly after the kernel in
RAM.  Instead, the filesystem needs to be relocated to the end of memory.
As such, we need to tweak the map addr/size during boot for Blackfin
systems.

Signed-off-by: default avatarMike Frysinger <vapier@gentoo.org>
parent 37082511
Loading
Loading
Loading
Loading
+7 −4
Original line number Diff line number Diff line
@@ -18,9 +18,12 @@
#include <linux/tty.h>
#include <linux/pfn.h>

#ifdef CONFIG_MTD_UCLINUX
#include <linux/mtd/map.h>
#include <linux/ext2_fs.h>
#include <linux/cramfs_fs.h>
#include <linux/romfs_fs.h>
#endif

#include <asm/cplb.h>
#include <asm/cacheflush.h>
@@ -45,6 +48,7 @@ EXPORT_SYMBOL(_ramend);
EXPORT_SYMBOL(reserved_mem_dcache_on);

#ifdef CONFIG_MTD_UCLINUX
extern struct map_info uclinux_ram_map;
unsigned long memory_mtd_end, memory_mtd_start, mtd_size;
unsigned long _ebss;
EXPORT_SYMBOL(memory_mtd_end);
@@ -535,10 +539,9 @@ static __init void memory_setup(void)
	}

	/* Relocate MTD image to the top of memory after the uncached memory area */
	dma_memcpy((char *)memory_end, _end, mtd_size);

	memory_mtd_start = memory_end;
	_ebss = memory_mtd_start;	/* define _ebss for compatible */
	uclinux_ram_map.phys = memory_mtd_start = memory_end;
	uclinux_ram_map.size = mtd_size;
	dma_memcpy((void *)uclinux_ram_map.phys, _end, uclinux_ram_map.size);
#endif				/* CONFIG_MTD_UCLINUX */

#if (defined(CONFIG_BFIN_ICACHE) && ANOMALY_05000263)