forked from mirror/openwrt
The most relevant change is the removal of the empty board_init() functions by u-boot/u-boot@70a4d1fa1d, which makes many patches not apply anymore and also requires most board defconfigs to be updated by adding "# CONFIG_BOARD_INIT is not set" to them. Also some config symbols have been renamed and downstream boards had to be adapted accordingly: u-boot/u-boot@0fd9a3480a ("env: Rename OVERWRITE_ETHADDR_ONCE to ENV_OVERWRITE_ETHADDR_ONCE") u-boot/u-boot@5fb88fa725 ("env: Rename SYS_REDUNDAND_ENVIRONMENT to ENV_REDUNDANT") u-boot/u-boot@123682c765 ("env: Rename SYS_RELOC_GD_ENV_ADDR to ENV_RELOC_GD_ENV_ADDR") u-boot/u-boot@0f44d5549e ("env: Rename SYS_MMC_ENV_DEV to ENV_MMC_DEVICE_INDEX") u-boot/u-boot@31617b880a ("env: Rename SYS_MMC_ENV_PART to ENV_MMC_EMMC_HW_PARTITION") u-boot/u-boot@ffc4914703 ("env: Rename ENV_MMC_PARTITION to ENV_MMC_SW_PARTITION") u-boot/u-boot@fb5235239a ("env: Rename DEFAULT_ENV_FILE to ENV_DEFAULT_ENV_TEXT_FILE") (also renamed USE_DEFAULT_ENV_FILE to USE_ENV_DEFAULT_ENV_TEXT_FILE) Remove upstreamed patches: * 001-mtd-spinand-winbond-add-Winbond-W25N04KV-flash-suppo.patch u-boot/u-boot@fe37fb8214 * 002-mtd-spinand-gigadevice-sync-supported-chips-with-lin.patch u-boot/u-boot@506ceddffd * 003-net-mediatek-correct-the-AN8855-TPID-value-in-port-i.patch u-boot/u-boot@70db2be9fb * 004-01-serial-mediatek-fix-register-names-and-offsets.patch u-boot/u-boot@6e15d3f91a * 004-02-serial-mediatek-enable-baudrate-accuracy-compensatio.patch u-boot/u-boot@6952209ef2 * 005-clk-mediatek-add-dummy-clk-enable-disable-ops-for-ap.patch u-boot/u-boot@1bf2121297 * 006-env-Fix-possible-out-of-bound-access-in-env_do_env_s.patch u-boot/u-boot@0ffd456516 * 130-01-env-mtd-add-the-missing-put_mtd_device.patch u-boot/u-boot@39ae954b04 * 130-02-env-mtd-initialize-saved_buf-pointer.patch u-boot/u-boot@7e842bd331 * 170-cmd-bootmenu-permit-to-select-bootmenu-entry-with.patch u-boot/u-boot@8c986521c3 Signed-off-by: Daniel Golle <daniel@makrotopia.org>
154 lines
4.1 KiB
Diff
154 lines
4.1 KiB
Diff
--- a/board/mediatek/mt7622/mt7622_rfb.c
|
|
+++ b/board/mediatek/mt7622/mt7622_rfb.c
|
|
@@ -10,7 +10,9 @@
|
|
#include <env.h>
|
|
#include <init.h>
|
|
#include <asm/global_data.h>
|
|
+#include <asm/io.h>
|
|
#include <linux/delay.h>
|
|
+#include <linux/libfdt.h>
|
|
|
|
#ifndef CONFIG_RESET_BUTTON_LABEL
|
|
#define CONFIG_RESET_BUTTON_LABEL "reset"
|
|
@@ -21,8 +23,46 @@
|
|
#include <nmbm/nmbm.h>
|
|
#include <nmbm/nmbm-mtd.h>
|
|
|
|
+#define MT7622_TOPRGUSTRAP_PAR 0x10212060
|
|
+#define MT7622_BOOT_SEQ_MASK 0x18
|
|
+#define MT7622_BOOT_SEQ_SHIFT 3
|
|
+#define MT7622_BOOT_SEQ_NOR_EMMC_SDXC 0x0
|
|
+#define MT7622_BOOT_SEQ_SPI_NAND_EMMC_SDXC 0x1
|
|
+#define MT7622_BOOT_SEQ_NAND_EMMC_SDXC 0x2
|
|
+#define MT7622_BOOT_SEQ_SDXC_EMMC_NAND 0x3
|
|
+
|
|
+#define MT7622_GPIO_MODE0 0x10211300
|
|
+#define MT7622_GPIO_NAND_MODE_MASK 0x00f00000
|
|
+#define MT7622_GPIO_NAND_MODE_SHIFT 20
|
|
+#define MT7622_GPIO_NAND_MODE_EMMC 0x2
|
|
+#define MT7622_GPIO_RGMII_MODE_MASK 0x0000f000
|
|
+#define MT7622_GPIO_RGMII_MODE_SHIFT 12
|
|
+#define MT7622_GPIO_RGMII_MODE_SDCX 0x2
|
|
+#define MT7622_GPIO_SPI_MODE_MASK 0x00000f00
|
|
+#define MT7622_GPIO_SPI_MODE_SHIFT 8
|
|
+#define MT7622_GPIO_SPI_MODE_NAND 0x2
|
|
+
|
|
+#define MT7622_MSDC_INT 0x1124000C
|
|
+#define MT7622_MSDC_INT_BD_CS_ERR 0x200
|
|
+
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
+static int gpio_mode0;
|
|
+static int msdc_int;
|
|
+
|
|
+int board_init(void)
|
|
+{
|
|
+ /*
|
|
+ * Save content of GPIO_MODE0 as left behind by the BootROM.
|
|
+ * Also grab MSDC1 INT status to see if BootROM has been reading
|
|
+ * from SD card.
|
|
+ * Together this will allow to infer the device used for booting.
|
|
+ */
|
|
+ gpio_mode0 = readl(MT7622_GPIO_MODE0);
|
|
+ msdc_int = readl(MT7622_MSDC_INT);
|
|
+ return 0;
|
|
+}
|
|
+
|
|
int board_late_init(void)
|
|
{
|
|
struct udevice *dev;
|
|
@@ -77,3 +117,84 @@ int board_nmbm_init(void)
|
|
|
|
return 0;
|
|
}
|
|
+
|
|
+int ft_system_setup(void *blob, struct bd_info *bd)
|
|
+{
|
|
+ bool pinctrl_set_mmc = false;
|
|
+ bool pinctrl_set_snfi = false;
|
|
+ bool pinctrl_set_emmc = false;
|
|
+ bool msdc_bd_cs_err = false;
|
|
+
|
|
+ const u32 *media_handle_p;
|
|
+ int chosen, len, ret;
|
|
+ const char *media;
|
|
+ u32 media_handle, strap;
|
|
+
|
|
+ if ((gpio_mode0 & MT7622_GPIO_RGMII_MODE_MASK) >>
|
|
+ MT7622_GPIO_RGMII_MODE_SHIFT == MT7622_GPIO_RGMII_MODE_SDCX)
|
|
+ pinctrl_set_mmc = true;
|
|
+
|
|
+ if ((gpio_mode0 & MT7622_GPIO_SPI_MODE_MASK) >>
|
|
+ MT7622_GPIO_SPI_MODE_SHIFT == MT7622_GPIO_SPI_MODE_NAND)
|
|
+ pinctrl_set_snfi = true;
|
|
+
|
|
+ if ((gpio_mode0 & MT7622_GPIO_NAND_MODE_MASK) >>
|
|
+ MT7622_GPIO_NAND_MODE_SHIFT == MT7622_GPIO_NAND_MODE_EMMC)
|
|
+ pinctrl_set_emmc = true;
|
|
+
|
|
+ if (msdc_int & MT7622_MSDC_INT_BD_CS_ERR)
|
|
+ msdc_bd_cs_err = true;
|
|
+
|
|
+ strap = readl(MT7622_TOPRGUSTRAP_PAR);
|
|
+ strap &= MT7622_BOOT_SEQ_MASK;
|
|
+ strap >>= MT7622_BOOT_SEQ_SHIFT;
|
|
+ switch (strap) {
|
|
+ case MT7622_BOOT_SEQ_NOR_EMMC_SDXC:
|
|
+ if (!pinctrl_set_emmc)
|
|
+ media = "rootdisk-nor";
|
|
+ else if (pinctrl_set_mmc)
|
|
+ media = "rootdisk-emmc";
|
|
+ else
|
|
+ media = "rootdisk-sd";
|
|
+ break
|
|
+ ;;
|
|
+ case MT7622_BOOT_SEQ_SPI_NAND_EMMC_SDXC:
|
|
+ if (pinctrl_set_snfi)
|
|
+ media = "rootdisk-snfi";
|
|
+ else if (pinctrl_set_emmc)
|
|
+ media = "rootdisk-emmc";
|
|
+ else
|
|
+ media = "rootdisk-sd";
|
|
+ break
|
|
+ ;;
|
|
+ case MT7622_BOOT_SEQ_NAND_EMMC_SDXC:
|
|
+ case MT7622_BOOT_SEQ_SDXC_EMMC_NAND:
|
|
+ if (!pinctrl_set_emmc && pinctrl_set_mmc)
|
|
+ media = "rootdisk-nand";
|
|
+ else if (pinctrl_set_emmc)
|
|
+ media = "rootdisk-emmc";
|
|
+ else
|
|
+ media = "rootdisk-sd";
|
|
+ break
|
|
+ ;;
|
|
+ }
|
|
+
|
|
+ chosen = fdt_path_offset(blob, "/chosen");
|
|
+ if (chosen <= 0)
|
|
+ return 0;
|
|
+
|
|
+ media_handle_p = fdt_getprop(blob, chosen, media, &len);
|
|
+ if (media_handle_p <= 0 || len != 4)
|
|
+ return 0;
|
|
+
|
|
+ media_handle = *media_handle_p;
|
|
+ ret = fdt_setprop(blob, chosen, "rootdisk", &media_handle, sizeof(media_handle));
|
|
+ if (ret) {
|
|
+ printf("cannot set media phandle %s as rootdisk /chosen node\n", media);
|
|
+ return ret;
|
|
+ }
|
|
+
|
|
+ printf("set /chosen/rootdisk to bootrom media: %s (phandle 0x%08x)\n", media, fdt32_to_cpu(media_handle));
|
|
+
|
|
+ return 0;
|
|
+}
|
|
--- a/configs/mt7622_rfb_defconfig
|
|
+++ b/configs/mt7622_rfb_defconfig
|
|
@@ -16,7 +16,6 @@ CONFIG_DEFAULT_FDT_FILE="mt7622-rfb"
|
|
CONFIG_SYS_PBSIZE=1049
|
|
CONFIG_LOGLEVEL=7
|
|
CONFIG_LOG=y
|
|
-# CONFIG_BOARD_INIT is not set
|
|
CONFIG_SYS_PROMPT="MT7622> "
|
|
CONFIG_SYS_MAXARGS=8
|
|
CONFIG_CMD_BOOTMENU=y
|