mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-01-11 17:10:13 +00:00
The ports definition currently defined in the usb-switch.yaml fits standards devices which are either recipient of altmode muxing and orientation switching events or an element of the USB Super Speed data lanes. This doesn't necessarely fit combo PHYs like the Qualcomm USB3/DP Combo which has a different ports representation. Move the ports definition to a separate usb-switch-ports.yaml and reference it next to the usb-switch.yaml, except for the Qualcomm USB3/DP Combo PHY bindings. Reported-by: Rob Herring <robh@kernel.org> Closes: https://lore.kernel.org/all/175462129176.394940.16810637795278334342.robh@kernel.org/ Fixes: 3bad7fe22796 ("dt-bindings: phy: qcom,sc8280xp-qmp-usb43dp: Reference usb-switch.yaml to allow mode-switch") Signed-off-by: Neil Armstrong <neil.armstrong@linaro.org> Reviewed-by: Rob Herring (Arm) <robh@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
161 lines
3.4 KiB
YAML
161 lines
3.4 KiB
YAML
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/phy/fsl,imx8mq-usb-phy.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: Freescale i.MX8MQ USB3 PHY
|
|
|
|
maintainers:
|
|
- Li Jun <jun.li@nxp.com>
|
|
|
|
properties:
|
|
compatible:
|
|
oneOf:
|
|
- enum:
|
|
- fsl,imx8mq-usb-phy
|
|
- fsl,imx8mp-usb-phy
|
|
- items:
|
|
- const: fsl,imx95-usb-phy
|
|
- const: fsl,imx8mp-usb-phy
|
|
|
|
reg:
|
|
minItems: 1
|
|
maxItems: 2
|
|
|
|
"#phy-cells":
|
|
const: 0
|
|
|
|
clocks:
|
|
maxItems: 1
|
|
|
|
clock-names:
|
|
items:
|
|
- const: phy
|
|
|
|
power-domains:
|
|
maxItems: 1
|
|
|
|
vbus-supply:
|
|
description:
|
|
A phandle to the regulator for USB VBUS.
|
|
|
|
fsl,phy-tx-vref-tune-percent:
|
|
description:
|
|
Tunes the HS DC level relative to the nominal level
|
|
minimum: 90
|
|
maximum: 124
|
|
|
|
fsl,phy-tx-rise-tune-percent:
|
|
description:
|
|
Adjusts the rise/fall time duration of the HS waveform relative to
|
|
its nominal value
|
|
minimum: 90
|
|
maximum: 120
|
|
|
|
fsl,phy-tx-preemp-amp-tune-microamp:
|
|
description:
|
|
Adjust amount of current sourced to DPn and DMn after a J-to-K
|
|
or K-to-J transition. Default is 0 (disabled).
|
|
minimum: 0
|
|
maximum: 1800
|
|
|
|
fsl,phy-tx-vboost-level-microvolt:
|
|
description:
|
|
Adjust the boosted transmit launch pk-pk differential amplitude
|
|
enum: [844, 1008, 1156]
|
|
|
|
fsl,phy-comp-dis-tune-percent:
|
|
description:
|
|
Adjust the voltage level used to detect a disconnect event at the host
|
|
relative to the nominal value
|
|
minimum: 91
|
|
maximum: 115
|
|
|
|
fsl,phy-pcs-tx-deemph-3p5db-attenuation-db:
|
|
description:
|
|
Adjust TX de-emphasis attenuation in dB at nominal
|
|
3.5dB point as per USB specification
|
|
minimum: 0
|
|
maximum: 36
|
|
|
|
fsl,phy-pcs-tx-swing-full-percent:
|
|
description:
|
|
Scaling of the voltage defined by fsl,phy-tx-vboost-level-microvolt
|
|
minimum: 0
|
|
maximum: 100
|
|
|
|
required:
|
|
- compatible
|
|
- reg
|
|
- "#phy-cells"
|
|
- clocks
|
|
- clock-names
|
|
|
|
allOf:
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
contains:
|
|
enum:
|
|
- fsl,imx95-usb-phy
|
|
then:
|
|
properties:
|
|
reg:
|
|
items:
|
|
- description: USB PHY Control range
|
|
- description: USB PHY TCA Block range
|
|
else:
|
|
properties:
|
|
reg:
|
|
maxItems: 1
|
|
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- fsl,imx8mq-usb-phy
|
|
- fsl,imx8mp-usb-phy
|
|
then:
|
|
properties:
|
|
fsl,phy-tx-vref-tune-percent:
|
|
minimum: 94
|
|
fsl,phy-tx-rise-tune-percent:
|
|
minimum: 97
|
|
maximum: 103
|
|
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
contains:
|
|
enum:
|
|
- fsl,imx95-usb-phy
|
|
then:
|
|
properties:
|
|
fsl,phy-tx-vref-tune-percent:
|
|
maximum: 108
|
|
fsl,phy-comp-dis-tune-percent:
|
|
minimum: 94
|
|
maximum: 104
|
|
|
|
- if:
|
|
required:
|
|
- orientation-switch
|
|
then:
|
|
allOf:
|
|
- $ref: /schemas/usb/usb-switch.yaml#
|
|
- $ref: /schemas/usb/usb-switch-ports.yaml#
|
|
|
|
unevaluatedProperties: false
|
|
|
|
examples:
|
|
- |
|
|
#include <dt-bindings/clock/imx8mq-clock.h>
|
|
usb3_phy0: phy@381f0040 {
|
|
compatible = "fsl,imx8mq-usb-phy";
|
|
reg = <0x381f0040 0x40>;
|
|
clocks = <&clk IMX8MQ_CLK_USB1_PHY_ROOT>;
|
|
clock-names = "phy";
|
|
#phy-cells = <0>;
|
|
};
|