xref: /openbmc/u-boot/include/env_callback.h (revision 68489ed037530ec29fc0bc452ad6e4b0c5db02ec)
1*83d290c5STom Rini /* SPDX-License-Identifier: GPL-2.0+ */
2170ab110SJoe Hershberger /*
3170ab110SJoe Hershberger  * (C) Copyright 2012
4170ab110SJoe Hershberger  * Joe Hershberger, National Instruments, joe.hershberger@ni.com
5170ab110SJoe Hershberger  */
6170ab110SJoe Hershberger 
7170ab110SJoe Hershberger #ifndef __ENV_CALLBACK_H__
8170ab110SJoe Hershberger #define __ENV_CALLBACK_H__
9170ab110SJoe Hershberger 
102598090bSJoe Hershberger #include <env_flags.h>
11170ab110SJoe Hershberger #include <linker_lists.h>
12170ab110SJoe Hershberger #include <search.h>
13170ab110SJoe Hershberger 
14170ab110SJoe Hershberger #define ENV_CALLBACK_VAR ".callbacks"
15170ab110SJoe Hershberger 
16170ab110SJoe Hershberger /* Board configs can define additional static callback bindings */
17170ab110SJoe Hershberger #ifndef CONFIG_ENV_CALLBACK_LIST_STATIC
18170ab110SJoe Hershberger #define CONFIG_ENV_CALLBACK_LIST_STATIC
19170ab110SJoe Hershberger #endif
20170ab110SJoe Hershberger 
21e080d545SJoe Hershberger #ifdef CONFIG_SILENT_CONSOLE
22e080d545SJoe Hershberger #define SILENT_CALLBACK "silent:silent,"
23e080d545SJoe Hershberger #else
24e080d545SJoe Hershberger #define SILENT_CALLBACK
25e080d545SJoe Hershberger #endif
26e080d545SJoe Hershberger 
27c0880485SNikita Kiryanov #ifdef CONFIG_SPLASHIMAGE_GUARD
28c0880485SNikita Kiryanov #define SPLASHIMAGE_CALLBACK "splashimage:splashimage,"
29c0880485SNikita Kiryanov #else
30c0880485SNikita Kiryanov #define SPLASHIMAGE_CALLBACK
31c0880485SNikita Kiryanov #endif
32c0880485SNikita Kiryanov 
33bdf1fe4eSJoe Hershberger #ifdef CONFIG_REGEX
34bdf1fe4eSJoe Hershberger #define ENV_DOT_ESCAPE "\\"
35bdf1fe4eSJoe Hershberger #else
36bdf1fe4eSJoe Hershberger #define ENV_DOT_ESCAPE
37bdf1fe4eSJoe Hershberger #endif
38bdf1fe4eSJoe Hershberger 
39fd305633SJoe Hershberger #ifdef CONFIG_CMD_DNS
40fd305633SJoe Hershberger #define DNS_CALLBACK "dnsip:dnsip,"
41fd305633SJoe Hershberger #else
42fd305633SJoe Hershberger #define DNS_CALLBACK
43fd305633SJoe Hershberger #endif
44fd305633SJoe Hershberger 
453b3ea2c5SMichal Simek #ifdef CONFIG_CMD_NET
46fd305633SJoe Hershberger #define NET_CALLBACKS \
47fd305633SJoe Hershberger 	"bootfile:bootfile," \
48fd305633SJoe Hershberger 	"ipaddr:ipaddr," \
49fd305633SJoe Hershberger 	"gatewayip:gatewayip," \
50fd305633SJoe Hershberger 	"netmask:netmask," \
51fd305633SJoe Hershberger 	"serverip:serverip," \
52fd305633SJoe Hershberger 	"nvlan:nvlan," \
53fd305633SJoe Hershberger 	"vlan:vlan," \
546e0d26c0SJoe Hershberger 	DNS_CALLBACK \
55f7848d90SJoe Hershberger 	"eth" ETHADDR_WILDCARD "addr:ethaddr,"
56fd305633SJoe Hershberger #else
57fd305633SJoe Hershberger #define NET_CALLBACKS
58fd305633SJoe Hershberger #endif
59fd305633SJoe Hershberger 
60170ab110SJoe Hershberger /*
61170ab110SJoe Hershberger  * This list of callback bindings is static, but may be overridden by defining
62170ab110SJoe Hershberger  * a new association in the ".callbacks" environment variable.
63170ab110SJoe Hershberger  */
64bdf1fe4eSJoe Hershberger #define ENV_CALLBACK_LIST_STATIC ENV_DOT_ESCAPE ENV_CALLBACK_VAR ":callbacks," \
65bdf1fe4eSJoe Hershberger 	ENV_DOT_ESCAPE ENV_FLAGS_VAR ":flags," \
6632057717SJoe Hershberger 	"baudrate:baudrate," \
67fd305633SJoe Hershberger 	NET_CALLBACKS \
681cf0a8b2SJoe Hershberger 	"loadaddr:loadaddr," \
69e080d545SJoe Hershberger 	SILENT_CALLBACK \
70c0880485SNikita Kiryanov 	SPLASHIMAGE_CALLBACK \
71849d5d9cSJoe Hershberger 	"stdin:console,stdout:console,stderr:console," \
72de4e4edaSSam Protsenko 	"serial#:serialno," \
73170ab110SJoe Hershberger 	CONFIG_ENV_CALLBACK_LIST_STATIC
74170ab110SJoe Hershberger 
75170ab110SJoe Hershberger struct env_clbk_tbl {
76170ab110SJoe Hershberger 	const char *name;		/* Callback name */
77170ab110SJoe Hershberger 	int (*callback)(const char *name, const char *value, enum env_op op,
78170ab110SJoe Hershberger 		int flags);
79170ab110SJoe Hershberger };
80170ab110SJoe Hershberger 
81170ab110SJoe Hershberger void env_callback_init(ENTRY *var_entry);
82170ab110SJoe Hershberger 
83170ab110SJoe Hershberger /*
84170ab110SJoe Hershberger  * Define a callback that can be associated with variables.
85170ab110SJoe Hershberger  * when associated through the ".callbacks" environment variable, the callback
86170ab110SJoe Hershberger  * will be executed any time the variable is inserted, overwritten, or deleted.
87170ab110SJoe Hershberger  */
88f8cfcf1bSScott Wood #ifdef CONFIG_SPL_BUILD
89f8cfcf1bSScott Wood #define U_BOOT_ENV_CALLBACK(name, callback) \
903ea664c7SJeroen Hofstee 	static inline __maybe_unused void _u_boot_env_noop_##name(void) \
91f8cfcf1bSScott Wood 	{ \
92f8cfcf1bSScott Wood 		(void)callback; \
93f8cfcf1bSScott Wood 	}
94f8cfcf1bSScott Wood #else
95170ab110SJoe Hershberger #define U_BOOT_ENV_CALLBACK(name, callback) \
96ef123c52SAlbert ARIBAUD 	ll_entry_declare(struct env_clbk_tbl, name, env_clbk) = \
97170ab110SJoe Hershberger 	{#name, callback}
98f8cfcf1bSScott Wood #endif
99170ab110SJoe Hershberger 
100170ab110SJoe Hershberger #endif /* __ENV_CALLBACK_H__ */
101