[PATCH 1/2] cmd: fuse: add a fuse comparison function
Angus Ainslie
angus at akkea.ca
Fri Jan 14 15:56:55 CET 2022
Are there any problems with this patch ?
Thanks
Angus
On 2021-11-28 08:02, Angus Ainslie wrote:
> Compare a hexval to the fuse value and return pass or fail.
>
> Signed-off-by: Angus Ainslie <angus at akkea.ca>
> ---
> cmd/fuse.c | 22 +++++++++++++++++++++-
> 1 file changed, 21 insertions(+), 1 deletion(-)
>
> diff --git a/cmd/fuse.c b/cmd/fuse.c
> index e001619d172..78b1065d99e 100644
> --- a/cmd/fuse.c
> +++ b/cmd/fuse.c
> @@ -45,7 +45,7 @@ static int do_fuse(struct cmd_tbl *cmdtp, int flag,
> int argc,
> {
> const char *op = argc >= 2 ? argv[1] : NULL;
> int confirmed = argc >= 3 && !strcmp(argv[2], "-y");
> - u32 bank, word, cnt, val;
> + u32 bank, word, cnt, val, cmp;
> int ret, i;
>
> argc -= 2 + confirmed;
> @@ -73,6 +73,24 @@ static int do_fuse(struct cmd_tbl *cmdtp, int flag,
> int argc,
> printf(" %.8x", val);
> }
> putc('\n');
> + } else if (!strcmp(op, "cmp")) {
> + if (argc != 3 || strtou32(argv[2], 0, &cmp))
> + return CMD_RET_USAGE;
> +
> + printf("Comparing bank %u:\n", bank);
> + printf("\nWord 0x%.8x:", word);
> + printf("\nValue 0x%.8x:", cmp);
> +
> + ret = fuse_read(bank, word, &val);
> + if (ret)
> + goto err;
> +
> + printf("0x%.8x\n", val);
> + if (val != cmp) {
> + printf("failed\n");
> + return CMD_RET_FAILURE;
> + }
> + printf("passed\n");
> } else if (!strcmp(op, "sense")) {
> if (argc == 2)
> cnt = 1;
> @@ -137,6 +155,8 @@ U_BOOT_CMD(
> "Fuse sub-system",
> "read <bank> <word> [<cnt>] - read 1 or 'cnt' fuse words,\n"
> " starting at 'word'\n"
> + "fuse cmp <bank> <word> <hexval> - compare 'hexval' to fuse\n"
> + " at 'word'\n"
> "fuse sense <bank> <word> [<cnt>] - sense 1 or 'cnt' fuse words,\n"
> " starting at 'word'\n"
> "fuse prog [-y] <bank> <word> <hexval> [<hexval>...] - program 1
> or\n"
More information about the U-Boot
mailing list