diff options
author | Jianlong.Huang <jianlong.huang@starfivetech.com> | 2021-10-27 04:17:57 +0300 |
---|---|---|
committer | Tekkaman Ninja <tekkamanninja@163.com> | 2022-02-15 12:48:24 +0300 |
commit | 803349d95608b64404144ea2e4ceddf139459985 (patch) | |
tree | 1bed739fe90f852f864e522411b63917e1843517 | |
parent | 4793fbc0f0d395868245f0c78d553c61527ff585 (diff) | |
download | u-boot-803349d95608b64404144ea2e4ceddf139459985.tar.xz |
cmd/eeprom: fix data type issue for parse_numeric_param
This patch fixs parse_numeric_param issue on some platfrom which has
different sizes of int and long, like riscv64.
On riscv64, int is 4 bytes, but long is 8 bytes.
on this situation:
ulong addr = parse_numeric_param(argv[index]);
if argv[index] is "0x80000000", this "ulong addr" will be
0xffffffff80000000.
Signed-off-by: Jianlong.Huang <jianlong.huang@starfivetech.com>
Co-developed-by: Wei Fu <wefu@redhat.com>
Signed-off-by: Wei Fu <wefu@redhat.com>
-rw-r--r-- | cmd/eeprom.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/cmd/eeprom.c b/cmd/eeprom.c index cdd65af763..614263fd8e 100644 --- a/cmd/eeprom.c +++ b/cmd/eeprom.c @@ -200,10 +200,10 @@ int eeprom_write(unsigned dev_addr, unsigned offset, return ret; } -static int parse_numeric_param(char *str) +static long parse_numeric_param(char *str) { char *endptr; - int value = simple_strtol(str, &endptr, 16); + long value = simple_strtol(str, &endptr, 16); return (*endptr != '\0') ? -1 : value; } |