mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-07 10:48:54 +00:00
61fed3155f
All *boot env commands overrides default boot source location via i2c. After board reset without power off, BootROM then starts booting U-Boot from this specified location instead of the default one. Add new env command defboot which reverts boot location to the default value, which in most cases is configurable by HW DIP switches. And add new env commands norlowerboot, norupperboot, sd2boot to boot from other locations. norlowerboot would instruct BootROM to boot from lower NOR bank, norupperboot from upper NOR bank and sd2boot from SD card with alternative configuration. Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Peng Fan <peng.fan@nxp.com>
79 lines
2.5 KiB
C
79 lines
2.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Copyright 2010-2011 Freescale Semiconductor, Inc.
|
|
* Copyright 2020 NXP
|
|
* Copyright 2022 Pali Rohár <pali@kernel.org>
|
|
*/
|
|
|
|
#include <linux/stringify.h>
|
|
|
|
#if !defined(CONFIG_SYS_SPD_BUS_NUM) || !defined(CONFIG_SYS_I2C_PCA9557_ADDR)
|
|
#error "CONFIG_SYS_SPD_BUS_NUM and CONFIG_SYS_I2C_PCA9557_ADDR are required"
|
|
#endif
|
|
|
|
#define __BOOTSRC_CMD(src, msk) i2c dev CONFIG_SYS_SPD_BUS_NUM; i2c mw CONFIG_SYS_I2C_PCA9557_ADDR 1 src 1; i2c mw CONFIG_SYS_I2C_PCA9557_ADDR 3 msk 1
|
|
|
|
#define __VAR_CMD(var, cmd) __stringify(var=cmd\0)
|
|
#define __VAR_CMD_RST(var, cmd) __VAR_CMD(var, cmd; reset)
|
|
|
|
#ifdef __SW_NOR_BANK_LO
|
|
#define MAP_NOR_LO_CMD(var, ...) __VAR_CMD(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_NOR_BANK_LO, __SW_NOR_BANK_MASK))
|
|
#else
|
|
#define MAP_NOR_LO_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_NOR_BANK_UP
|
|
#define MAP_NOR_UP_CMD(var, ...) __VAR_CMD(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_NOR_BANK_UP, __SW_NOR_BANK_MASK))
|
|
#else
|
|
#define MAP_NOR_UP_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_NOR
|
|
#define RST_NOR_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_NOR, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_NOR_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_NOR_BANK_LO
|
|
#define RST_NOR_LO_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_NOR_BANK_LO, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_NOR_LO_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_NOR_BANK_UP
|
|
#define RST_NOR_UP_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_NOR_BANK_UP, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_NOR_UP_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_SPI
|
|
#define RST_SPI_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_SPI, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_SPI_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_SD
|
|
#define RST_SD_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_SD, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_SD_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_SD2
|
|
#define RST_SD2_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_SD2, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_SD2_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_NAND
|
|
#define RST_NAND_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_NAND, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_NAND_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#ifdef __SW_BOOT_PCIE
|
|
#define RST_PCIE_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(__SW_BOOT_PCIE, __SW_BOOT_MASK))
|
|
#else
|
|
#define RST_PCIE_CMD(var, ...) ""
|
|
#endif
|
|
|
|
#define RST_DEF_CMD(var, ...) __VAR_CMD_RST(var, __VA_ARGS__ __BOOTSRC_CMD(0x00, 0xff))
|