[PATCH v2 3/3] tegra: allow to expose UART on microSD slot

Svyatoslav Ryhel clamor95 at gmail.com
Mon Mar 31 07:51:23 CEST 2025


нд, 30 бер. 2025 р. о 22:27 Artur Kowalski <arturkow2000 at gmail.com> пише:
>
> Tegra20 has mux allowing to repurpose microSD as UART on boards which
> use sdmmc3 controller for microSD. Add TEGRA_UARTA_MICROSD to enable
> this feature. It is currently supported on Transformer T20, support for
> other boards may require Device Tree changes.
>
> Update Transformer T20 DTS to select correct pinmux and stdout-path
> based on TEGRA_UARTA_MICROSD.
>
> Signed-off-by: Artur Kowalski <arturkow2000 at gmail.com>
> ---
>
> Changes in v2:
> - added TEGRA_UARTA_MICROSD Kconfig option
> - removed .dtsi for enabling UART over microSD
> - modified transformer DT to use UARTA and correct pinmux when
>   TEGRA_UARTA_MICROSD is enabled; it is enough to flip a single
>   switch to enable/disable UART over microSD
>
>  arch/arm/dts/tegra20-asus-transformer.dtsi | 24 ++++++++++++++++++++++
>  arch/arm/mach-tegra/tegra20/Kconfig        | 15 ++++++++++++++
>  2 files changed, 39 insertions(+)
>
> diff --git a/arch/arm/dts/tegra20-asus-transformer.dtsi b/arch/arm/dts/tegra20-asus-transformer.dtsi
> index 49efabbfd92..9ea323c81f3 100644
> --- a/arch/arm/dts/tegra20-asus-transformer.dtsi
> +++ b/arch/arm/dts/tegra20-asus-transformer.dtsi
> @@ -5,7 +5,13 @@
>
>  / {
>         chosen {
> +#if CONFIG_IS_ENABLED(TEGRA_ENABLE_UARTA)
> +               stdout-path = &uarta;
> +#elif CONFIG_IS_ENABLED(TEGRA_ENABLE_UARTD)
>                 stdout-path = &uartd;
> +#else
> +#error Unsupported UART
> +#endif
>         };
>
>         aliases {
> @@ -195,10 +201,17 @@
>                                 nvidia,function = "i2c1";
>                         };
>
> +#if CONFIG_IS_ENABLED(TEGRA_UARTA_SDB_SDD)
> +                       dbguart {
> +                               nvidia,pins = "sdb", "sdd";
> +                               nvidia,function = "uarta";
> +                       };
> +#else
>                         sdb {
>                                 nvidia,pins = "sdb", "sdc", "sdd", "slxc", "slxk";
>                                 nvidia,function = "sdio3";
>                         };
> +#endif
>
>                         sdio1 {
>                                 nvidia,pins = "sdio1";
> @@ -376,7 +389,13 @@
>                 };
>         };
>
> +#if CONFIG_IS_ENABLED(TEGRA_ENABLE_UARTA)
> +       uarta: serial at 70006000 {
> +#elif CONFIG_IS_ENABLED(TEGRA_ENABLE_UARTD)
>         uartd: serial at 70006300 {
> +#else
> +#error Unsupported UART
> +#endif
>                 status = "okay";
>                 clock-frequency = <216000000>;
>         };
> @@ -434,7 +453,12 @@
>         };
>
>         sdmmc3: sdhci at c8000400 {
> +#if CONFIG_IS_ENABLED(TEGRA_UARTA_MICROSD)
> +               /* Can't use both at the same time */
> +               status = "disabled";
> +#else
>                 status = "okay";
> +#endif
>                 bus-width = <4>;
>
>                 cd-gpios = <&gpio TEGRA_GPIO(I, 5) GPIO_ACTIVE_LOW>;
> diff --git a/arch/arm/mach-tegra/tegra20/Kconfig b/arch/arm/mach-tegra/tegra20/Kconfig
> index 3349f1e2786..c2c51660216 100644
> --- a/arch/arm/mach-tegra/tegra20/Kconfig
> +++ b/arch/arm/mach-tegra/tegra20/Kconfig
> @@ -77,6 +77,21 @@ endchoice
>  config SYS_SOC
>         default "tegra20"
>
> +config TEGRA_UARTA_MICROSD
> +       bool "UARTA on MicroSD breakout board"
> +       default n
> +       depends on TEGRA_ENABLE_UARTA && TARGET_TRANSFORMER_T20
> +       select TEGRA_UARTA_SDB_SDD
> +       help
> +         Repurpose the SD card slot for getting access to the UARTA serial
> +         console. Primarily useful only for low level u-boot debugging on
> +         tablets, where normal UARTD is difficult to access and requires
> +         device disassembly and/or soldering. Enabling this option causes
> +         UARTA TX to become exposed on SDD and RX on SDB pins which correspond
> +         to microSD CLK and CMD pins respectively. Currently this is supported
> +         only on Transformer T20, support for other platforms may require DT
> +         and configs (from include/configs/*) updates.
> +
>  source "board/nvidia/harmony/Kconfig"
>  source "board/avionic-design/medcom-wide/Kconfig"
>  source "board/compal/paz00/Kconfig"
> --
> 2.48.1
>

This is not applicable since this is a hack by nature, BUT if you
contain this in the transformer t20 board and Kconfig (no dts
changes), this may be applied.


More information about the U-Boot mailing list