Skip to content
Snippets Groups Projects
Commit 0239c2fb authored by Marek Vasut's avatar Marek Vasut Committed by Albert ARIBAUD
Browse files

i.MX28: Improve passing of data from SPL to U-Boot


Pass memory size from SPL via structure located in SRAM instead of SCRATCH
registers. This allows passing more data about boot from SPL to U-Boot, like the
boot mode pads configuration.

Signed-off-by: default avatarMarek Vasut <marex@denx.de>
Cc: Detlev Zundel <dzu@denx.de>
Cc: Fabio Estevam <fabio.estevam@freescale.com>
Cc: Stefano Babic <sbabic@denx.de>
Cc: Wolfgang Denk <wd@denx.de>
parent 9a0f98d3
No related branches found
No related tags found
No related merge requests found
...@@ -279,22 +279,16 @@ void imx_get_mac_from_fuse(int dev_id, unsigned char *mac) ...@@ -279,22 +279,16 @@ void imx_get_mac_from_fuse(int dev_id, unsigned char *mac)
int mx28_dram_init(void) int mx28_dram_init(void)
{ {
struct mx28_digctl_regs *digctl_regs = struct mx28_spl_data *data = (struct mx28_spl_data *)
(struct mx28_digctl_regs *)MXS_DIGCTL_BASE; ((CONFIG_SYS_TEXT_BASE - sizeof(struct mx28_spl_data)) & ~0xf);
uint32_t sz[2];
sz[0] = readl(&digctl_regs->hw_digctl_scratch0); if (data->mem_dram_size == 0) {
sz[1] = readl(&digctl_regs->hw_digctl_scratch1);
if (sz[0] != sz[1]) {
printf("MX28:\n" printf("MX28:\n"
"Error, the RAM size in HW_DIGCTRL_SCRATCH0 and\n" "Error, the RAM size passed up from SPL is 0!\n");
"HW_DIGCTRL_SCRATCH1 is not the same. Please\n"
"verify these two registers contain valid RAM size!\n");
hang(); hang();
} }
gd->ram_size = sz[0]; gd->ram_size = data->mem_dram_size;
return 0; return 0;
} }
......
...@@ -37,5 +37,6 @@ static inline void mx28_power_wait_pswitch(void) { } ...@@ -37,5 +37,6 @@ static inline void mx28_power_wait_pswitch(void) { }
#endif #endif
void mx28_mem_init(void); void mx28_mem_init(void);
uint32_t mx28_mem_get_size(void);
#endif /* __M28_INIT_H__ */ #endif /* __M28_INIT_H__ */
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include <asm/io.h> #include <asm/io.h>
#include <asm/arch/iomux-mx28.h> #include <asm/arch/iomux-mx28.h>
#include <asm/arch/imx-regs.h> #include <asm/arch/imx-regs.h>
#include <asm/arch/sys_proto.h>
#include "mx28_init.h" #include "mx28_init.h"
...@@ -49,9 +50,15 @@ void early_delay(int delay) ...@@ -49,9 +50,15 @@ void early_delay(int delay)
void mx28_common_spl_init(const iomux_cfg_t *iomux_setup, void mx28_common_spl_init(const iomux_cfg_t *iomux_setup,
const unsigned int iomux_size) const unsigned int iomux_size)
{ {
struct mx28_spl_data *data = (struct mx28_spl_data *)
((CONFIG_SYS_TEXT_BASE - sizeof(struct mx28_spl_data)) & ~0xf);
mxs_iomux_setup_multiple_pads(iomux_setup, iomux_size); mxs_iomux_setup_multiple_pads(iomux_setup, iomux_size);
mx28_power_init(); mx28_power_init();
mx28_mem_init(); mx28_mem_init();
data->mem_dram_size = mx28_mem_get_size();
mx28_power_wait_pswitch(); mx28_power_wait_pswitch();
} }
......
...@@ -175,10 +175,8 @@ void mx28_mem_setup_vddd(void) ...@@ -175,10 +175,8 @@ void mx28_mem_setup_vddd(void)
&power_regs->hw_power_vdddctrl); &power_regs->hw_power_vdddctrl);
} }
void mx28_mem_get_size(void) uint32_t mx28_mem_get_size(void)
{ {
struct mx28_digctl_regs *digctl_regs =
(struct mx28_digctl_regs *)MXS_DIGCTL_BASE;
uint32_t sz, da; uint32_t sz, da;
uint32_t *vt = (uint32_t *)0x20; uint32_t *vt = (uint32_t *)0x20;
/* The following is "subs pc, r14, #4", used as return from DABT. */ /* The following is "subs pc, r14, #4", used as return from DABT. */
...@@ -189,11 +187,11 @@ void mx28_mem_get_size(void) ...@@ -189,11 +187,11 @@ void mx28_mem_get_size(void)
vt[4] = data_abort_memdetect_handler; vt[4] = data_abort_memdetect_handler;
sz = get_ram_size((long *)PHYS_SDRAM_1, PHYS_SDRAM_1_SIZE); sz = get_ram_size((long *)PHYS_SDRAM_1, PHYS_SDRAM_1_SIZE);
writel(sz, &digctl_regs->hw_digctl_scratch0);
writel(sz, &digctl_regs->hw_digctl_scratch1);
/* Restore the old DABT handler. */ /* Restore the old DABT handler. */
vt[4] = da; vt[4] = da;
return sz;
} }
void mx28_mem_init(void) void mx28_mem_init(void)
...@@ -241,6 +239,4 @@ void mx28_mem_init(void) ...@@ -241,6 +239,4 @@ void mx28_mem_init(void)
early_delay(10000); early_delay(10000);
mx28_mem_setup_cpu_and_hbus(); mx28_mem_setup_cpu_and_hbus();
mx28_mem_get_size();
} }
...@@ -39,6 +39,10 @@ void mx28_common_spl_init(const iomux_cfg_t *iomux_setup, ...@@ -39,6 +39,10 @@ void mx28_common_spl_init(const iomux_cfg_t *iomux_setup,
const unsigned int iomux_size); const unsigned int iomux_size);
#endif #endif
struct mx28_spl_data {
uint32_t mem_dram_size;
};
int mx28_dram_init(void); int mx28_dram_init(void);
#endif /* __MX28_H__ */ #endif /* __MX28_H__ */
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment