Re: [PATCH v2] arm64: dts: imx8mn-var-som-symphony: fix USB OTG

From: Shawn Guo
Date: Tue Jul 18 2023 - 02:38:08 EST


On Wed, Jul 05, 2023 at 01:49:32PM -0400, Hugo Villeneuve wrote:
> From: Hugo Villeneuve <hvilleneuve@xxxxxxxxxxxx>
>
> USB OTG is currently broken on the Variscite Symphony EVK and imx8mn
> nano SOM.
>
> The PTN5150 circuitry on newer versions of the Symphony EVK board has
> a non-standard configuration in which the PTN5150 IRQ pin is left
> unconnected, and the PTN5150 ID pin is connected to GPIO1_IO11. This
> requires changes to the ptn5150 driver to support this new mode.
> Variscite have indicated their intention to submit those changes
> upstream.
>
> In the meantime, import device tree changes from linux-5.15 branch of
> varigit repos to at least make the USB OTG port operate correctly in
> host mode.
>
> Fixes: 7358e05bddca ("arm64: dts: imx8mn-var-som-symphony: Add Variscite Symphony board with VAR-SOM-MX8MN")

Has USB OTG been ever worked at all? If the answer is no, it's not
a fix but a new feature, and I would suggest you rework the patch
subject and drop the Fixes tag.

Shawn

> Signed-off-by: Hugo Villeneuve <hvilleneuve@xxxxxxxxxxxx>
> ---
> Link: [v1] https://lkml.org/lkml/2023/7/4/702
>
> Changes from v1:
> - Add comments about PTN5150 IRQ/ID line connections
> - Remove "typec1_con: connector" node
> - Change IRQ type to IRQ_TYPE_EDGE_FALLING
>
> .../dts/freescale/imx8mn-var-som-symphony.dts | 32 +++++++++++++++++--
> 1 file changed, 30 insertions(+), 2 deletions(-)
>
> diff --git a/arch/arm64/boot/dts/freescale/imx8mn-var-som-symphony.dts b/arch/arm64/boot/dts/freescale/imx8mn-var-som-symphony.dts
> index 406a711486da..a7a57442cb81 100644
> --- a/arch/arm64/boot/dts/freescale/imx8mn-var-som-symphony.dts
> +++ b/arch/arm64/boot/dts/freescale/imx8mn-var-som-symphony.dts
> @@ -1,11 +1,14 @@
> // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> /*
> + * Supports Symphony evaluation board versions >= 1.4a.
> + *
> * Copyright 2019-2020 Variscite Ltd.
> * Copyright (C) 2020 Krzysztof Kozlowski <krzk@xxxxxxxxxx>
> */
>
> /dts-v1/;
>
> +#include <dt-bindings/usb/pd.h>
> #include "imx8mn-var-som.dtsi"
>
> / {
> @@ -100,14 +103,26 @@ enet-sel-hog {
> };
> };
>
> + /*
> + * For Symphony board version <= 1.4, the PTN5150 IRQ pin is connected
> + * to GPIO1_IO11 on the SoM (R106 present, R132 absent). From Symphony
> + * board version >= 1.4a, the PTN5150 ID pin is connected to GPIO1_IO11
> + * on the SoM (R106 absent, R132 present).
> + */
> extcon_usbotg1: typec@3d {
> compatible = "nxp,ptn5150";
> reg = <0x3d>;
> interrupt-parent = <&gpio1>;
> - interrupts = <11 IRQ_TYPE_LEVEL_LOW>;
> + interrupts = <11 IRQ_TYPE_EDGE_FALLING>;
> pinctrl-names = "default";
> pinctrl-0 = <&pinctrl_ptn5150>;
> status = "okay";
> +
> + port {
> + typec1_dr_sw: endpoint {
> + remote-endpoint = <&usb1_drd_sw>;
> + };
> + };
> };
> };
>
> @@ -148,8 +163,21 @@ &uart3 {
> };
>
> &usbotg1 {
> + dr_mode = "otg";
> + hnp-disable;
> + srp-disable;
> + adp-disable;
> + usb-role-switch;
> disable-over-current;
> - extcon = <&extcon_usbotg1>, <&extcon_usbotg1>;
> + samsung,picophy-pre-emp-curr-control = <3>;
> + samsung,picophy-dc-vol-level-adjust = <7>;
> + status = "okay";
> +
> + port {
> + usb1_drd_sw: endpoint {
> + remote-endpoint = <&typec1_dr_sw>;
> + };
> + };
> };
>
> &iomuxc {
>
> base-commit: d528014517f2b0531862c02865b9d4c908019dc4
> --
> 2.30.2
>