env: Create a location driver for each location
Set up a location driver for each supported environment location. At
present this just points to the global functions and is not used. A
later patch will switch this over to use private functions in each driver.
There are several special cases here in various drivers to handle
peculiarities of certain boards:
1. Some boards define CONFIG_ENV_IS_IN_FAT and CONFIG_SPL_ENV_SUPPORT but
do not actually load the environment in SPL. The env load code was
optimised out before but with the driver, it is not. Therefore a special
case is added to env/fat.c. The correct fix (depending on board testing
might be to disable CONFIG_SPL_ENV_SUPPORT.
2. A similar situations happens with CONFIG_ENV_IS_IN_FLASH. Some boards
do not actually load the environment in SPL, so to reduce code size we
need to drop that code. A similar fix may be possible with these boards,
or it may be possible to adjust the environment CONFIG settings.
Added to the above is that the CONFIG_SPL_ENV_SUPPORT option does not
apply when the environment is in flash.
Obviously the above has been discovered through painful and time-consuming
trial and error. Hopefully board maintainers can take a look and figure
out what is actually needed.
Signed-off-by:
Simon Glass <sjg@chromium.org>
Showing
- env/dataflash.c 8 additions, 0 deletionsenv/dataflash.c
- env/eeprom.c 8 additions, 0 deletionsenv/eeprom.c
- env/ext4.c 8 additions, 0 deletionsenv/ext4.c
- env/fat.c 28 additions, 2 deletionsenv/fat.c
- env/flash.c 35 additions, 4 deletionsenv/flash.c
- env/mmc.c 10 additions, 0 deletionsenv/mmc.c
- env/nand.c 11 additions, 1 deletionenv/nand.c
- env/nowhere.c 6 additions, 0 deletionsenv/nowhere.c
- env/nvram.c 10 additions, 0 deletionsenv/nvram.c
- env/onenand.c 8 additions, 0 deletionsenv/onenand.c
- env/remote.c 8 additions, 0 deletionsenv/remote.c
- env/sata.c 8 additions, 0 deletionsenv/sata.c
- env/sf.c 20 additions, 0 deletionsenv/sf.c
- env/ubi.c 8 additions, 0 deletionsenv/ubi.c
- include/environment.h 70 additions, 0 deletionsinclude/environment.h
Loading
Please register or sign in to comment