There have been issues with autoboot on DB410c for years, where autoboot
gets interrupted by spurious input on the UART console. I've tried fixing
this back in 2021, but it turned out this fix was not enough. Looking into
it further, there are two separate issues to fix:

 - Spurious input with UART disconnected: The RX pin is floating in this
   case, resulting in garbage or a UART break event (0x00 byte). This is
   interpreted as input in the autoboot prompt. Fix this by adding
   bias-pull-up for the RX pin. I've made this change upstream in Linux for
   all MSM8916/MSM8939 devices, so I only backport the changes here using
   tools/update-subtree.sh.

 - Spurious input when querying console size with UART connected: It's
   unclear why this happens, but it seems to be some issue in the overly
   complex implementation of 4-character packing mode in the serial_msm
   driver. Fix this by switching the driver to use the more simple
   single-character mode, which doesn't have this issue.

With these patches, autoboot is finally working reliably on DragonBoard
410c (and hopefully will remain so for the future :-)).

Signed-off-by: Stephan Gerhold <stephan.gerh...@linaro.org>
---
Stephan Gerhold (10):
      arm64: dts: qcom: msm8916/39: Move UART pinctrl to board files
      arm64: dts: qcom: msm8916/39: Introduce new UART console pinctrl
      arm64: dts: qcom: msm8919/39: Use UART2 console pinctrl where appropriate
      arm64: dts: qcom: msm8916-motorola: Use UART1 console pinctrl
      board: dragonboard410c: Drop now unneeded bootph-all for console
      Revert "serial: serial_msm: Delay initialization to let pins stabilize"
      serial: msm: Cleanup register naming
      serial: msm: Reset after writing to DMEN
      serial: msm: Re-enable after resetting
      serial: msm: Use single character mode

 arch/arm/dts/apq8016-sbc-u-boot.dtsi               |   9 --
 drivers/serial/serial_msm.c                        | 127 +++++----------------
 dts/upstream/src/arm64/qcom/apq8016-sbc.dts        |   6 +
 .../src/arm64/qcom/apq8016-schneider-hmibsc.dts    |   6 +
 dts/upstream/src/arm64/qcom/apq8039-t2.dts         |   6 +
 .../src/arm64/qcom/msm8916-acer-a1-724.dts         |   3 +
 .../src/arm64/qcom/msm8916-alcatel-idol347.dts     |   3 +
 dts/upstream/src/arm64/qcom/msm8916-asus-z00l.dts  |   3 +
 .../src/arm64/qcom/msm8916-gplus-fl8005a.dts       |   3 +
 dts/upstream/src/arm64/qcom/msm8916-huawei-g7.dts  |   3 +
 dts/upstream/src/arm64/qcom/msm8916-lg-c50.dts     |   3 +
 dts/upstream/src/arm64/qcom/msm8916-lg-m216.dts    |   3 +
 .../src/arm64/qcom/msm8916-longcheer-l8150.dts     |   3 +
 .../src/arm64/qcom/msm8916-longcheer-l8910.dts     |   3 +
 .../src/arm64/qcom/msm8916-motorola-common.dtsi    |  11 +-
 dts/upstream/src/arm64/qcom/msm8916-mtp.dts        |   3 +
 .../arm64/qcom/msm8916-samsung-a2015-common.dtsi   |   3 +
 .../arm64/qcom/msm8916-samsung-fortuna-common.dtsi |   3 +
 .../src/arm64/qcom/msm8916-samsung-gt5-common.dtsi |   3 +
 .../src/arm64/qcom/msm8916-samsung-j5-common.dtsi  |   3 +
 .../src/arm64/qcom/msm8916-samsung-serranove.dts   |   3 +
 dts/upstream/src/arm64/qcom/msm8916-ufi.dtsi       |   3 +
 .../src/arm64/qcom/msm8916-wingtech-wt865x8.dtsi   |   3 +
 .../src/arm64/qcom/msm8916-wingtech-wt88047.dts    |   3 +
 dts/upstream/src/arm64/qcom/msm8916.dtsi           |  51 +++++++--
 .../src/arm64/qcom/msm8939-huawei-kiwi.dts         |   3 +
 .../src/arm64/qcom/msm8939-longcheer-l9100.dts     |   3 +
 dts/upstream/src/arm64/qcom/msm8939-samsung-a7.dts |   3 +
 .../src/arm64/qcom/msm8939-wingtech-wt82918.dtsi   |   3 +
 dts/upstream/src/arm64/qcom/msm8939.dtsi           |  51 +++++++--
 30 files changed, 204 insertions(+), 129 deletions(-)
---
base-commit: fb4a488eb91b089912ffbc9a74d0527f0f2c79ac
change-id: 20250419-db410c-autoboot-fixes-ad7f4f5973a8

Best regards,
-- 
Stephan Gerhold <stephan.gerh...@linaro.org>

Reply via email to