[PATCH v2 0/4] Better smartphone support (Qualcomm)

Jens Reidel adrian at mainlining.org
Fri Mar 14 19:36:09 CET 2025


On 3/11/25 1:31 PM, Caleb Connolly wrote:
> Improve support for running U-Boot on [Qualcomm] smartphones, with:
> 
> * A boot menu which can be entered by holding power during boot
> * Hang on panic (so errors can be read on the display)
> * Serial gadget which can be enabled by holding volume down or via
>    boot menu
> 
> In its current form, U-Boot's boot menu is perfectly adequate, however
> once an option is picked U-Boot will never return to the menu, always to
> the CLI.
> 
> On a phone (with no keyboard), dropping to the CLI effectively makes the
> device unusable until manually rebooted, since there is no way to run
> any commands...
> 
> To rectify this, let's revive CONFIG_BOOT_RETRY for the hush parser and
> add an option CONFIG_RETRY_BOOTCMD to run the contents of "bootcmd".
> This provides for a flexible menu system which we can enter and exit.
> See qcom-phone.env in patch 1 for more details.
> 
> Finally, provide some rough-ish documentation to describe how Qualcomm
> phone support works and outline some debugging steps for when UART and
> the framebuffer are unavailable.
> 
> ---
> Changes in v3:
> - Minor wording/clarification improvements in docs
> - Introduce CONFIG_RETRY_BOOTCMD rather than changing the default
>    behaviour.
> - Enable some more gadgets in the phone config fragment.
> - Link to v2: https://lore.kernel.org/u-boot/20241004-qcom-phones-v2-0-c7ab67ac3043@linaro.org
> 
> Changes in v2:
> - Fix CONFIG_BUTTON_REMAP_PHONE_KEYS name in qcom-phone.config
> - Add Tom and Simon to CC
> - Link to v1: https://lore.kernel.org/r/20240831-qcom-phones-v1-0-08614edd8e35@linaro.org
> 
> ---
> Caleb Connolly (4):
>        board/qualcomm: introduce phone config
>        cli_hush: support running bootcmd on boot retry
>        bootretry: check for bootretry variable changes
>        doc: board/qualcomm: describe phone support and bringup
> 
>   board/qualcomm/qcom-phone.config |  17 ++++++
>   board/qualcomm/qcom-phone.env    |  49 ++++++++++++++++
>   boot/Kconfig                     |   7 +++
>   boot/bootretry.c                 |   2 +
>   common/cli_hush.c                |   6 +-
>   common/cli_hush_upstream.c       |   6 +-
>   doc/board/qualcomm/board.rst     |   5 ++
>   doc/board/qualcomm/index.rst     |   1 +
>   doc/board/qualcomm/phones.rst    | 122 +++++++++++++++++++++++++++++++++++++++
>   9 files changed, 211 insertions(+), 4 deletions(-)
> ---
> base-commit: 78f8c8c58f7d3f7c3a26af4afbd08aba21c14c90
> 
> Caleb Connolly <caleb.connolly at linaro.org>
> 

I've tested this on a Xiaomi Mi 9T / Redmi K20 (xiaomi-davinci, Qualcomm 
SM7150) with a handful of patches on top for SM7150 support.

I had to manually enable the following configs for USB serial gadget to 
work, so I suggest enabling them like others already pointed out:
CONFIG_DM_USB_GADGET=y
CONFIG_USB_FUNCTION_ACM=y

Also, for EFI boot to work I added the following configs, not sure which 
ones were actually making the difference:
CONFIG_EFI_RT_VOLATILE_STORE=y
CONFIG_EFI_SET_TIME=y
CONFIG_EFI_RUNTIME_UPDATE_CAPSULE=y
CONFIG_EFI_CAPSULE_ON_DISK=y
CONFIG_EFI_IGNORE_OSINDICATIONS=y
CONFIG_EFI_CAPSULE_FIRMWARE_RAW=y

With those enabled, everything works as expected and is comfortable to 
navigate. Thanks for your work!

Tested-by: Jens Reidel <adrian at mainlining.org> # xiaomi-davinci

Best regards,
Jens


More information about the U-Boot mailing list