summaryrefslogtreecommitdiff
path: root/board/engicam/common/board.c
diff options
context:
space:
mode:
Diffstat (limited to 'board/engicam/common/board.c')
-rw-r--r--board/engicam/common/board.c28
1 files changed, 27 insertions, 1 deletions
diff --git a/board/engicam/common/board.c b/board/engicam/common/board.c
index 8a83608..af4ef28 100644
--- a/board/engicam/common/board.c
+++ b/board/engicam/common/board.c
@@ -15,7 +15,7 @@
DECLARE_GLOBAL_DATA_PTR;
#ifdef CONFIG_ENV_IS_IN_MMC
-void mmc_late_init(void)
+static void mmc_late_init(void)
{
char cmd[32];
char mmcblk[32];
@@ -32,6 +32,32 @@ void mmc_late_init(void)
}
#endif
+int board_late_init(void)
+{
+ switch ((imx6_src_get_boot_mode() & IMX6_BMODE_MASK) >>
+ IMX6_BMODE_SHIFT) {
+ case IMX6_BMODE_SD:
+ case IMX6_BMODE_ESD:
+ case IMX6_BMODE_MMC:
+ case IMX6_BMODE_EMMC:
+#ifdef CONFIG_ENV_IS_IN_MMC
+ mmc_late_init();
+#endif
+ setenv("modeboot", "mmcboot");
+ break;
+ case IMX6_BMODE_NAND:
+ setenv("modeboot", "nandboot");
+ break;
+ default:
+ setenv("modeboot", "");
+ break;
+ }
+
+ setenv_fdt_file();
+
+ return 0;
+}
+
int board_init(void)
{
/* Address of boot parameters */