| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- From ee46d05eefefb0fb40b5682b4f6f3876b496044b Mon Sep 17 00:00:00 2001
- From: John Crispin <[email protected]>
- Date: Sun, 16 Mar 2014 04:40:48 +0000
- Subject: [PATCH 107/133] MIPS: ralink: allow manual memory override
- RT5350 relies on the bootloader setting up the memc correctly.
- On sme boards the setup is incorrect leading to 32 MB being available but only 16 being recognized. Allow these boards to manually override the memory range
- .
- Signed-off-by: John Crispin <[email protected]>
- ---
- arch/mips/ralink/of.c | 16 +++++++++++++++-
- 1 file changed, 15 insertions(+), 1 deletion(-)
- --- a/arch/mips/ralink/of.c
- +++ b/arch/mips/ralink/of.c
- @@ -77,6 +77,17 @@ void __init device_tree_init(void)
- //free_bootmem(base, size);
- }
-
- +static int memory_dtb;
- +
- +static int __init early_init_dt_find_memory(unsigned long node, const char *uname,
- + int depth, void *data)
- +{
- + if (depth == 1 && !strcmp(uname, "memory@0"))
- + memory_dtb = 1;
- +
- + return 0;
- +}
- +
- void __init plat_mem_setup(void)
- {
- set_io_port_base(KSEG1);
- @@ -87,7 +98,10 @@ void __init plat_mem_setup(void)
- */
- __dt_setup_arch(&__dtb_start);
-
- - if (soc_info.mem_size)
- + of_scan_flat_dt(early_init_dt_find_memory, NULL);
- + if (memory_dtb)
- + of_scan_flat_dt(early_init_dt_scan_memory, NULL);
- + else if (soc_info.mem_size)
- add_memory_region(soc_info.mem_base, soc_info.mem_size * SZ_1M,
- BOOT_MEM_RAM);
- else
|