1239e81247
Add support for usb3803, compared to usb3503 it uses a regular USB connection to upstream instead of HSIC, it has an additional low power mode (bypass) and an additional control signal (BYPASS_N). In bypass mode the downstream port 3 is connected to the upstream port with low switch resistance R_on. Signed-off-by: Emanuele Ghidoli <emanuele.ghidoli@toradex.com> Signed-off-by: Francesco Dolcini <francesco.dolcini@toradex.com> Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://lore.kernel.org/r/20230313165039.255579-2-francesco@dolcini.it Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
160 lines
3.8 KiB
YAML
160 lines
3.8 KiB
YAML
# SPDX-License-Identifier: GPL-2.0
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/usb/smsc,usb3503.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: SMSC USB3503 High-Speed Hub Controller
|
|
|
|
maintainers:
|
|
- Dongjin Kim <tobetter@gmail.com>
|
|
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- smsc,usb3503
|
|
- smsc,usb3503a
|
|
- smsc,usb3803
|
|
|
|
reg:
|
|
maxItems: 1
|
|
|
|
connect-gpios:
|
|
maxItems: 1
|
|
description: >
|
|
GPIO for connect
|
|
|
|
intn-gpios:
|
|
maxItems: 1
|
|
description: >
|
|
GPIO for interrupt
|
|
|
|
reset-gpios:
|
|
maxItems: 1
|
|
description: >
|
|
GPIO for reset
|
|
|
|
bypass-gpios:
|
|
maxItems: 1
|
|
description: >
|
|
GPIO for bypass.
|
|
Control signal to select between HUB MODE and BYPASS MODE.
|
|
|
|
disabled-ports:
|
|
$ref: /schemas/types.yaml#/definitions/uint32-array
|
|
minItems: 1
|
|
maxItems: 3
|
|
items:
|
|
minimum: 1
|
|
maximum: 3
|
|
description: >
|
|
Specifies the ports unused using their port number. Do not describe this
|
|
property if all ports have to be enabled.
|
|
|
|
initial-mode:
|
|
$ref: /schemas/types.yaml#/definitions/uint32
|
|
description: >
|
|
Specifies initial mode. 1 for Hub mode, 2 for standby mode and 3 for bypass mode.
|
|
In bypass mode the downstream port 3 is connected to the upstream port with low
|
|
switch resistance R_on.
|
|
|
|
clocks:
|
|
maxItems: 1
|
|
description: >
|
|
Clock used for driving REFCLK signal. If not provided the driver assumes
|
|
that clock signal is always available, its rate is specified by REF_SEL
|
|
pins and a value from the primary reference clock frequencies table is
|
|
used.
|
|
|
|
clock-names:
|
|
const: refclk
|
|
|
|
refclk-frequency:
|
|
$ref: /schemas/types.yaml#/definitions/uint32
|
|
description: >
|
|
Frequency of the REFCLK signal as defined by REF_SEL pins. If not
|
|
provided, driver will not set rate of the REFCLK signal and assume that a
|
|
value from the primary reference clock frequencies table is used.
|
|
|
|
required:
|
|
- compatible
|
|
|
|
allOf:
|
|
- if:
|
|
not:
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- smsc,usb3803
|
|
then:
|
|
properties:
|
|
bypass-gpios: false
|
|
|
|
- if:
|
|
required:
|
|
- bypass-gpios
|
|
then:
|
|
properties:
|
|
initial-mode:
|
|
enum: [1, 2, 3]
|
|
else:
|
|
properties:
|
|
initial-mode:
|
|
enum: [1, 2]
|
|
|
|
additionalProperties: false
|
|
|
|
examples:
|
|
- |
|
|
i2c {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
usb-hub@8 {
|
|
compatible = "smsc,usb3503";
|
|
reg = <0x08>;
|
|
connect-gpios = <&gpx3 0 1>;
|
|
disabled-ports = <2 3>;
|
|
intn-gpios = <&gpx3 4 1>;
|
|
reset-gpios = <&gpx3 5 1>;
|
|
initial-mode = <1>;
|
|
clocks = <&clks 80>;
|
|
clock-names = "refclk";
|
|
};
|
|
};
|
|
|
|
- |
|
|
i2c {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
usb-hub@8 {
|
|
compatible = "smsc,usb3803";
|
|
reg = <0x08>;
|
|
connect-gpios = <&gpx3 0 1>;
|
|
disabled-ports = <2 3>;
|
|
intn-gpios = <&gpx3 4 1>;
|
|
reset-gpios = <&gpx3 5 1>;
|
|
bypass-gpios = <&gpx3 6 1>;
|
|
initial-mode = <3>;
|
|
clocks = <&clks 80>;
|
|
clock-names = "refclk";
|
|
};
|
|
};
|
|
|
|
- |
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
|
|
usb-hub {
|
|
/* I2C is not connected */
|
|
compatible = "smsc,usb3503";
|
|
initial-mode = <1>; /* initialize in HUB mode */
|
|
disabled-ports = <1>;
|
|
intn-gpios = <&pio 7 5 GPIO_ACTIVE_HIGH>; /* PH5 */
|
|
reset-gpios = <&pio 4 16 GPIO_ACTIVE_LOW>; /* PE16 */
|
|
connect-gpios = <&pio 4 17 GPIO_ACTIVE_HIGH>; /* PE17 */
|
|
refclk-frequency = <19200000>;
|
|
};
|
|
|
|
...
|