[PATCH v10 3/4] Boot var automatic management for removable medias

Heinrich Schuchardt xypron.glpk at gmx.de
Tue Jul 18 17:35:30 CEST 2023


On 18.07.23 11:03, Masahisa Kojima wrote:
> Hi Raymond,
>
> On Tue, 18 Jul 2023 at 05:23, Raymond Mao <raymond.mao at linaro.org> wrote:
>>
>> Hi Heinrich,
>>
>> I run 'make tests' with the patches locally but no errors observed from 'test_signed.py', below are few lines from the output console:
>> ```
>> test/py/tests/test_efi_secboot/test_signed.py ssssssss                                                                                                                                              [      90%]
>> ```
>
> I think the test cases are just skipped, not executed.
>
> I guess that some required packages are missing on the host machine,
> such as sbsigntool, efitools and libguestfs-tools.
> build-sandbox/test-log.html will help to analyze why the tests are skipped.
>
> The following document describes prerequisites to run python tests.
> https://u-boot.readthedocs.io/en/latest/develop/py_testing.html
>
> 'make tests' runs many test cases and takes time.
> './test/py/test.py --bd sandbox --build -k efi_secboot' will run only
> the efi_secboot test
> and it will be useful for debugging purposes.
>
> Thanks,
> Masahisa Kojima

To get more output describing why tests are skipped or fail use

    export PYTEST_ADDOPTS="-ra"

https://source.denx.de/u-boot/custodians/u-boot-efi/-/pipelines/16948
shows the errors with the suggested patch.

Best regards

Heinrich

>
>
>>
>> Regards,
>> Raymond
>>
>> On Sat, 15 Jul 2023 at 05:19, Heinrich Schuchardt <xypron.glpk at gmx.de> wrote:
>>>
>>> On 7/9/23 10:56, Heinrich Schuchardt wrote:
>>>> On 6/19/23 23:23, Raymond Mao wrote:
>>>>> Changes for complying to EFI spec §3.5.1.1
>>>>> 'Removable Media Boot Behavior'.
>>>>> Boot variables can be automatically generated during a removable
>>>>> media is probed. At the same time, unused boot variables will be
>>>>> detected and removed.
>>>>>
>>>>> Please note that currently the function 'efi_disk_remove' has no
>>>>> ability to distinguish below two scenarios
>>>>> a) Unplugging of a removable media under U-Boot
>>>>> b) U-Boot exiting and booting an OS
>>>>> Thus currently the boot variables management is not added into
>>>>> 'efi_disk_remove' to avoid boot options being added/erased
>>>>> repeatedly under scenario b) during power cycles
>>>>> See TODO comments under function 'efi_disk_remove' for more details
>>>>>
>>>>> Signed-off-by: Raymond Mao <raymond.mao at linaro.org>
>>>>> ---
>>>>> Changes in v3
>>>>> - Split the patch into moving and renaming functions and
>>>>>     individual patches for each changed functionality
>>>>> Changes in v5
>>>>> - Move function call of efi_bootmgr_update_media_device_boot_option()
>>>>>     from efi_init_variables() to efi_init_obj_list()
>>>>> Changes in v6
>>>>> - Revert unrelated changes
>>>>> Changes in v7
>>>>> - adapt the return code of function
>>>>>     efi_bootmgr_update_media_device_boot_option()
>>>>> Changes in v8
>>>>> - add a note in the commit message for future reference
>>>>> Changes in v9
>>>>> - amend the note text in the commit message
>>>>> - add a TODO comment in 'efi_disk_remove'
>>>>> Changes in v10
>>>>> - fix typo and build failures with 'CONFIG_CMD_BOOTEFI_BOOTMGR=n'
>>>>>
>>>>>    lib/efi_loader/efi_disk.c  | 18 ++++++++++++++++++
>>>>>    lib/efi_loader/efi_setup.c |  7 +++++++
>>>>>    2 files changed, 25 insertions(+)
>>>>>
>>>>> diff --git a/lib/efi_loader/efi_disk.c b/lib/efi_loader/efi_disk.c
>>>>> index d2256713a8..911a4adfb1 100644
>>>>> --- a/lib/efi_loader/efi_disk.c
>>>>> +++ b/lib/efi_loader/efi_disk.c
>>>>> @@ -687,6 +687,13 @@ int efi_disk_probe(void *ctx, struct event *event)
>>>>>                return -1;
>>>>>        }
>>>>> +    /* only do the boot option management when UEFI sub-system is
>>>>> initialized */
>>>>> +    if (IS_ENABLED(CONFIG_CMD_BOOTEFI_BOOTMGR) &&
>>>>> efi_obj_list_initialized == EFI_SUCCESS) {
>>>>> +        ret = efi_bootmgr_update_media_device_boot_option();
>>>>> +        if (ret != EFI_SUCCESS)
>>>>> +            return -1;
>>>>> +    }
>>>>> +
>>>>>        return 0;
>>>>>    }
>>>>> @@ -773,6 +780,17 @@ int efi_disk_remove(void *ctx, struct event *event)
>>>>>            return efi_disk_delete_part(dev);
>>>>>        else
>>>>>            return 0;
>>>>> +
>>>>> +    /*
>>>>> +     * TODO A flag to distinguish below 2 different scenarios of this
>>>>> +     * function call is needed:
>>>>> +     * a) Unplugging of a removable media under U-Boot
>>>>> +     * b) U-Boot exiting and booting an OS
>>>>> +     * In case of scenario a),
>>>>> efi_bootmgr_update_media_device_boot_option()
>>>>> +     * needs to be invoked here to update the boot options and remove
>>>>> the
>>>>> +     * unnecessary ones.
>>>>> +     */
>>>>
>>>> As in future we want to integrate more EFI drivers with the driver model
>>>> such a status should be in a global variable. It will have to be set in
>>>> ExitBootServices() before invoking dm_remove_devices_flags().
>>>>
>>>> Reviewed-by: Heinrich Schuchardt <xypron.glpk at gmx.de>
>>>>
>>>>> +
>>>>>    }
>>>>>    /**
>>>>> diff --git a/lib/efi_loader/efi_setup.c b/lib/efi_loader/efi_setup.c
>>>>> index 58d4e13402..69c8b27730 100644
>>>>> --- a/lib/efi_loader/efi_setup.c
>>>>> +++ b/lib/efi_loader/efi_setup.c
>>>>> @@ -245,6 +245,13 @@ efi_status_t efi_init_obj_list(void)
>>>>>        if (ret != EFI_SUCCESS)
>>>>>            goto out;
>>>>> +    if (IS_ENABLED(CONFIG_CMD_BOOTEFI_BOOTMGR)) {
>>>>> +        /* update boot option after variable service initialized */
>>>>> +        ret = efi_bootmgr_update_media_device_boot_option();
>>>>> +        if (ret != EFI_SUCCESS)
>>>>> +            goto out;
>>>>> +    }
>>>>> +
>>>>>        /* Define supported languages */
>>>>>        ret = efi_init_platform_lang();
>>>>>        if (ret != EFI_SUCCESS)
>>>>
>>>
>>> This patch leads to a test failure in
>>>
>>> test/py/tests/test_efi_secboot/test_signed.py::TestEfiSignedImage::test_efi_signed_image_auth2
>>>
>>> No EFI system partition
>>> Failed to persist EFI variables
>>>
>>> Please, run 'make tests' before resubmitting.
>>>
>>> Best regards
>>>
>>> Heinrich



More information about the U-Boot mailing list