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

Michael Walle mwalle at kernel.org
Thu Mar 13 11:40:17 CET 2025


Hi,

> > 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?

Yes exactly.

> 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?

I didn't come up with that, as I just moved the help text. But I can
certainly add "(hardware) MMC partition".

>
> > +	  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!

Thanks for reviewing.

Let's give this patch a couple more day, then I'll resend it with
your remarks being addressed.

-michael
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 297 bytes
Desc: not available
URL: <https://lists.denx.de/pipermail/u-boot/attachments/20250313/8678fe54/attachment.sig>


More information about the U-Boot mailing list