[PATCH 0/4] Qualcomm: expand capsule update support
Caleb Connolly
caleb.connolly at linaro.org
Wed Mar 26 18:44:19 CET 2025
On 3/26/25 18:40, Caleb Connolly wrote:
> The initial capsule update support only worked on the RB3 Gen 2 and made
> a lot of assumptions specific to that board.
>
> Implement the logic necessary to update U-Boot no matter where it was
> flashed to, independent of any particular board.
>
> First, we keep track of how U-Boot was loaded, specifically if we had a
> valid external FDT (even if we didn't use it) this indicates that we
> were booted via the Android bootloader, in this case the target for
> capsule updates is the boot partition. Otherwise, we target the uefi
> partition (if it exists) or the xbl partition. We handle A/B support for
> all 3 (currently we always flash to the currently active partition with
> a minor exception for the uefi partition).
>
> We introduce two new fw_name strings to differentiate the GUIDs based on
> the target partition, this means one board can support multiple boot
> methods with capsule update support for all of them (typically this
> would be chainloading OR flashing U-Boot to XBL).
>
> Lastly, the call to scsi_scan() in dfu_scsi.c is removed. Since
> scsi_scan() unbinds all scsi devices it breaks device handles maintained
> in the EFI layer for the duration of the capsule update process and
> causes the EFI filesystem access to delete the capsule file after the
> update to fail.
>
> Boards should instead be responsible for calling scsi_scan() before
> initiating DFU.
Forgot to mention: this has been tested on the OnePlus 6 (with U-Boot in
the boot partition - chainloaded), the rb3 (with U-Boot flashed to xbl),
and the rb3gen2 (With u-boot flashed to uefi).
More testing is very welcome!
>
> ---
> Caleb Connolly (4):
> mach-snapdragon: track boot source
> mach-snapdragon: CapsuleUpdate: support all boot methods
> dfu: scsi: don't call scsi_scan()
> qcom_defconfig: enable capsule update support
>
> arch/arm/mach-snapdragon/board.c | 25 +++
> arch/arm/mach-snapdragon/capsule_update.c | 256 +++++++++++++++++++++++-------
> arch/arm/mach-snapdragon/qcom-priv.h | 14 ++
> configs/qcm6490_defconfig | 6 -
> configs/qcom_defconfig | 3 +
> drivers/dfu/dfu_scsi.c | 5 -
> 6 files changed, 245 insertions(+), 64 deletions(-)
> ---
> base-commit: 68ac813c70d991ec518d0fd815efdb10a05958c0
>
> Caleb Connolly <caleb.connolly at linaro.org>
>
--
Caleb (they/them)
More information about the U-Boot
mailing list