diff options
author | Martin Fuzzey <martin.fuzzey@flowbird.group> | 2020-01-14 15:56:18 +0000 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2020-01-27 12:11:39 -0500 |
commit | 27b12b4a25f4102b047e59e3295c79d193f7b712 (patch) | |
tree | 4e1d921cb6b39fd82589dd21b2b2069696b35241 | |
parent | c17be8a9ca628fc18dd24b141bd415015ceddbbb (diff) | |
download | u-boot-WIP/2020-01-27-master-imports.tar.gz |
pmic: allow dump command for non contiguous register mapsWIP/2020-01-27-master-imports
Some PMICs (such as the DA9063) have non-contiguous register maps.
Attempting to read the non implemented registers returns an error
rather than a dummy value which causes 'pmic dump' to terminate
prematurely.
Fix this by allowing the PMIC driver to return -ENODATA for such
registers, which will then be displayed as '--' by pmic dump.
Use a single error code rather than any error code so that
we can distinguish between a hardware failure reading the PMIC
and a non implemented register known to the driver.
Signed-off-by: Martin Fuzzey <martin.fuzzey@flowbird.group>
-rw-r--r-- | cmd/pmic.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/cmd/pmic.c b/cmd/pmic.c index e46d813a70..2400bfb601 100644 --- a/cmd/pmic.c +++ b/cmd/pmic.c @@ -95,7 +95,7 @@ static int do_dump(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) for (reg = 0; reg < pmic_reg_count(dev); reg++) { ret = pmic_reg_read(dev, reg); - if (ret < 0) { + if (ret < 0 && ret != -ENODATA) { printf("Can't read register: %d\n", reg); return failure(ret); } @@ -103,7 +103,15 @@ static int do_dump(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) if (!(reg % 16)) printf("\n0x%02x: ", reg); - printf(fmt, ret); + if (ret == -ENODATA) { + int i; + + for (i = 0; i < priv->trans_len; i++) + puts("--"); + puts(" "); + } else { + printf(fmt, ret); + } } printf("\n"); |