[PATCH 3/3] env: mmc: fix offsets relative to the end of the partition

Quentin Schulz quentin.schulz at cherry.de
Thu Mar 13 11:36:01 CET 2025


Hi Michael,

On 3/12/25 8:40 AM, Michael Walle wrote:
> According to the help text, you can set negative offsets to indicated
> that the offset is relative to the end of the parition. But kconfig
> doesn't let you specify negative hex values. I think this fell through
> the cracks when converting the symbol from a '#define' to a kconfig
> option.
> 
> Introduce a new boolean kconfig option to switch on the "relative to the
> end" behavior.
> 
> Signed-off-by: Michael Walle <mwalle at kernel.org>
> ---
>   env/Kconfig | 42 +++++++++++++++++++++++++-----------------
>   env/mmc.c   |  8 ++++++++
>   2 files changed, 33 insertions(+), 17 deletions(-)
> 
> diff --git a/env/Kconfig b/env/Kconfig
> index 4438f0b392c..49888bf700c 100644
> --- a/env/Kconfig
> +++ b/env/Kconfig
> @@ -231,14 +231,6 @@ config ENV_IS_IN_MMC
>   	  These two #defines specify the offset and size of the environment
>   	  area within the specified MMC device.
>   
> -	  If offset is positive (the usual case), it is treated as relative to
> -	  the start of the MMC partition. If offset is negative, it is treated
> -	  as relative to the end of the MMC partition. This can be useful if
> -	  your board may be fitted with different MMC devices, which have
> -	  different sizes for the MMC partitions, and you always want the
> -	  environment placed at the very end of the partition, to leave the
> -	  maximum possible space before it, to store other data.
> -
>   	  These two values are in units of bytes, but must be aligned to an
>   	  MMC sector boundary.
>   
> @@ -249,9 +241,6 @@ config ENV_IS_IN_MMC
>   	  valid backup copy in case the other copy is corrupted, e.g. due
>   	  to a power failure during a "saveenv" operation.
>   
> -	  This value may also be positive or negative; this is handled in the
> -	  same way as CONFIG_ENV_OFFSET.
> -
>   	  In case CONFIG_SYS_MMC_ENV_PART is 1 (i.e. environment in eMMC boot
>   	  partition) then setting CONFIG_ENV_OFFSET_REDUND to the same value
>   	  as CONFIG_ENV_OFFSET makes use of the second eMMC boot partition for
> @@ -592,9 +581,18 @@ config ENV_OFFSET
>   	  Offset from the start of the device (or partition).
>   
>   	  This offset may be interpreted differently depending on the chosen
> -	  ENV_IS_IN_* options. For example, for ENV_IS_IN_MMC=y, this offset may
> -	  be negative to indicate an offset backwards from the end of the
> -	  partition. See the relevant help messages for more details.
> +	  ENV_IS_IN_* options. See the relevant help messages for more details.
> +
> +config ENV_OFFSET_RELATIVE_END
> +	bool "Offset is relative to the end of the partition"
> +	depends on ENV_IS_IN_MMC
> +	help
> +	  Treat the environment offset as relative to the end of the MMC
> +	  partition. This can be useful if your board may be fitted with

I guess by MMC partition you meant hardware MMC partitions, as opposed 
to GPT/MBR partitions?

It's not clear from JEDEC standard if there's a word that would apply to 
the boot partitions, User Area (I think it can be split also?), RPMB, 
etc.? But if there's one, maybe use that term?

> +	  different MMC devices, which have different sizes for the MMC
> +	  partitions, and you always want the environment placed at the very end
> +	  of the partition, to leave the maximum possible space before it, to
> +	  store other data.
>   
>   config ENV_OFFSET_REDUND
>   	hex "Redundant environment offset"
> @@ -607,9 +605,19 @@ config ENV_OFFSET_REDUND
>   	  environment location.
>   
>   	  This offset may be interpreted differently depending on the chosen
> -	  ENV_IS_IN_* options. For example, for ENV_IS_IN_MMC=y, this offset may
> -	  be negative to indicate an offset backwards from the end of the
> -	  partition. See the relevant help messages for more details.
> +	  ENV_IS_IN_* options. See the relevant help messages for more details.
> +
> +config ENV_OFFSET_REDUND_RELATIVE_END
> +	bool "Offset is relative to the end of the partition"
> +	depends on SYS_REDUNDAND_ENVIRONMENT
> +	depends on ENV_IS_IN_MMC
> +	help
> +	  Treat the redundnat environment offset as relative to the end of the

s/redundnat/redundant/

> +	  MMC partition. This can be useful if your board may be fitted with
> +	  different MMC devices, which have different sizes for the MMC
> +	  partitions, and you always want the environment placed at the very end
> +	  of the partition, to leave the maximum possible space before it, to
> +	  store other data.
>   

Same remark as for ENV_OFFSET_RELATIVE_END.

Looks good to me otherwise!

Cheers,
Quentin


More information about the U-Boot mailing list