uboot: mt7622: add rootdisk support from openwrt

Signed-off-by: Tianling Shen <cnsztl@immortalwrt.org>
This commit is contained in:
Tianling Shen
2024-10-06 14:03:26 +08:00
committed by hanwckf
parent 3788274583
commit 84cfb1511b
4 changed files with 293 additions and 2 deletions

View File

@@ -152,4 +152,11 @@ source "board/mediatek/mt7981/Kconfig"
source "board/mediatek/mt7986/Kconfig"
source "board/mediatek/mt7988/Kconfig"
config RESET_BUTTON_LABEL
string "Button to trigger factory reset"
default "reset"
config RESET_BUTTON_SETTLE_DELAY
int "Delay to wait for button to settle"
default 0
endif

View File

@@ -6,26 +6,84 @@
#include <common.h>
#include <config.h>
#include <dm.h>
#include <button.h>
#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"
#endif
#include <mtd.h>
#include <linux/mtd/mtd.h>
#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);
gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100;
return 0;
}
int board_late_init(void)
{
gd->env_valid = 1; //to load environment variable from persistent store
struct udevice *dev;
if (!button_get_by_label(CONFIG_RESET_BUTTON_LABEL, &dev)) {
puts("reset button found\n");
#ifdef CONFIG_RESET_BUTTON_SETTLE_DELAY
if (CONFIG_RESET_BUTTON_SETTLE_DELAY > 0) {
button_get_state(dev);
mdelay(CONFIG_RESET_BUTTON_SETTLE_DELAY);
}
#endif
if (button_get_state(dev) == BUTTON_ON) {
puts("button pushed, resetting environment\n");
gd->env_valid = ENV_INVALID;
}
}
env_relocate();
return 0;
}
@@ -62,3 +120,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;
}