[PATCH v2] env: spi: Fix gd->env_valid for the first write
Michal Simek
michal.simek at amd.com
Mon Sep 22 16:02:45 CEST 2025
On 9/11/25 07:40, Michal Simek wrote:
>
>
> On 9/11/25 05:28, Marek Vasut wrote:
>> On 9/10/25 9:26 AM, Michal Simek wrote:
>>> In case of ENV_INVALID (uninitialized variables) the first env location
>>> should be used for storing variables.
>>> That's why change the logic how env_valid is setup to be aligned with
>>> offset calculation.
>>> This will also fix the print about Valid environment is showing proper
>>> location where variables are saved for the first time.
>>> And also fixes behavior where the first two writes were going to the
>>> first location instead of the first to the first location and second to
>>> second location.
>>>
>>> Signed-off-by: Michal Simek <michal.simek at amd.com>
>>> ---
>>>
>>> Changes in v2:
>>> - Simplify commit message
>>>
>>> Origin commit message with more technical details.
>>>
>>> When both location for variables are not valid (or empty) gd->env_valid is
>>> 0 (ENV_INVALID) which is setup by
>>> env_sf_load()/env_import_redund()/env_check_redund() calls.
>>>
>>> When saveenv is called in case of SPI env_sf_save() is called which
>>> contains logic which describes new/old variable locations.
>>>
>>> if (gd->env_valid == ENV_VALID) {
>>> env_new_offset = CONFIG_ENV_OFFSET_REDUND;
>>> env_offset = CONFIG_ENV_OFFSET;
>>> } else {
>>> env_new_offset = CONFIG_ENV_OFFSET;
>>> env_offset = CONFIG_ENV_OFFSET_REDUND;
>>> }
>>>
>>> In case of ENV_INVALID option the first location is used (else part)
>>> and variables are saved with ENV_REDUND_ACTIVE flag.
>>> The second location flag is rewritten to ENV_REDUND_OBSOLETE.
>>>
>>> And
>>> gd->env_valid = gd->env_valid == ENV_REDUND ? ENV_VALID : ENV_REDUND;
>>> is executed. env_valid is ENV_INVALID that's why ENV_REDUND is setup
>>> but that's not correct because the first location has been written and not
>>> the second one.
>>> That is confirmed by
>>> printf("Valid environment: %d\n", (int)gd->env_valid);
>>> which is showing number 2 (ENV_REDUND).
>>>
>>> That's why change the logic how env_valid is setup to be aligned with
>>> offset calculation which also cover the case where initial state is
>>> ENV_INVALID.
>>> Then print about Valid environment is showing proper location where
>>> variables are saved for the first time.
>>> But also it is fixing behavior where the first two writes are going to the
>>> first location instead of the first to the first location and second to
>>> second location. Alternation is happening after it.
>>>
>>> v1: https://lore.kernel.org/
>>> r/03aa59f72f47fe0ecafd1e1ca52cbb8a5a8f0446.1755613540.git.michal.simek at amd.com
>> Sorry for not being clear, the original commit message structure and technical
>> details were fine, it only needed slight rephrasing, in the original form it
>> was very hard to understand. Can you please reinstate the original commit
>> message and only clean it up slightly ?
>
> Can you exactly point me to part which wasn't clear? It has a lot of details
> about flow and obviously it makes sense to me that's why I would like you to
> point me to exact part which should be improved.
What about this?
When both SPI environment locations are invalid (gd->env_valid == ENV_INVALID),
the first call to saveenv writes to the primary location and sets the active
flag. However, the logic for updating gd->env_valid incorrectly sets it to
ENV_REDUND, which does not match the actual location written. This causes the
first two writes to target the same location, and alternation only begins after
the second write.
Update the logic to alternate gd->env_valid based on whether the last write was
to the primary or redundant location, ensuring the first write sets ENV_VALID
and subsequent writes alternate as expected. This aligns env_valid with the
actual storage location and fixes the alternation sequence from the first write.
With this change, the "Valid environment" printout correctly reflects the active
location after each save, and the alternation between primary and redundant
locations works as intended from the start.
Thanks,
Michal
More information about the U-Boot
mailing list