提交 2f812c0b 编写于 作者: R Robin Getz 提交者: Mike Frysinger

Blackfin: clean up early memory setup code

Remove code duplication, and only print out memory warnings when they are
an actual problem.
Signed-off-by: NRobin Getz <robin.getz@analog.com>
Signed-off-by: NMike Frysinger <vapier@gentoo.org>
上级 a7690940
...@@ -511,6 +511,7 @@ static __init void memory_setup(void) ...@@ -511,6 +511,7 @@ static __init void memory_setup(void)
#ifdef CONFIG_MTD_UCLINUX #ifdef CONFIG_MTD_UCLINUX
unsigned long mtd_phys = 0; unsigned long mtd_phys = 0;
#endif #endif
unsigned long max_mem;
_rambase = (unsigned long)_stext; _rambase = (unsigned long)_stext;
_ramstart = (unsigned long)_end; _ramstart = (unsigned long)_end;
...@@ -520,7 +521,22 @@ static __init void memory_setup(void) ...@@ -520,7 +521,22 @@ static __init void memory_setup(void)
panic("DMA region exceeds memory limit: %lu.", panic("DMA region exceeds memory limit: %lu.",
_ramend - _ramstart); _ramend - _ramstart);
} }
memory_end = _ramend - DMA_UNCACHED_REGION; max_mem = memory_end = _ramend - DMA_UNCACHED_REGION;
#if (defined(CONFIG_BFIN_EXTMEM_ICACHEABLE) && ANOMALY_05000263)
/* Due to a Hardware Anomaly we need to limit the size of usable
* instruction memory to max 60MB, 56 if HUNT_FOR_ZERO is on
* 05000263 - Hardware loop corrupted when taking an ICPLB exception
*/
# if (defined(CONFIG_DEBUG_HUNT_FOR_ZERO))
if (max_mem >= 56 * 1024 * 1024)
max_mem = 56 * 1024 * 1024;
# else
if (max_mem >= 60 * 1024 * 1024)
max_mem = 60 * 1024 * 1024;
# endif /* CONFIG_DEBUG_HUNT_FOR_ZERO */
#endif /* ANOMALY_05000263 */
#ifdef CONFIG_MPU #ifdef CONFIG_MPU
/* Round up to multiple of 4MB */ /* Round up to multiple of 4MB */
...@@ -549,22 +565,16 @@ static __init void memory_setup(void) ...@@ -549,22 +565,16 @@ static __init void memory_setup(void)
# if defined(CONFIG_ROMFS_FS) # if defined(CONFIG_ROMFS_FS)
if (((unsigned long *)mtd_phys)[0] == ROMSB_WORD0 if (((unsigned long *)mtd_phys)[0] == ROMSB_WORD0
&& ((unsigned long *)mtd_phys)[1] == ROMSB_WORD1) && ((unsigned long *)mtd_phys)[1] == ROMSB_WORD1) {
mtd_size = mtd_size =
PAGE_ALIGN(be32_to_cpu(((unsigned long *)mtd_phys)[2])); PAGE_ALIGN(be32_to_cpu(((unsigned long *)mtd_phys)[2]));
# if (defined(CONFIG_BFIN_EXTMEM_ICACHEABLE) && ANOMALY_05000263)
/* Due to a Hardware Anomaly we need to limit the size of usable /* ROM_FS is XIP, so if we found it, we need to limit memory */
* instruction memory to max 60MB, 56 if HUNT_FOR_ZERO is on if (memory_end > max_mem) {
* 05000263 - Hardware loop corrupted when taking an ICPLB exception pr_info("Limiting kernel memory to %liMB due to anomaly 05000263\n", max_mem >> 20);
*/ memory_end = max_mem;
# if (defined(CONFIG_DEBUG_HUNT_FOR_ZERO)) }
if (memory_end >= 56 * 1024 * 1024) }
memory_end = 56 * 1024 * 1024;
# else
if (memory_end >= 60 * 1024 * 1024)
memory_end = 60 * 1024 * 1024;
# endif /* CONFIG_DEBUG_HUNT_FOR_ZERO */
# endif /* ANOMALY_05000263 */
# endif /* CONFIG_ROMFS_FS */ # endif /* CONFIG_ROMFS_FS */
/* Since the default MTD_UCLINUX has no magic number, we just blindly /* Since the default MTD_UCLINUX has no magic number, we just blindly
...@@ -586,20 +596,14 @@ static __init void memory_setup(void) ...@@ -586,20 +596,14 @@ static __init void memory_setup(void)
} }
#endif /* CONFIG_MTD_UCLINUX */ #endif /* CONFIG_MTD_UCLINUX */
#if (defined(CONFIG_BFIN_EXTMEM_ICACHEABLE) && ANOMALY_05000263) /* We need lo limit memory, since everything could have a text section
/* Due to a Hardware Anomaly we need to limit the size of usable * of userspace in it, and expose anomaly 05000263. If the anomaly
* instruction memory to max 60MB, 56 if HUNT_FOR_ZERO is on * doesn't exist, or we don't need to - then dont.
* 05000263 - Hardware loop corrupted when taking an ICPLB exception
*/ */
#if (defined(CONFIG_DEBUG_HUNT_FOR_ZERO)) if (memory_end > max_mem) {
if (memory_end >= 56 * 1024 * 1024) pr_info("Limiting kernel memory to %liMB due to anomaly 05000263\n", max_mem >> 20);
memory_end = 56 * 1024 * 1024; memory_end = max_mem;
#else }
if (memory_end >= 60 * 1024 * 1024)
memory_end = 60 * 1024 * 1024;
#endif /* CONFIG_DEBUG_HUNT_FOR_ZERO */
printk(KERN_NOTICE "Warning: limiting memory to %liMB due to hardware anomaly 05000263\n", memory_end >> 20);
#endif /* ANOMALY_05000263 */
#ifdef CONFIG_MPU #ifdef CONFIG_MPU
page_mask_nelts = ((_ramend >> PAGE_SHIFT) + 31) / 32; page_mask_nelts = ((_ramend >> PAGE_SHIFT) + 31) / 32;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册