Re: [PATCH v2 1/9] dt-bindings: soc: qcom: eud: Restructure to model multi-path hardware

From: Konrad Dybcio

Date: Tue Feb 03 2026 - 08:36:14 EST


On 1/27/26 12:38 AM, Elson Serrao wrote:
> The Qualcomm Embedded USB Debugger (EUD) can intercept one or two
> independent High-Speed UTMI paths, depending on the SoC. Each path is
> distinct with its own HS-PHY interface, connector/controller wiring, and
> UTMI routing behavior. The EUD hardware sits between the USB2 PHY and
> the USB controller on each path.
>
> The existing binding models only a single UTMI path and does not provide
> a way to associate the required High-Speed USB PHY. EUD relies on the
> HS-PHY on the selected UTMI path for link signalling and correct operation
> of the hardware.
>
> Historically, EUD has worked on platforms that use a single UTMI path
> because the USB controller maintains ownership of the PHY during
> enumeration and normal operation. This implicit relationship allowed
> EUD to function even though the dependency on the PHY was not described
> in the binding. However, this behavior is not guaranteed by hardware.
> The current binding description is not sufficient for SoCs that expose
> two independent UTMI paths, where the PHY association and port wiring
> must be explicitly described.
>
> Introduce per-path eud-path child nodes so each UTMI path can describe
> its HS-PHY, port connections, and the role‑switching capability of its
> associated USB port.
>
> Signed-off-by: Elson Serrao <elson.serrao@xxxxxxxxxxxxxxxx>
> ---

[...]

> +patternProperties:
> + "^eud-path@[0-1]$":

I can't quite put it into words why I don't like this name, but I
don't like this name.. That said I don't really have any clever ideas
for a better one, so I'm not going to object, suppose I just needed
to vent my ramblings

> + type: object
> description:
> - These ports is to be attached to the endpoint of the DWC3 controller node
> - and type C connector node. The controller has the "usb-role-switch"
> - property.
> + Represents one High-Speed UTMI path that EUD intercepts. This node models
> + the physical data path intercepted by EUD and provides graph endpoints to
> + link the USB controller and the external connector associated with this path.
>
> properties:
> - port@0:
> - $ref: /schemas/graph.yaml#/properties/port
> - description: This port is to be attached to the DWC3 controller.
> + reg:
> + maxItems: 1
> + description: Path number
> +
> + phys:
> + maxItems: 1
> + description: High-Speed USB PHY associated with this data path.
> +
> + usb-role-switch:
> + type: boolean
> + description:
> + Set this property if the USB port on this path is role switch capable.

This doesn't quite sound right. The EUD acts/can act as a rolesw no matter
what's connected to it.

> + In device role, debug mode inserts the EUD hub into the UTMI path. In
> + host role, the EUD hub is bypassed and UTMI traffic flows directly
> + between the PHY and the USB controller.

The rest of this paragraph is good stuff, explaining the reasoning

> +
> + ports:
> + $ref: /schemas/graph.yaml#/properties/ports
> + description:
> + These ports are to be attached to the endpoint of the USB controller node
> + and USB connector node.
> +
> + properties:
> + port@0:
> + $ref: /schemas/graph.yaml#/properties/port
> + description: This port is to be attached to the USB controller.
>
> - port@1:
> - $ref: /schemas/graph.yaml#/properties/port
> - description: This port is to be attached to the type C connector.

nit: "Type-C"

Konrad