Documentation / devicetree / bindings / usb / usb-hub.yaml


Based on kernel version 6.16. Page generated on 2025-08-06 08:57 EST.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
%YAML 1.2
---
$id: http://devicetree.org/schemas/usb/usb-hub.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: Generic USB Hub

maintainers:
  - Pin-yen Lin <treapking@chromium.org>

allOf:
  - $ref: usb-device.yaml#

properties:
  '#address-cells':
    const: 1

  peer-hub:
    $ref: /schemas/types.yaml#/definitions/phandle
    description:
      phandle to the peer hub on the controller.

  ports:
    $ref: /schemas/graph.yaml#/properties/ports
    description:
      The downstream facing USB ports

    patternProperties:
      "^port@[1-9a-f][0-9a-f]*$":
        $ref: /schemas/graph.yaml#/properties/port

patternProperties:
  '^.*@[1-9a-f][0-9a-f]*$':
    description: The hard wired USB devices
    type: object
    $ref: /schemas/usb/usb-device.yaml
    additionalProperties: true

required:
  - compatible
  - reg

additionalProperties: true

examples:
  - |
    usb {
        #address-cells = <1>;
        #size-cells = <0>;
 
        /* 2.0 hub on port 1 */
        hub_2_0: hub@1 {
            compatible = "usb123,4567";
            reg = <1>;
            peer-hub = <&hub_3_0>;
            #address-cells = <1>;
            #size-cells = <0>;
            /* USB 2.0 device on port 5 */
            device@5 {
                reg = <5>;
                compatible = "usb765,4321";
            };
        };
 
        /* 3.0 hub on port 2 */
        hub_3_0: hub@2 {
            compatible = "usb123,abcd";
            reg = <2>;
            peer-hub = <&hub_2_0>;
 
            ports {
                #address-cells = <1>;
                #size-cells = <0>;
                /* Type-A connector on port 3 */
                port@3 {
                    reg = <3>;
                    endpoint {
                        remote-endpoint = <&usb_a0_ss>;
                    };
                };
            };
        };
    };