CBI: Allow get command to reload data from EEPROM

This patch adds CBI_GET_RELOAD flag to EC_CMD_GET_CROS_BOARD_INFO
command. When the flag is set, the command will be forced to read
data from EEPROM even, ignoring the data cached by the previous
read.

This allows ectool to verify a write was successful without reboot.

BUG=b:70294260
BRANCH=none
TEST=ectool cbi set 0 0x1234 && ectool cbi get 0 1

Change-Id: I3e7ced5be56a74c605870a4c0622c0a2f47963bb
Signed-off-by: Daisuke Nojiri <dnojiri@chromium.org>
Reviewed-on: https://chromium-review.googlesource.com/874155
Reviewed-by: Randall Spangler <rspangler@chromium.org>
This commit is contained in:
Daisuke Nojiri
2018-01-17 17:22:42 -08:00
committed by chrome-bot
parent 4941dd5542
commit ead2428e91
3 changed files with 25 additions and 4 deletions

View File

@@ -172,6 +172,9 @@ static int hc_cbi_get(struct host_cmd_handler_args *args)
{
const struct __ec_align4 ec_params_get_cbi *p = args->params;
if (p->flag & CBI_GET_RELOAD)
cached_read_result = EC_ERROR_CBI_CACHE_INVALID;
if (read_board_info())
return EC_RES_ERROR;

View File

@@ -4592,8 +4592,17 @@ enum cbi_data_type {
CBI_DATA_COUNT,
};
/*
* Flags to control read operation
*
* RELOAD: Invalidate cache and read data from EEPROM. Useful to verify
* write was successful without reboot.
*/
#define CBI_GET_RELOAD (1 << 0)
struct __ec_align4 ec_params_get_cbi {
uint32_t type; /* enum cbi_data_type */
uint32_t flag; /* CBI_GET_* */
};
/*
@@ -4609,7 +4618,7 @@ struct __ec_align4 ec_params_get_cbi {
struct __ec_align1 ec_params_set_cbi {
uint32_t type; /* enum cbi_data_type */
uint8_t flag; /* CBI_SET_* */
uint32_t flag; /* CBI_SET_* */
uint32_t data; /* For numeric value */
uint8_t raw[]; /* For string and raw data */
};

View File

@@ -6230,13 +6230,15 @@ int cmd_board_version(int argc, char *argv[])
static void cmd_cbi_help(char *cmd)
{
fprintf(stderr,
" Usage: %s get <type>\n"
" Usage: %s set <type> value [flag]\n"
" Usage: %s get <type> [get_flag]\n"
" Usage: %s set <type> value [set_flag]\n"
" <type> is one of:\n"
" 0: BOARD_VERSION\n"
" 1: OEM_ID\n"
" 2: SKU_ID\n"
" [flag] is combination of:\n"
" [get_flag] is combination of:\n"
" 01b: Invalidate cache and reload data from EEPROM\n"
" [set_flag] is combination of:\n"
" 01b: Skip write to EEPROM. Use for back-to-back writes\n"
" 10b: Set all fields to defaults first\n", cmd, cmd);
}
@@ -6269,6 +6271,13 @@ static int cmd_cbi(int argc, char *argv[])
struct ec_params_get_cbi p;
uint32_t r;
p.type = type;
if (argc > 3) {
p.flag = strtol(argv[3], &e, 0);
if (e && *e) {
fprintf(stderr, "Bad flag\n");
return -1;
}
}
rv = ec_command(EC_CMD_GET_CROS_BOARD_INFO, 0, &p, sizeof(p),
&r, sizeof(r));
if (rv < 0) {