env: Rename the redundancy flags

Add an ENV prefix to these two flags so that it is clear what they relate
to. Also move them to env.h since they are part of the public API. Use an
enum rather than a #define to tie them together.

Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
Simon Glass 2019-08-01 09:47:08 -06:00 committed by Tom Rini
parent 25e51e90fe
commit d3716dd64b
7 changed files with 39 additions and 31 deletions

View File

@ -1002,7 +1002,7 @@ NXTARG: ;
envp->crc = crc32(0, envp->data, envp->crc = crc32(0, envp->data,
size ? size - offsetof(env_t, data) : ENV_SIZE); size ? size - offsetof(env_t, data) : ENV_SIZE);
#ifdef CONFIG_ENV_ADDR_REDUND #ifdef CONFIG_ENV_ADDR_REDUND
envp->flags = ACTIVE_FLAG; envp->flags = ENV_REDUND_ACTIVE;
#endif #endif
} }
env_set_hex("filesize", len + offsetof(env_t, data)); env_set_hex("filesize", len + offsetof(env_t, data));

10
env/eeprom.c vendored
View File

@ -132,9 +132,11 @@ static int env_eeprom_load(void)
gd->env_valid = ENV_REDUND; gd->env_valid = ENV_REDUND;
} else { } else {
/* both ok - check serial */ /* both ok - check serial */
if (flags[0] == ACTIVE_FLAG && flags[1] == OBSOLETE_FLAG) if (flags[0] == ENV_REDUND_ACTIVE &&
flags[1] == ENV_REDUND_OBSOLETE)
gd->env_valid = ENV_VALID; gd->env_valid = ENV_VALID;
else if (flags[0] == OBSOLETE_FLAG && flags[1] == ACTIVE_FLAG) else if (flags[0] == ENV_REDUND_OBSOLETE &&
flags[1] == ENV_REDUND_ACTIVE)
gd->env_valid = ENV_REDUND; gd->env_valid = ENV_REDUND;
else if (flags[0] == 0xFF && flags[1] == 0) else if (flags[0] == 0xFF && flags[1] == 0)
gd->env_valid = ENV_REDUND; gd->env_valid = ENV_REDUND;
@ -194,7 +196,7 @@ static int env_eeprom_save(void)
unsigned int off = CONFIG_ENV_OFFSET; unsigned int off = CONFIG_ENV_OFFSET;
#ifdef CONFIG_ENV_OFFSET_REDUND #ifdef CONFIG_ENV_OFFSET_REDUND
unsigned int off_red = CONFIG_ENV_OFFSET_REDUND; unsigned int off_red = CONFIG_ENV_OFFSET_REDUND;
char flag_obsolete = OBSOLETE_FLAG; char flag_obsolete = ENV_REDUND_OBSOLETE;
#endif #endif
rc = env_export(&env_new); rc = env_export(&env_new);
@ -207,7 +209,7 @@ static int env_eeprom_save(void)
off_red = CONFIG_ENV_OFFSET; off_red = CONFIG_ENV_OFFSET;
} }
env_new.flags = ACTIVE_FLAG; env_new.flags = ENV_REDUND_ACTIVE;
#endif #endif
rc = eeprom_bus_write(CONFIG_SYS_DEF_EEPROM_ADDR, rc = eeprom_bus_write(CONFIG_SYS_DEF_EEPROM_ADDR,

18
env/flash.c vendored
View File

@ -95,10 +95,12 @@ static int env_flash_init(void)
} else if (!crc1_ok && !crc2_ok) { } else if (!crc1_ok && !crc2_ok) {
gd->env_addr = addr_default; gd->env_addr = addr_default;
gd->env_valid = ENV_INVALID; gd->env_valid = ENV_INVALID;
} else if (flag1 == ACTIVE_FLAG && flag2 == OBSOLETE_FLAG) { } else if (flag1 == ENV_REDUND_ACTIVE &&
flag2 == ENV_REDUND_OBSOLETE) {
gd->env_addr = addr1; gd->env_addr = addr1;
gd->env_valid = ENV_VALID; gd->env_valid = ENV_VALID;
} else if (flag1 == OBSOLETE_FLAG && flag2 == ACTIVE_FLAG) { } else if (flag1 == ENV_REDUND_OBSOLETE &&
flag2 == ENV_REDUND_ACTIVE) {
gd->env_addr = addr2; gd->env_addr = addr2;
gd->env_valid = ENV_VALID; gd->env_valid = ENV_VALID;
} else if (flag1 == flag2) { } else if (flag1 == flag2) {
@ -121,7 +123,7 @@ static int env_flash_save(void)
{ {
env_t env_new; env_t env_new;
char *saved_data = NULL; char *saved_data = NULL;
char flag = OBSOLETE_FLAG, new_flag = ACTIVE_FLAG; char flag = ENV_REDUND_OBSOLETE, new_flag = ENV_REDUND_ACTIVE;
int rc = 1; int rc = 1;
#if CONFIG_ENV_SECT_SIZE > CONFIG_ENV_SIZE #if CONFIG_ENV_SECT_SIZE > CONFIG_ENV_SIZE
ulong up_data = 0; ulong up_data = 0;
@ -322,9 +324,9 @@ static int env_flash_load(void)
end_addr_new = ltmp; end_addr_new = ltmp;
} }
if (flash_addr_new->flags != OBSOLETE_FLAG && if (flash_addr_new->flags != ENV_REDUND_OBSOLETE &&
crc32(0, flash_addr_new->data, ENV_SIZE) == flash_addr_new->crc) { crc32(0, flash_addr_new->data, ENV_SIZE) == flash_addr_new->crc) {
char flag = OBSOLETE_FLAG; char flag = ENV_REDUND_OBSOLETE;
gd->env_valid = ENV_REDUND; gd->env_valid = ENV_REDUND;
flash_sect_protect(0, (ulong)flash_addr_new, end_addr_new); flash_sect_protect(0, (ulong)flash_addr_new, end_addr_new);
@ -334,9 +336,9 @@ static int env_flash_load(void)
flash_sect_protect(1, (ulong)flash_addr_new, end_addr_new); flash_sect_protect(1, (ulong)flash_addr_new, end_addr_new);
} }
if (flash_addr->flags != ACTIVE_FLAG && if (flash_addr->flags != ENV_REDUND_ACTIVE &&
(flash_addr->flags & ACTIVE_FLAG) == ACTIVE_FLAG) { (flash_addr->flags & ENV_REDUND_ACTIVE) == ENV_REDUND_ACTIVE) {
char flag = ACTIVE_FLAG; char flag = ENV_REDUND_ACTIVE;
gd->env_valid = ENV_REDUND; gd->env_valid = ENV_REDUND;
flash_sect_protect(0, (ulong)flash_addr, end_addr); flash_sect_protect(0, (ulong)flash_addr, end_addr);

6
env/sf.c vendored
View File

@ -30,8 +30,6 @@ static ulong env_offset = CONFIG_ENV_OFFSET;
static ulong env_new_offset = CONFIG_ENV_OFFSET_REDUND; static ulong env_new_offset = CONFIG_ENV_OFFSET_REDUND;
#endif #endif
#define ACTIVE_FLAG 1
#define OBSOLETE_FLAG 0
#endif /* CONFIG_ENV_OFFSET_REDUND */ #endif /* CONFIG_ENV_OFFSET_REDUND */
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
@ -74,7 +72,7 @@ static int setup_flash_device(void)
static int env_sf_save(void) static int env_sf_save(void)
{ {
env_t env_new; env_t env_new;
char *saved_buffer = NULL, flag = OBSOLETE_FLAG; char *saved_buffer = NULL, flag = ENV_REDUND_OBSOLETE;
u32 saved_size, saved_offset, sector; u32 saved_size, saved_offset, sector;
int ret; int ret;
@ -85,7 +83,7 @@ static int env_sf_save(void)
ret = env_export(&env_new); ret = env_export(&env_new);
if (ret) if (ret)
return -EIO; return -EIO;
env_new.flags = ACTIVE_FLAG; env_new.flags = ENV_REDUND_ACTIVE;
if (gd->env_valid == ENV_VALID) { if (gd->env_valid == ENV_VALID) {
env_new_offset = CONFIG_ENV_OFFSET_REDUND; env_new_offset = CONFIG_ENV_OFFSET_REDUND;

View File

@ -55,6 +55,12 @@ struct env_clbk_tbl {
{#name, callback} {#name, callback}
#endif #endif
/** enum env_redund_flags - Flags for the redundand_environment */
enum env_redund_flags {
ENV_REDUND_OBSOLETE = 0,
ENV_REDUND_ACTIVE = 1,
};
/** /**
* env_get_id() - Gets a sequence number for the environment * env_get_id() - Gets a sequence number for the environment
* *

View File

@ -135,9 +135,6 @@ extern unsigned long nand_env_oob_offset;
#ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT #ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
# define ENV_HEADER_SIZE (sizeof(uint32_t) + 1) # define ENV_HEADER_SIZE (sizeof(uint32_t) + 1)
# define ACTIVE_FLAG 1
# define OBSOLETE_FLAG 0
#else #else
# define ENV_HEADER_SIZE (sizeof(uint32_t)) # define ENV_HEADER_SIZE (sizeof(uint32_t))
#endif #endif
@ -147,7 +144,7 @@ extern unsigned long nand_env_oob_offset;
typedef struct environment_s { typedef struct environment_s {
uint32_t crc; /* CRC32 over data bytes */ uint32_t crc; /* CRC32 over data bytes */
#ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT #ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
unsigned char flags; /* active/obsolete flags */ unsigned char flags; /* active/obsolete flags ENVF_REDUND_ */
#endif #endif
unsigned char data[ENV_SIZE]; /* Environment data */ unsigned char data[ENV_SIZE]; /* Environment data */
} env_t; } env_t;

23
tools/env/fw_env.c vendored
View File

@ -119,9 +119,12 @@ static struct environment environment = {
static int have_redund_env; static int have_redund_env;
static unsigned char active_flag = 1; static unsigned char ENV_REDUND_ACTIVE = 1;
/* obsolete_flag must be 0 to efficiently set it on NOR flash without erasing */ /*
static unsigned char obsolete_flag = 0; * ENV_REDUND_OBSOLETE must be 0 to efficiently set it on NOR flash without
* erasing
*/
static unsigned char ENV_REDUND_OBSOLETE;
#define DEFAULT_ENV_INSTANCE_STATIC #define DEFAULT_ENV_INSTANCE_STATIC
#include <env_default.h> #include <env_default.h>
@ -1142,7 +1145,7 @@ static int flash_flag_obsolete(int dev, int fd, off_t offset)
erase.start = DEVOFFSET(dev); erase.start = DEVOFFSET(dev);
erase.length = DEVESIZE(dev); erase.length = DEVESIZE(dev);
/* This relies on the fact, that obsolete_flag == 0 */ /* This relies on the fact, that ENV_REDUND_OBSOLETE == 0 */
rc = lseek(fd, offset, SEEK_SET); rc = lseek(fd, offset, SEEK_SET);
if (rc < 0) { if (rc < 0) {
fprintf(stderr, "Cannot seek to set the flag on %s\n", fprintf(stderr, "Cannot seek to set the flag on %s\n",
@ -1150,7 +1153,7 @@ static int flash_flag_obsolete(int dev, int fd, off_t offset)
return rc; return rc;
} }
ioctl(fd, MEMUNLOCK, &erase); ioctl(fd, MEMUNLOCK, &erase);
rc = write(fd, &obsolete_flag, sizeof(obsolete_flag)); rc = write(fd, &ENV_REDUND_OBSOLETE, sizeof(ENV_REDUND_OBSOLETE));
ioctl(fd, MEMLOCK, &erase); ioctl(fd, MEMLOCK, &erase);
if (rc < 0) if (rc < 0)
perror("Could not set obsolete flag"); perror("Could not set obsolete flag");
@ -1169,7 +1172,7 @@ static int flash_write(int fd_current, int fd_target, int dev_target)
(*environment.flags)++; (*environment.flags)++;
break; break;
case FLAG_BOOLEAN: case FLAG_BOOLEAN:
*environment.flags = active_flag; *environment.flags = ENV_REDUND_ACTIVE;
break; break;
default: default:
fprintf(stderr, "Unimplemented flash scheme %u\n", fprintf(stderr, "Unimplemented flash scheme %u\n",
@ -1508,11 +1511,11 @@ int fw_env_open(struct env_opts *opts)
} else { } else {
switch (environment.flag_scheme) { switch (environment.flag_scheme) {
case FLAG_BOOLEAN: case FLAG_BOOLEAN:
if (flag0 == active_flag && if (flag0 == ENV_REDUND_ACTIVE &&
flag1 == obsolete_flag) { flag1 == ENV_REDUND_OBSOLETE) {
dev_current = 0; dev_current = 0;
} else if (flag0 == obsolete_flag && } else if (flag0 == ENV_REDUND_OBSOLETE &&
flag1 == active_flag) { flag1 == ENV_REDUND_ACTIVE) {
dev_current = 1; dev_current = 1;
} else if (flag0 == flag1) { } else if (flag0 == flag1) {
dev_current = 0; dev_current = 0;