]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
ARM: imx6q_logic: Fix MMC2 booting
authorAdam Ford <aford173@gmail.com>
Tue, 8 Oct 2019 13:01:12 +0000 (08:01 -0500)
committerStefano Babic <sbabic@denx.de>
Tue, 8 Oct 2019 14:36:37 +0000 (16:36 +0200)
With the reverting of a previous change to spl_boot_device,
this board needs a new solution to determining if we're booting
from MMC1 or MMC2.

This patch creates board_boot_order function which overrides the
standard, and returns not only MMC1, or MMC2, but also can fall
back to NAND or the serial downloader should other boot options
fail.

Signed-off-by: Adam Ford <aford173@gmail.com>
board/logicpd/imx6/imx6logic.c

index 7fb6dc42c67485844948120b2761ef8bf70f527e..4bacd8660a96ea7453c76312529b3fd7e9f4ff54 100644 (file)
@@ -207,6 +207,35 @@ struct fsl_esdhc_cfg usdhc_cfg[] = {
        {USDHC2_BASE_ADDR}  /* Baseboard */
 };
 
+void board_boot_order(u32 *spl_boot_list)
+{
+       struct src *psrc = (struct src *)SRC_BASE_ADDR;
+       unsigned int reg = readl(&psrc->sbmr1) >> 11;
+       /*
+        * Upon reading BOOT_CFG register the following map is done:
+        * Bit 11 and 12 of BOOT_CFG register can determine the current
+        * mmc port
+        * 0x1                  SD1-SOM
+        * 0x2                  SD2-Baseboard
+        */
+
+       reg &= 0x3; /* Only care about bottom 2 bits */
+       switch (reg) {
+       case 0:
+               spl_boot_list[0] = BOOT_DEVICE_MMC1;
+               break;
+       case 1:
+               spl_boot_list[0] = BOOT_DEVICE_MMC2;
+               break;
+       }
+
+       /* If we cannot find a valid MMC/SD card, try NAND */
+       spl_boot_list[1] = BOOT_DEVICE_NAND;
+
+       /* As a last resort, use serial downloader */
+       spl_boot_list[2] = BOOT_DEVICE_BOARD;
+}
+
 int board_mmc_init(bd_t *bis)
 {
        struct src *psrc = (struct src *)SRC_BASE_ADDR;