mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-17 10:24:49 +00:00

I'm trying to use dfu-util for bootstrapping an stm32mp board. It mostly works fine, but something goes horribly wrong as soon as I make use of the ability to run arbitrary u-boot shell commands. The shell commands themselves work fine, but the heuristic "dfu_alt_info may have changed, we have to reinit" seems to cause the board and/or my host machine to go into some bad state, and further dfu-util commands fail. U-Boot already has a mechanism whereby C code can be told about changes to specific environment variables. So instead of always doing re-init, add a hook to the dfu_alt_info variable so that we only do set dfu_reinit_needed if the commands actually did modify that variable. Signed-off-by: Rasmus Villemoes <rasmus.villemoes@prevas.dk> Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com> Link: https://lore.kernel.org/r/20240911133900.1444083-1-rasmus.villemoes@prevas.dk Signed-off-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
103 lines
2.1 KiB
C
103 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* (C) Copyright 2012
|
|
* Joe Hershberger, National Instruments, joe.hershberger@ni.com
|
|
*/
|
|
|
|
#ifndef __ENV_CALLBACK_H__
|
|
#define __ENV_CALLBACK_H__
|
|
|
|
#include <config.h>
|
|
#include <env_flags.h>
|
|
#include <linker_lists.h>
|
|
#include <search.h>
|
|
|
|
#define ENV_CALLBACK_VAR ".callbacks"
|
|
|
|
/* Board configs can define additional static callback bindings */
|
|
#ifndef CFG_ENV_CALLBACK_LIST_STATIC
|
|
#define CFG_ENV_CALLBACK_LIST_STATIC
|
|
#endif
|
|
|
|
#ifdef CONFIG_SILENT_CONSOLE
|
|
#define SILENT_CALLBACK "silent:silent,"
|
|
#else
|
|
#define SILENT_CALLBACK
|
|
#endif
|
|
|
|
#ifdef CONFIG_REGEX
|
|
#define ENV_DOT_ESCAPE "\\"
|
|
#else
|
|
#define ENV_DOT_ESCAPE
|
|
#endif
|
|
|
|
#ifdef CONFIG_CMD_DNS
|
|
#define DNS_CALLBACK "dnsip:dnsip,"
|
|
#else
|
|
#define DNS_CALLBACK
|
|
#endif
|
|
|
|
#ifdef CONFIG_NET
|
|
#define NET_CALLBACKS \
|
|
"bootfile:bootfile," \
|
|
"ipaddr:ipaddr," \
|
|
"gatewayip:gatewayip," \
|
|
"netmask:netmask," \
|
|
"serverip:serverip," \
|
|
"nvlan:nvlan," \
|
|
"vlan:vlan," \
|
|
DNS_CALLBACK \
|
|
"eth" ETHADDR_WILDCARD "addr:ethaddr,"
|
|
#else
|
|
#define NET_CALLBACKS
|
|
#endif
|
|
|
|
#ifdef CONFIG_IPV6
|
|
#define NET6_CALLBACKS \
|
|
"ip6addr:ip6addr," \
|
|
"serverip6:serverip6," \
|
|
"gatewayip6:gatewayip6,"
|
|
#else
|
|
#define NET6_CALLBACKS
|
|
#endif
|
|
|
|
#ifdef CONFIG_BOOTSTD_FULL
|
|
#define BOOTSTD_CALLBACK \
|
|
"bootmeths:bootmeths," \
|
|
"bootargs:bootargs,"
|
|
#else
|
|
#define BOOTSTD_CALLBACK
|
|
#endif
|
|
|
|
#ifdef CONFIG_DFU
|
|
#define DFU_CALLBACK "dfu_alt_info:dfu_alt_info,"
|
|
#else
|
|
#define DFU_CALLBACK
|
|
#endif
|
|
|
|
/*
|
|
* This list of callback bindings is static, but may be overridden by defining
|
|
* a new association in the ".callbacks" environment variable.
|
|
*/
|
|
#define ENV_CALLBACK_LIST_STATIC ENV_DOT_ESCAPE ENV_CALLBACK_VAR ":callbacks," \
|
|
ENV_DOT_ESCAPE ENV_FLAGS_VAR ":flags," \
|
|
"baudrate:baudrate," \
|
|
NET_CALLBACKS \
|
|
NET6_CALLBACKS \
|
|
BOOTSTD_CALLBACK \
|
|
DFU_CALLBACK \
|
|
"loadaddr:loadaddr," \
|
|
SILENT_CALLBACK \
|
|
"stdin:console,stdout:console,stderr:console," \
|
|
"serial#:serialno," \
|
|
CFG_ENV_CALLBACK_LIST_STATIC
|
|
|
|
#ifndef CONFIG_SPL_BUILD
|
|
void env_callback_init(struct env_entry *var_entry);
|
|
#else
|
|
static inline void env_callback_init(struct env_entry *var_entry)
|
|
{
|
|
}
|
|
#endif
|
|
|
|
#endif /* __ENV_CALLBACK_H__ */
|