From: Patrick Delaunay Date: Thu, 27 Apr 2023 13:36:37 +0000 (+0200) Subject: stm32mp: stm32prog: use the decimal format by default for offset parsing X-Git-Tag: v2025.01-rc5-pxa1908~950^2~14^2~7 X-Git-Url: http://git.dujemihanovic.xyz/login.html?a=commitdiff_plain;h=bd087f62c9f56bb6610706aeea0825fd55c393e9;p=u-boot.git stm32mp: stm32prog: use the decimal format by default for offset parsing Change the default base for offset parsing with simple_strtoull(), so offset in flashlayout is coded in base 10 by default, even if string start with '0'. The Octal encoding is not supported. The base 16 is still supported when the '0x' header is detected. This patch solves an unexpected parsing result when the address, provided by decimal value is starting by 0, for example 0x4400 = 00017408 is a invalid with current code. ... P 0x04 fsbl1 Binary mmc0 00017408 tf-a.stm32 .... Signed-off-by: Patrick Delaunay Reviewed-by: Patrice Chotard --- diff --git a/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c b/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c index 1e40bdf0f6..9ba94be804 100644 --- a/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c +++ b/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c @@ -521,7 +521,7 @@ static int parse_offset(struct stm32prog_data *data, stm32prog_err("Layout line %d: invalid part '%s'", i, p); } else { - part->addr = simple_strtoull(p, &tail, 0); + part->addr = simple_strtoull(p, &tail, 10); if (tail == p || *tail != '\0') { stm32prog_err("Layout line %d: invalid offset '%s'", i, p);