xref: /rk3399_rockchip-uboot/include/environment.h (revision ac358beb85362fb2fac47aaec40a7e1bca49656c)
1c609719bSwdenk /*
2c609719bSwdenk  * (C) Copyright 2002
3c609719bSwdenk  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4c609719bSwdenk  *
51a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
6c609719bSwdenk  */
7c609719bSwdenk 
8c609719bSwdenk #ifndef _ENVIRONMENT_H_
96f403badSIgor Grinberg #define _ENVIRONMENT_H_
10c609719bSwdenk 
11fb1c43ccSMaxime Ripard #include <linux/kconfig.h>
12fb1c43ccSMaxime Ripard 
13c609719bSwdenk /**************************************************************************
14c609719bSwdenk  *
15c609719bSwdenk  * The "environment" is stored as a list of '\0' terminated
16c609719bSwdenk  * "name=value" strings. The end of the list is marked by a double
17c609719bSwdenk  * '\0'. New entries are always added at the end. Deleting an entry
18c609719bSwdenk  * shifts the remaining entries to the front. Replacing an entry is a
19c609719bSwdenk  * combination of deleting the old value and adding the new one.
20c609719bSwdenk  *
21fc0b5948SRobert P. J. Day  * The environment is preceded by a 32 bit CRC over the data part.
22c609719bSwdenk  *
23fc0b5948SRobert P. J. Day  *************************************************************************/
24c609719bSwdenk 
255a1aceb0SJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_ENV_IS_IN_FLASH)
260e8d1586SJean-Christophe PLAGNIOL-VILLARD # ifndef	CONFIG_ENV_ADDR
276d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #  define	CONFIG_ENV_ADDR	(CONFIG_SYS_FLASH_BASE + CONFIG_ENV_OFFSET)
28c609719bSwdenk # endif
290e8d1586SJean-Christophe PLAGNIOL-VILLARD # ifndef	CONFIG_ENV_OFFSET
306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #  define	CONFIG_ENV_OFFSET (CONFIG_ENV_ADDR - CONFIG_SYS_FLASH_BASE)
31c609719bSwdenk # endif
320e8d1586SJean-Christophe PLAGNIOL-VILLARD # if !defined(CONFIG_ENV_ADDR_REDUND) && defined(CONFIG_ENV_OFFSET_REDUND)
33507651d6SIgor Grinberg #  define	CONFIG_ENV_ADDR_REDUND	\
34507651d6SIgor Grinberg 		(CONFIG_SYS_FLASH_BASE + CONFIG_ENV_OFFSET_REDUND)
35c609719bSwdenk # endif
360e8d1586SJean-Christophe PLAGNIOL-VILLARD # if defined(CONFIG_ENV_SECT_SIZE) || defined(CONFIG_ENV_SIZE)
370e8d1586SJean-Christophe PLAGNIOL-VILLARD #  ifndef	CONFIG_ENV_SECT_SIZE
380e8d1586SJean-Christophe PLAGNIOL-VILLARD #   define	CONFIG_ENV_SECT_SIZE	CONFIG_ENV_SIZE
39500545ccSwdenk #  endif
400e8d1586SJean-Christophe PLAGNIOL-VILLARD #  ifndef	CONFIG_ENV_SIZE
410e8d1586SJean-Christophe PLAGNIOL-VILLARD #   define	CONFIG_ENV_SIZE	CONFIG_ENV_SECT_SIZE
42c609719bSwdenk #  endif
43500545ccSwdenk # else
440e8d1586SJean-Christophe PLAGNIOL-VILLARD #  error "Both CONFIG_ENV_SECT_SIZE and CONFIG_ENV_SIZE undefined"
45500545ccSwdenk # endif
460e8d1586SJean-Christophe PLAGNIOL-VILLARD # if defined(CONFIG_ENV_ADDR_REDUND) && !defined(CONFIG_ENV_SIZE_REDUND)
470e8d1586SJean-Christophe PLAGNIOL-VILLARD #  define CONFIG_ENV_SIZE_REDUND	CONFIG_ENV_SIZE
48c609719bSwdenk # endif
496d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # if	(CONFIG_ENV_ADDR >= CONFIG_SYS_MONITOR_BASE) &&		\
50507651d6SIgor Grinberg 	(CONFIG_ENV_ADDR + CONFIG_ENV_SIZE) <=			\
51507651d6SIgor Grinberg 	(CONFIG_SYS_MONITOR_BASE + CONFIG_SYS_MONITOR_LEN)
526f403badSIgor Grinberg #  define ENV_IS_EMBEDDED
53c609719bSwdenk # endif
540e8d1586SJean-Christophe PLAGNIOL-VILLARD # if defined(CONFIG_ENV_ADDR_REDUND) || defined(CONFIG_ENV_OFFSET_REDUND)
556f403badSIgor Grinberg #  define CONFIG_SYS_REDUNDAND_ENVIRONMENT
56c609719bSwdenk # endif
570a9e4e77SMike Frysinger # ifdef CONFIG_ENV_IS_EMBEDDED
580a9e4e77SMike Frysinger #  error "do not define CONFIG_ENV_IS_EMBEDDED in your board config"
590a9e4e77SMike Frysinger #  error "it is calculated automatically for you"
600a9e4e77SMike Frysinger # endif
615a1aceb0SJean-Christophe PLAGNIOL-VILLARD #endif	/* CONFIG_ENV_IS_IN_FLASH */
62c609719bSwdenk 
635707df77SBo Shen #if defined(CONFIG_ENV_IS_IN_MMC)
645707df77SBo Shen # ifdef CONFIG_ENV_OFFSET_REDUND
655707df77SBo Shen #  define CONFIG_SYS_REDUNDAND_ENVIRONMENT
665707df77SBo Shen # endif
675707df77SBo Shen #endif
685707df77SBo Shen 
6951bfee19SJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_ENV_IS_IN_NAND)
70c9f7351bSBen Gardiner # if defined(CONFIG_ENV_OFFSET_OOB)
71c9f7351bSBen Gardiner #  ifdef CONFIG_ENV_OFFSET_REDUND
72c9f7351bSBen Gardiner #   error "CONFIG_ENV_OFFSET_REDUND is not supported when CONFIG_ENV_OFFSET_OOB"
73c9f7351bSBen Gardiner #   error "is set"
74c9f7351bSBen Gardiner #  endif
75c9f7351bSBen Gardiner extern unsigned long nand_env_oob_offset;
76c9f7351bSBen Gardiner #  define CONFIG_ENV_OFFSET nand_env_oob_offset
77c9f7351bSBen Gardiner # else
780e8d1586SJean-Christophe PLAGNIOL-VILLARD #  ifndef CONFIG_ENV_OFFSET
790e8d1586SJean-Christophe PLAGNIOL-VILLARD #   error "Need to define CONFIG_ENV_OFFSET when using CONFIG_ENV_IS_IN_NAND"
80e443c944SMarkus Klotzbuecher #  endif
810e8d1586SJean-Christophe PLAGNIOL-VILLARD #  ifdef CONFIG_ENV_OFFSET_REDUND
826d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #   define CONFIG_SYS_REDUNDAND_ENVIRONMENT
83e443c944SMarkus Klotzbuecher #  endif
84c9f7351bSBen Gardiner # endif /* CONFIG_ENV_OFFSET_OOB */
85c9f7351bSBen Gardiner # ifndef CONFIG_ENV_SIZE
86c9f7351bSBen Gardiner #  error "Need to define CONFIG_ENV_SIZE when using CONFIG_ENV_IS_IN_NAND"
87c9f7351bSBen Gardiner # endif
8851bfee19SJean-Christophe PLAGNIOL-VILLARD #endif /* CONFIG_ENV_IS_IN_NAND */
89e443c944SMarkus Klotzbuecher 
902b74433fSJoe Hershberger #if defined(CONFIG_ENV_IS_IN_UBI)
912b74433fSJoe Hershberger # ifndef CONFIG_ENV_UBI_PART
922b74433fSJoe Hershberger #  error "Need to define CONFIG_ENV_UBI_PART when using CONFIG_ENV_IS_IN_UBI"
932b74433fSJoe Hershberger # endif
942b74433fSJoe Hershberger # ifndef CONFIG_ENV_UBI_VOLUME
952b74433fSJoe Hershberger #  error "Need to define CONFIG_ENV_UBI_VOLUME when using CONFIG_ENV_IS_IN_UBI"
962b74433fSJoe Hershberger # endif
97785881f7SJoe Hershberger # if defined(CONFIG_ENV_UBI_VOLUME_REDUND)
98785881f7SJoe Hershberger #  define CONFIG_SYS_REDUNDAND_ENVIRONMENT
99785881f7SJoe Hershberger # endif
1002b74433fSJoe Hershberger # ifndef CONFIG_ENV_SIZE
1012b74433fSJoe Hershberger #  error "Need to define CONFIG_ENV_SIZE when using CONFIG_ENV_IS_IN_UBI"
1022b74433fSJoe Hershberger # endif
1032b74433fSJoe Hershberger # ifndef CONFIG_CMD_UBI
1042b74433fSJoe Hershberger #  error "Need to define CONFIG_CMD_UBI when using CONFIG_ENV_IS_IN_UBI"
1052b74433fSJoe Hershberger # endif
1062b74433fSJoe Hershberger #endif /* CONFIG_ENV_IS_IN_UBI */
1072b74433fSJoe Hershberger 
1080a9e4e77SMike Frysinger /* Embedded env is only supported for some flash types */
1090a9e4e77SMike Frysinger #ifdef CONFIG_ENV_IS_EMBEDDED
1100a9e4e77SMike Frysinger # if	!defined(CONFIG_ENV_IS_IN_FLASH)	&& \
1110a9e4e77SMike Frysinger 	!defined(CONFIG_ENV_IS_IN_NAND)		&& \
112efb06339SYoshihiro Shimoda 	!defined(CONFIG_ENV_IS_IN_ONENAND)	&& \
113efb06339SYoshihiro Shimoda 	!defined(CONFIG_ENV_IS_IN_SPI_FLASH)
1140a9e4e77SMike Frysinger #  error "CONFIG_ENV_IS_EMBEDDED not supported for your flash type"
1150a9e4e77SMike Frysinger # endif
1160a9e4e77SMike Frysinger #endif
1170a9e4e77SMike Frysinger 
1180a9e4e77SMike Frysinger /*
1190a9e4e77SMike Frysinger  * For the flash types where embedded env is supported, but it cannot be
1200a9e4e77SMike Frysinger  * calculated automatically (i.e. NAND), take the board opt-in.
1210a9e4e77SMike Frysinger  */
1220a9e4e77SMike Frysinger #if defined(CONFIG_ENV_IS_EMBEDDED) && !defined(ENV_IS_EMBEDDED)
1236f403badSIgor Grinberg # define ENV_IS_EMBEDDED
1240a9e4e77SMike Frysinger #endif
1250a9e4e77SMike Frysinger 
1260a9e4e77SMike Frysinger /* The build system likes to know if the env is embedded */
1270a9e4e77SMike Frysinger #ifdef DO_DEPS_ONLY
1280a9e4e77SMike Frysinger # ifdef ENV_IS_EMBEDDED
12933a6b9e9SWolfgang Denk #  ifndef CONFIG_ENV_IS_EMBEDDED
1300a9e4e77SMike Frysinger #   define CONFIG_ENV_IS_EMBEDDED
1310a9e4e77SMike Frysinger #  endif
1320a9e4e77SMike Frysinger # endif
13333a6b9e9SWolfgang Denk #endif
1340a9e4e77SMike Frysinger 
13537566090SMike Frysinger #include "compiler.h"
136c609719bSwdenk 
1376d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
13889cdab78SMike Frysinger # define ENV_HEADER_SIZE	(sizeof(uint32_t) + 1)
139b218ccb5SWolfgang Denk 
140b218ccb5SWolfgang Denk # define ACTIVE_FLAG   1
141b218ccb5SWolfgang Denk # define OBSOLETE_FLAG 0
142c609719bSwdenk #else
14389cdab78SMike Frysinger # define ENV_HEADER_SIZE	(sizeof(uint32_t))
144c609719bSwdenk #endif
145c609719bSwdenk 
146a4223b74SMarek Vasut #ifdef CONFIG_ENV_AES
147a4223b74SMarek Vasut /* Make sure the payload is multiple of AES block size */
148a4223b74SMarek Vasut #define ENV_SIZE ((CONFIG_ENV_SIZE - ENV_HEADER_SIZE) & ~(16 - 1))
149a4223b74SMarek Vasut #else
1500e8d1586SJean-Christophe PLAGNIOL-VILLARD #define ENV_SIZE (CONFIG_ENV_SIZE - ENV_HEADER_SIZE)
151a4223b74SMarek Vasut #endif
152c609719bSwdenk 
153c609719bSwdenk typedef struct environment_s {
15489cdab78SMike Frysinger 	uint32_t	crc;		/* CRC32 over data bytes	*/
1556d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
156c609719bSwdenk 	unsigned char	flags;		/* active/obsolete flags	*/
157c609719bSwdenk #endif
158c609719bSwdenk 	unsigned char	data[ENV_SIZE]; /* Environment data		*/
159a4223b74SMarek Vasut } env_t
160a4223b74SMarek Vasut #ifdef CONFIG_ENV_AES
161a4223b74SMarek Vasut /* Make sure the env is aligned to block size. */
162a4223b74SMarek Vasut __attribute__((aligned(16)))
163a4223b74SMarek Vasut #endif
164a4223b74SMarek Vasut ;
165c609719bSwdenk 
166994bc671SIgor Grinberg #ifdef ENV_IS_EMBEDDED
167994bc671SIgor Grinberg extern env_t environment;
168994bc671SIgor Grinberg #endif /* ENV_IS_EMBEDDED */
169994bc671SIgor Grinberg 
170d1459f0fSIgor Grinberg extern const unsigned char default_environment[];
17127aafe98SIgor Grinberg extern env_t *env_ptr;
17227aafe98SIgor Grinberg 
17327aafe98SIgor Grinberg extern void env_relocate_spec(void);
17427aafe98SIgor Grinberg extern unsigned char env_get_char_spec(int);
17527aafe98SIgor Grinberg 
17627aafe98SIgor Grinberg #if defined(CONFIG_NEEDS_MANUAL_RELOC)
17727aafe98SIgor Grinberg extern void env_reloc(void);
17827aafe98SIgor Grinberg #endif
179d1459f0fSIgor Grinberg 
180ac77f42dSDmitry Lifshitz #ifdef CONFIG_ENV_IS_IN_MMC
181ac77f42dSDmitry Lifshitz #include <mmc.h>
182ac77f42dSDmitry Lifshitz 
183ac77f42dSDmitry Lifshitz extern int mmc_get_env_addr(struct mmc *mmc, int copy, u32 *env_addr);
1846e7b7df4SDmitry Lifshitz # ifdef CONFIG_SYS_MMC_ENV_PART
1856e7b7df4SDmitry Lifshitz extern uint mmc_get_env_part(struct mmc *mmc);
1866e7b7df4SDmitry Lifshitz # endif
187ac77f42dSDmitry Lifshitz #endif
188ac77f42dSDmitry Lifshitz 
1892eb1573fSMike Frysinger #ifndef DO_DEPS_ONLY
1902eb1573fSMike Frysinger 
191170ab110SJoe Hershberger #include <env_attr.h>
192170ab110SJoe Hershberger #include <env_callback.h>
1932598090bSJoe Hershberger #include <env_flags.h>
1942eb1573fSMike Frysinger #include <search.h>
1952eb1573fSMike Frysinger 
196203e94f6SSimon Glass /* Value for environment validity */
197203e94f6SSimon Glass enum env_valid {
198203e94f6SSimon Glass 	ENV_INVALID,	/* No valid environment */
199203e94f6SSimon Glass 	ENV_VALID,	/* First or only environment is valid */
200203e94f6SSimon Glass 	ENV_REDUND,	/* Redundant environment is valid */
201203e94f6SSimon Glass };
202203e94f6SSimon Glass 
2034415f1d1SSimon Glass enum env_location {
2044415f1d1SSimon Glass 	ENVL_DATAFLASH,
2054415f1d1SSimon Glass 	ENVL_EEPROM,
2064415f1d1SSimon Glass 	ENVL_EXT4,
2074415f1d1SSimon Glass 	ENVL_FAT,
2084415f1d1SSimon Glass 	ENVL_FLASH,
2094415f1d1SSimon Glass 	ENVL_MMC,
2104415f1d1SSimon Glass 	ENVL_NAND,
2114415f1d1SSimon Glass 	ENVL_NVRAM,
2124415f1d1SSimon Glass 	ENVL_ONENAND,
2134415f1d1SSimon Glass 	ENVL_REMOTE,
2144415f1d1SSimon Glass 	ENVL_SPI_FLASH,
2154415f1d1SSimon Glass 	ENVL_UBI,
2164415f1d1SSimon Glass 	ENVL_NOWHERE,
2174415f1d1SSimon Glass 
2184415f1d1SSimon Glass 	ENVL_COUNT,
2194415f1d1SSimon Glass 	ENVL_UNKNOWN,
2204415f1d1SSimon Glass };
2214415f1d1SSimon Glass 
2224415f1d1SSimon Glass struct env_driver {
223*ac358bebSSimon Glass 	const char *name;
2244415f1d1SSimon Glass 	enum env_location location;
2254415f1d1SSimon Glass 
2264415f1d1SSimon Glass 	/**
2274415f1d1SSimon Glass 	 * get_char() - Read a character from the environment
2284415f1d1SSimon Glass 	 *
2294415f1d1SSimon Glass 	 * This method is optional. If not provided, a default implementation
2304415f1d1SSimon Glass 	 * will read from gd->env_addr.
2314415f1d1SSimon Glass 	 *
2324415f1d1SSimon Glass 	 * @index: Index of character to read (0=first)
2334415f1d1SSimon Glass 	 * @return character read
2344415f1d1SSimon Glass 	 */
2354415f1d1SSimon Glass 	unsigned char (*get_char)(int index);
2364415f1d1SSimon Glass 
2374415f1d1SSimon Glass 	/**
2384415f1d1SSimon Glass 	 * load() - Load the environment from storage
2394415f1d1SSimon Glass 	 *
2404415f1d1SSimon Glass 	 * This method is optional. If not provided, no environment will be
2414415f1d1SSimon Glass 	 * loaded.
2424415f1d1SSimon Glass 	 */
2434415f1d1SSimon Glass 	void (*load)(void);
2444415f1d1SSimon Glass 
2454415f1d1SSimon Glass 	/**
2464415f1d1SSimon Glass 	 * save() - Save the environment to storage
2474415f1d1SSimon Glass 	 *
2484415f1d1SSimon Glass 	 * This method is required for 'saveenv' to work.
2494415f1d1SSimon Glass 	 *
2504415f1d1SSimon Glass 	 * @return 0 if OK, -ve on error
2514415f1d1SSimon Glass 	 */
2524415f1d1SSimon Glass 	int (*save)(void);
2534415f1d1SSimon Glass 
2544415f1d1SSimon Glass 	/**
2554415f1d1SSimon Glass 	 * init() - Set up the initial pre-relocation environment
2564415f1d1SSimon Glass 	 *
2574415f1d1SSimon Glass 	 * This method is optional.
2584415f1d1SSimon Glass 	 *
2597938822aSSimon Glass 	 * @return 0 if OK, -ENOENT if no initial environment could be found,
2607938822aSSimon Glass 	 * other -ve on error
2614415f1d1SSimon Glass 	 */
2624415f1d1SSimon Glass 	int (*init)(void);
2634415f1d1SSimon Glass };
2644415f1d1SSimon Glass 
2654415f1d1SSimon Glass /* Declare a new environment location driver */
2664415f1d1SSimon Glass #define U_BOOT_ENV_LOCATION(__name)					\
2674415f1d1SSimon Glass 	ll_entry_declare(struct env_driver, __name, env_driver)
2684415f1d1SSimon Glass 
269*ac358bebSSimon Glass /* Declare the name of a location */
270*ac358bebSSimon Glass #ifdef CONFIG_CMD_SAVEENV
271*ac358bebSSimon Glass #define ENV_NAME(_name) .name = _name,
272*ac358bebSSimon Glass #else
273*ac358bebSSimon Glass #define ENV_NAME(_name)
274*ac358bebSSimon Glass #endif
275*ac358bebSSimon Glass 
2764415f1d1SSimon Glass #ifdef CONFIG_CMD_SAVEENV
2774415f1d1SSimon Glass #define env_save_ptr(x) x
2784415f1d1SSimon Glass #else
2794415f1d1SSimon Glass #define env_save_ptr(x) NULL
2804415f1d1SSimon Glass #endif
2814415f1d1SSimon Glass 
2822eb1573fSMike Frysinger extern struct hsearch_data env_htab;
2832eb1573fSMike Frysinger 
284b502611bSJoakim Tjernlund /* Function that returns a character from the environment */
285b502611bSJoakim Tjernlund unsigned char env_get_char(int);
286a8409f4fSWolfgang Denk 
287a8409f4fSWolfgang Denk /* Function that updates CRC of the enironment */
288a8409f4fSWolfgang Denk void env_crc_update(void);
289a8409f4fSWolfgang Denk 
290267541f7SJoe Hershberger /* Look up the variable from the default environment */
291267541f7SJoe Hershberger char *getenv_default(const char *name);
292267541f7SJoe Hershberger 
2935bb12dbdSHarald Welte /* [re]set to the default environment */
294ea882bafSWolfgang Denk void set_default_env(const char *s);
295ea882bafSWolfgang Denk 
296b64b7c3dSGerlando Falauto /* [re]set individual variables to their value in the default environment */
297b64b7c3dSGerlando Falauto int set_default_vars(int nvars, char * const vars[]);
298b64b7c3dSGerlando Falauto 
299ea882bafSWolfgang Denk /* Import from binary representation into hash table */
300ea882bafSWolfgang Denk int env_import(const char *buf, int check);
3015bb12dbdSHarald Welte 
3027ce1526eSMarek Vasut /* Export from hash table into binary representation */
3037ce1526eSMarek Vasut int env_export(env_t *env_out);
3047ce1526eSMarek Vasut 
30576768f5fSFiach Antaw #ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
30676768f5fSFiach Antaw /* Select and import one of two redundant environments */
30776768f5fSFiach Antaw int env_import_redund(const char *buf1, const char *buf2);
30876768f5fSFiach Antaw #endif
30976768f5fSFiach Antaw 
310*ac358bebSSimon Glass /**
311*ac358bebSSimon Glass  * env_driver_lookup_default() - Look up the default environment driver
312*ac358bebSSimon Glass  *
313*ac358bebSSimon Glass  * @return pointer to driver, or NULL if none (which should not happen)
314*ac358bebSSimon Glass  */
315*ac358bebSSimon Glass struct env_driver *env_driver_lookup_default(void);
316*ac358bebSSimon Glass 
317507651d6SIgor Grinberg #endif /* DO_DEPS_ONLY */
3182eb1573fSMike Frysinger 
319c609719bSwdenk #endif /* _ENVIRONMENT_H_ */
320