mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 10:08:21 +01:00 
			
		
		
		
	As already done for NOR chips, if device ESIZE and ENVSECTORS static configurations are both zero, then autodetect them at runtime. Cc: Joe Hershberger <joe.hershberger@ni.com> cc: Stefan Agner <stefan@agner.ch> cc: Rasmus Villemoes <rasmus.villemoes@prevas.dk> Signed-off-by: Anthony Loiseau <anthony.loiseau@allcircuits.com>
		
			
				
	
	
		
			67 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
 | |
| This is a demo implementation of a Linux command line tool to access
 | |
| the U-Boot's environment variables.
 | |
| 
 | |
| In order to cross-compile fw_printenv, run
 | |
|     make CROSS_COMPILE=<your cross-compiler prefix> envtools
 | |
| in the root directory of the U-Boot distribution. For example,
 | |
|     make CROSS_COMPILE=arm-linux- envtools
 | |
| 
 | |
| You should then create a symlink from fw_setenv to fw_printenv. They use
 | |
| the same program and its function depends on its basename.
 | |
| 
 | |
| For the run-time utility configuration uncomment the line
 | |
| #define CONFIG_FILE  "/etc/fw_env.config"
 | |
| in fw_env.h.
 | |
| 
 | |
| For building against older versions of the MTD headers (meaning before
 | |
| v2.6.8-rc1) it is required to pass the argument "MTD_VERSION=old" to
 | |
| make.
 | |
| 
 | |
| See comments in the fw_env.config file for definitions for the
 | |
| particular board.
 | |
| 
 | |
| Configuration can also be done via #defines in the fw_env.h file. The
 | |
| following lines are relevant:
 | |
| 
 | |
| #define HAVE_REDUND	/* For systems with 2 env sectors */
 | |
| #define DEVICE1_NAME	"/dev/mtd1"
 | |
| #define DEVICE2_NAME	"/dev/mtd2"
 | |
| #define DEVICE1_OFFSET    0x0000
 | |
| #define ENV1_SIZE         0x4000
 | |
| #define DEVICE1_ESIZE     0x4000
 | |
| #define DEVICE1_ENVSECTORS     2
 | |
| #define DEVICE2_OFFSET    0x0000
 | |
| #define ENV2_SIZE         0x4000
 | |
| #define DEVICE2_ESIZE     0x4000
 | |
| #define DEVICE2_ENVSECTORS     2
 | |
| 
 | |
| Un-define HAVE_REDUND, if you want to use the utilities on a system
 | |
| that does not have support for redundant environment enabled.
 | |
| If HAVE_REDUND is undefined, DEVICE2_NAME is ignored,
 | |
| as is ENV2_SIZE and DEVICE2_ESIZE.
 | |
| 
 | |
| The DEVICEx_NAME constants define which MTD character devices are to
 | |
| be used to access the environment.
 | |
| 
 | |
| The DEVICEx_OFFSET constants define the environment offset within the
 | |
| MTD character device.
 | |
| 
 | |
| ENVx_SIZE defines the size in bytes taken by the environment, which
 | |
| may be less then flash sector size, if the environment takes less
 | |
| then 1 sector.
 | |
| 
 | |
| DEVICEx_ESIZE defines the size of the first sector in the flash
 | |
| partition where the environment resides.
 | |
| 
 | |
| DEVICEx_ENVSECTORS defines the number of sectors that may be used for
 | |
| this environment instance. On NAND this is used to limit the range
 | |
| within which bad blocks are skipped, on NOR it is not used.
 | |
| 
 | |
| If DEVICEx_ESIZE and DEVICEx_ENVSECTORS are both zero, then a runtime
 | |
| detection is attempted for NOR and NAND mtd types.
 | |
| 
 | |
| To prevent losing changes to the environment and to prevent confusing the MTD
 | |
| drivers, a lock file at /run/fw_printenv.lock is used to serialize access
 | |
| to the environment.
 |