1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 2# Copyright (c) 2020 MediaTek 3%YAML 1.2 4--- 5$id: http://devicetree.org/schemas/usb/mediatek,musb.yaml# 6$schema: http://devicetree.org/meta-schemas/core.yaml# 7 8title: MediaTek MUSB DRD/OTG Controller Device Tree Bindings 9 10maintainers: 11 - Min Guo <min.guo@mediatek.com> 12 13properties: 14 $nodename: 15 pattern: '^usb@[0-9a-f]+$' 16 17 compatible: 18 items: 19 - enum: 20 - mediatek,mt8516-musb 21 - mediatek,mt2701-musb 22 - const: mediatek,mtk-musb 23 24 reg: 25 maxItems: 1 26 27 interrupts: 28 maxItems: 1 29 30 interrupt-names: 31 items: 32 - const: mc 33 34 clocks: 35 items: 36 - description: The main/core clock 37 - description: The system bus clock 38 - description: The 48Mhz clock 39 40 clock-names: 41 items: 42 - const: main 43 - const: mcu 44 - const: univpll 45 46 phys: 47 maxItems: 1 48 49 usb-role-switch: 50 $ref: /schemas/types.yaml#/definitions/flag 51 description: Support role switch. See usb/generic.txt 52 type: boolean 53 54 dr_mode: 55 enum: 56 - host 57 - otg 58 - peripheral 59 60 power-domains: 61 description: A phandle to USB power domain node to control USB's MTCMOS 62 maxItems: 1 63 64 connector: 65 $ref: /connector/usb-connector.yaml# 66 description: Connector for dual role switch 67 type: object 68 69dependencies: 70 usb-role-switch: [ 'connector' ] 71 connector: [ 'usb-role-switch' ] 72 73required: 74 - compatible 75 - reg 76 - interrupts 77 - interrupt-names 78 - phys 79 - clocks 80 - clock-names 81 82additionalProperties: false 83 84examples: 85 - | 86 #include <dt-bindings/clock/mt2701-clk.h> 87 #include <dt-bindings/gpio/gpio.h> 88 #include <dt-bindings/interrupt-controller/arm-gic.h> 89 #include <dt-bindings/interrupt-controller/irq.h> 90 #include <dt-bindings/phy/phy.h> 91 #include <dt-bindings/power/mt2701-power.h> 92 93 usb@11200000 { 94 compatible = "mediatek,mt2701-musb", "mediatek,mtk-musb"; 95 reg = <0x11200000 0x1000>; 96 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_LOW>; 97 interrupt-names = "mc"; 98 phys = <&u2port2 PHY_TYPE_USB2>; 99 dr_mode = "otg"; 100 clocks = <&pericfg CLK_PERI_USB0>, 101 <&pericfg CLK_PERI_USB0_MCU>, 102 <&pericfg CLK_PERI_USB_SLV>; 103 clock-names = "main","mcu","univpll"; 104 power-domains = <&scpsys MT2701_POWER_DOMAIN_IFR_MSC>; 105 usb-role-switch; 106 107 connector { 108 compatible = "gpio-usb-b-connector", "usb-b-connector"; 109 type = "micro"; 110 id-gpios = <&pio 44 GPIO_ACTIVE_HIGH>; 111 vbus-supply = <&usb_vbus>; 112 }; 113 }; 114... 115