18c2ecf20Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
28c2ecf20Sopenharmony_ci# Copyright (c) 2020 Facebook Inc.
38c2ecf20Sopenharmony_ci%YAML 1.2
48c2ecf20Sopenharmony_ci---
58c2ecf20Sopenharmony_ci$id: http://devicetree.org/schemas/usb/aspeed,usb-vhub.yaml#
68c2ecf20Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_cititle: ASPEED USB 2.0 Virtual Hub Controller
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_cimaintainers:
118c2ecf20Sopenharmony_ci  - Benjamin Herrenschmidt <benh@kernel.crashing.org>
128c2ecf20Sopenharmony_ci
138c2ecf20Sopenharmony_cidescription: |+
148c2ecf20Sopenharmony_ci  The ASPEED USB 2.0 Virtual Hub Controller implements 1 set of USB Hub
158c2ecf20Sopenharmony_ci  register and several sets of Device and Endpoint registers to support
168c2ecf20Sopenharmony_ci  the Virtual Hub's downstream USB devices.
178c2ecf20Sopenharmony_ci
188c2ecf20Sopenharmony_ci  Supported number of devices and endpoints vary depending on hardware
198c2ecf20Sopenharmony_ci  revisions. AST2400 and AST2500 Virtual Hub supports 5 downstream devices
208c2ecf20Sopenharmony_ci  and 15 generic endpoints, while AST2600 Virtual Hub supports 7 downstream
218c2ecf20Sopenharmony_ci  devices and 21 generic endpoints.
228c2ecf20Sopenharmony_ci
238c2ecf20Sopenharmony_ciproperties:
248c2ecf20Sopenharmony_ci  compatible:
258c2ecf20Sopenharmony_ci    enum:
268c2ecf20Sopenharmony_ci      - aspeed,ast2400-usb-vhub
278c2ecf20Sopenharmony_ci      - aspeed,ast2500-usb-vhub
288c2ecf20Sopenharmony_ci      - aspeed,ast2600-usb-vhub
298c2ecf20Sopenharmony_ci
308c2ecf20Sopenharmony_ci  reg:
318c2ecf20Sopenharmony_ci    maxItems: 1
328c2ecf20Sopenharmony_ci
338c2ecf20Sopenharmony_ci  clocks:
348c2ecf20Sopenharmony_ci    maxItems: 1
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci  interrupts:
378c2ecf20Sopenharmony_ci    maxItems: 1
388c2ecf20Sopenharmony_ci
398c2ecf20Sopenharmony_ci  aspeed,vhub-downstream-ports:
408c2ecf20Sopenharmony_ci    description: Number of downstream ports supported by the Virtual Hub
418c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
428c2ecf20Sopenharmony_ci    default: 5
438c2ecf20Sopenharmony_ci    minimum: 1
448c2ecf20Sopenharmony_ci    maximum: 7
458c2ecf20Sopenharmony_ci
468c2ecf20Sopenharmony_ci  aspeed,vhub-generic-endpoints:
478c2ecf20Sopenharmony_ci    description: Number of generic endpoints supported by the Virtual Hub
488c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
498c2ecf20Sopenharmony_ci    default: 15
508c2ecf20Sopenharmony_ci    minimum: 1
518c2ecf20Sopenharmony_ci    maximum: 21
528c2ecf20Sopenharmony_ci
538c2ecf20Sopenharmony_ci  vhub-vendor-id:
548c2ecf20Sopenharmony_ci    description: vhub Vendor ID
558c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
568c2ecf20Sopenharmony_ci    maximum: 65535
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ci  vhub-product-id:
598c2ecf20Sopenharmony_ci    description: vhub Product ID
608c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
618c2ecf20Sopenharmony_ci    maximum: 65535
628c2ecf20Sopenharmony_ci
638c2ecf20Sopenharmony_ci  vhub-device-revision:
648c2ecf20Sopenharmony_ci    description: vhub Device Revision in binary-coded decimal
658c2ecf20Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
668c2ecf20Sopenharmony_ci    maximum: 65535
678c2ecf20Sopenharmony_ci
688c2ecf20Sopenharmony_ci  vhub-strings:
698c2ecf20Sopenharmony_ci    type: object
708c2ecf20Sopenharmony_ci
718c2ecf20Sopenharmony_ci    properties:
728c2ecf20Sopenharmony_ci      '#address-cells':
738c2ecf20Sopenharmony_ci        const: 1
748c2ecf20Sopenharmony_ci
758c2ecf20Sopenharmony_ci      '#size-cells':
768c2ecf20Sopenharmony_ci        const: 0
778c2ecf20Sopenharmony_ci
788c2ecf20Sopenharmony_ci    patternProperties:
798c2ecf20Sopenharmony_ci      '^string@[0-9a-f]+$':
808c2ecf20Sopenharmony_ci        type: object
818c2ecf20Sopenharmony_ci        description: string descriptors of the specific language
828c2ecf20Sopenharmony_ci
838c2ecf20Sopenharmony_ci        properties:
848c2ecf20Sopenharmony_ci          reg:
858c2ecf20Sopenharmony_ci            maxItems: 1
868c2ecf20Sopenharmony_ci            description: 16-bit Language Identifier defined by USB-IF
878c2ecf20Sopenharmony_ci
888c2ecf20Sopenharmony_ci          manufacturer:
898c2ecf20Sopenharmony_ci            description: vhub manufacturer
908c2ecf20Sopenharmony_ci            $ref: /schemas/types.yaml#/definitions/string
918c2ecf20Sopenharmony_ci
928c2ecf20Sopenharmony_ci          product:
938c2ecf20Sopenharmony_ci            description: vhub product name
948c2ecf20Sopenharmony_ci            $ref: /schemas/types.yaml#/definitions/string
958c2ecf20Sopenharmony_ci
968c2ecf20Sopenharmony_ci          serial-number:
978c2ecf20Sopenharmony_ci            description: vhub device serial number
988c2ecf20Sopenharmony_ci            $ref: /schemas/types.yaml#/definitions/string
998c2ecf20Sopenharmony_ci
1008c2ecf20Sopenharmony_cirequired:
1018c2ecf20Sopenharmony_ci  - compatible
1028c2ecf20Sopenharmony_ci  - reg
1038c2ecf20Sopenharmony_ci  - clocks
1048c2ecf20Sopenharmony_ci  - interrupts
1058c2ecf20Sopenharmony_ci  - aspeed,vhub-downstream-ports
1068c2ecf20Sopenharmony_ci  - aspeed,vhub-generic-endpoints
1078c2ecf20Sopenharmony_ci
1088c2ecf20Sopenharmony_ciadditionalProperties: false
1098c2ecf20Sopenharmony_ci
1108c2ecf20Sopenharmony_ciexamples:
1118c2ecf20Sopenharmony_ci  - |
1128c2ecf20Sopenharmony_ci    #include <dt-bindings/clock/aspeed-clock.h>
1138c2ecf20Sopenharmony_ci    vhub: usb-vhub@1e6a0000 {
1148c2ecf20Sopenharmony_ci            compatible = "aspeed,ast2500-usb-vhub";
1158c2ecf20Sopenharmony_ci            reg = <0x1e6a0000 0x300>;
1168c2ecf20Sopenharmony_ci            interrupts = <5>;
1178c2ecf20Sopenharmony_ci            clocks = <&syscon ASPEED_CLK_GATE_USBPORT1CLK>;
1188c2ecf20Sopenharmony_ci            aspeed,vhub-downstream-ports = <5>;
1198c2ecf20Sopenharmony_ci            aspeed,vhub-generic-endpoints = <15>;
1208c2ecf20Sopenharmony_ci            pinctrl-names = "default";
1218c2ecf20Sopenharmony_ci            pinctrl-0 = <&pinctrl_usb2ad_default>;
1228c2ecf20Sopenharmony_ci
1238c2ecf20Sopenharmony_ci            vhub-vendor-id = <0x1d6b>;
1248c2ecf20Sopenharmony_ci            vhub-product-id = <0x0107>;
1258c2ecf20Sopenharmony_ci            vhub-device-revision = <0x0100>;
1268c2ecf20Sopenharmony_ci            vhub-strings {
1278c2ecf20Sopenharmony_ci                #address-cells = <1>;
1288c2ecf20Sopenharmony_ci                #size-cells = <0>;
1298c2ecf20Sopenharmony_ci
1308c2ecf20Sopenharmony_ci                string@409 {
1318c2ecf20Sopenharmony_ci                        reg = <0x409>;
1328c2ecf20Sopenharmony_ci                        manufacturer = "ASPEED";
1338c2ecf20Sopenharmony_ci                        product = "USB Virtual Hub";
1348c2ecf20Sopenharmony_ci                        serial-number = "0000";
1358c2ecf20Sopenharmony_ci                };
1368c2ecf20Sopenharmony_ci            };
1378c2ecf20Sopenharmony_ci    };
138