mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-12 07:57:21 +00:00
676f682bad
Code for changing boot source is platform generic and can be used by any P1* and P2* compatible RDB board. Not only by boards which use config header file p1_p2_rdb_pc.h. So move this code from p1_p2_rdb_pc.h to p1_p2_bootsrc.h and cleanup macros for generating boot source env variables in CONFIG_EXTRA_ENV_SETTINGS. This allows to use code for resetting board and rebooting to other boot source also by other boards in future. Signed-off-by: Pali Rohár <pali@kernel.org>
59 lines
1.8 KiB
C
59 lines
1.8 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_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_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
|