[PATCH v2 1/1] cmd/setexpr: support concatenation of direct strings
Heinrich Schuchardt
heinrich.schuchardt at canonical.com
Mon Feb 3 12:03:21 CET 2025
On 2/2/25 16:00, Tom Rini wrote:
> On Sun, Feb 02, 2025 at 01:01:00PM +0100, Heinrich Schuchardt wrote:
>> On 1/20/25 21:52, Tom Rini wrote:
>>> On Sun, Jan 05, 2025 at 11:46:14AM +0100, Heinrich Schuchardt wrote:
>>>
>>>> The setexpr.s command allows to concatenate two strings.
>>>>
>>>> According to the description in doc/usage/cmd/setexpr.rst the parameters
>>>> value1 and value2 can be either direct values or pointers to a
>>>> memory location holding the values.
>>>>
>>>> Unfortunately `setexpr.s <value1> + <value2>` fails if any of the values
>>>> is a direct value. $? is set to false.
>>>>
>>>> * Add support for direct values in setexpr.s.
>>>> * Correct the unit test for "setexpr.s fred 0".
>>>> * Add a new unit test for "setexpr.s fred '1' + '3'" giving '13'.
>>>>
>>>> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
>>>
>>> This causes ut_setexpr_setexpr_test_str to fail.
>>>
>>
>> Hello Tom,
>>
>> I am not able to reproduce this problem in Gitlab.
>> https://source.denx.de/u-boot/custodians/u-boot-efi/-/pipelines/24424
>>
>> Please, provide a link to the failure.
>
> The three failures in:
> https://source.denx.de/u-boot/u-boot/-/jobs/999497
> were from that test. Do we have some problem lurking perhaps similar to
> what Marek fixed in commit 082b41df8abd ("test/cmd/wget.c: Fix loadaddr
> rewrite") ?
>
Hello Tom,
Thanks for the link.
With my patch
setexpr.s fred 0
is expected to succeed and allocate a string "0" that is assigned to
environment variable fred.
A few lines below Simon acknowledges that the assumption that replacing
an environment string by a string of same size does not change the value
of ut_check_free() does not hold true:
/*
* This fails in CI at present.
*
* ut_assertok(ut_check_delta(start_mem));
*/
I will update the patch accordingly.
@Simon:
In env_do_env_set() free() occurs after malloc(). Depending on the
current memory layout the free() may or may not result in merging of
chunks. So it is not expected that the available memory size stays the
same when replacing the value of an environment variable by a string of
the same size.
Best regards
Heinrich
More information about the U-Boot
mailing list