xref: /linux/Documentation/devicetree/bindings/usb/samsung,exynos-dwc3.yaml (revision ab93e0dd72c37d378dd936f031ffb83ff2bd87ce)
1949ea75bSKrzysztof Kozlowski# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2949ea75bSKrzysztof Kozlowski%YAML 1.2
3949ea75bSKrzysztof Kozlowski---
4949ea75bSKrzysztof Kozlowski$id: http://devicetree.org/schemas/usb/samsung,exynos-dwc3.yaml#
5949ea75bSKrzysztof Kozlowski$schema: http://devicetree.org/meta-schemas/core.yaml#
6949ea75bSKrzysztof Kozlowski
7949ea75bSKrzysztof Kozlowskititle: Samsung Exynos SoC USB 3.0 DWC3 Controller
8949ea75bSKrzysztof Kozlowski
9949ea75bSKrzysztof Kozlowskimaintainers:
108a1e6bb3SKrzysztof Kozlowski  - Krzysztof Kozlowski <krzk@kernel.org>
11949ea75bSKrzysztof Kozlowski
12949ea75bSKrzysztof Kozlowskiproperties:
13949ea75bSKrzysztof Kozlowski  compatible:
140a86e49aSIgor Belwon    oneOf:
150a86e49aSIgor Belwon      - enum:
16550c8877SAndré Draszik          - google,gs101-dwusb3
1741c69606SIvaylo Ivanov          - samsung,exynos2200-dwusb3
18949ea75bSKrzysztof Kozlowski          - samsung,exynos5250-dwusb3
19949ea75bSKrzysztof Kozlowski          - samsung,exynos5433-dwusb3
20949ea75bSKrzysztof Kozlowski          - samsung,exynos7-dwusb3
2143092fcdSKaustabh Chakraborty          - samsung,exynos7870-dwusb3
220c2dfb3eSSam Protsenko          - samsung,exynos850-dwusb3
23*6f399a10SPritam Manohar Sutar          - samsung,exynosautov920-dwusb3
240a86e49aSIgor Belwon      - items:
250a86e49aSIgor Belwon          - const: samsung,exynos990-dwusb3
260a86e49aSIgor Belwon          - const: samsung,exynos850-dwusb3
27949ea75bSKrzysztof Kozlowski
28949ea75bSKrzysztof Kozlowski  '#address-cells':
29949ea75bSKrzysztof Kozlowski    const: 1
30949ea75bSKrzysztof Kozlowski
31949ea75bSKrzysztof Kozlowski  clocks:
32949ea75bSKrzysztof Kozlowski    minItems: 1
33949ea75bSKrzysztof Kozlowski    maxItems: 4
34949ea75bSKrzysztof Kozlowski
35949ea75bSKrzysztof Kozlowski  clock-names:
36949ea75bSKrzysztof Kozlowski    minItems: 1
37949ea75bSKrzysztof Kozlowski    maxItems: 4
38949ea75bSKrzysztof Kozlowski
39949ea75bSKrzysztof Kozlowski  ranges: true
40949ea75bSKrzysztof Kozlowski
41949ea75bSKrzysztof Kozlowski  '#size-cells':
42949ea75bSKrzysztof Kozlowski    const: 1
43949ea75bSKrzysztof Kozlowski
44949ea75bSKrzysztof Kozlowski  vdd10-supply:
45949ea75bSKrzysztof Kozlowski    description: 1.0V power supply
46949ea75bSKrzysztof Kozlowski
47949ea75bSKrzysztof Kozlowski  vdd33-supply:
48949ea75bSKrzysztof Kozlowski    description: 3.0V/3.3V power supply
49949ea75bSKrzysztof Kozlowski
50949ea75bSKrzysztof KozlowskipatternProperties:
51949ea75bSKrzysztof Kozlowski  "^usb@[0-9a-f]+$":
52949ea75bSKrzysztof Kozlowski    $ref: snps,dwc3.yaml#
53949ea75bSKrzysztof Kozlowski    description: Required child node
54949ea75bSKrzysztof Kozlowski
55949ea75bSKrzysztof Kozlowskirequired:
56949ea75bSKrzysztof Kozlowski  - compatible
57949ea75bSKrzysztof Kozlowski  - '#address-cells'
58949ea75bSKrzysztof Kozlowski  - clocks
59949ea75bSKrzysztof Kozlowski  - clock-names
60949ea75bSKrzysztof Kozlowski  - ranges
61949ea75bSKrzysztof Kozlowski  - '#size-cells'
62949ea75bSKrzysztof Kozlowski  - vdd33-supply
63949ea75bSKrzysztof Kozlowski
64949ea75bSKrzysztof KozlowskiallOf:
65949ea75bSKrzysztof Kozlowski  - if:
66949ea75bSKrzysztof Kozlowski      properties:
67949ea75bSKrzysztof Kozlowski        compatible:
68949ea75bSKrzysztof Kozlowski          contains:
69550c8877SAndré Draszik            const: google,gs101-dwusb3
70550c8877SAndré Draszik    then:
71550c8877SAndré Draszik      properties:
72550c8877SAndré Draszik        clocks:
73550c8877SAndré Draszik          minItems: 4
74550c8877SAndré Draszik          maxItems: 4
75550c8877SAndré Draszik        clock-names:
76550c8877SAndré Draszik          items:
77550c8877SAndré Draszik            - const: bus_early
78550c8877SAndré Draszik            - const: susp_clk
79550c8877SAndré Draszik            - const: link_aclk
80550c8877SAndré Draszik            - const: link_pclk
8143092fcdSKaustabh Chakraborty      required:
8243092fcdSKaustabh Chakraborty        - vdd10-supply
83550c8877SAndré Draszik
84550c8877SAndré Draszik  - if:
85550c8877SAndré Draszik      properties:
86550c8877SAndré Draszik        compatible:
87550c8877SAndré Draszik          contains:
8841c69606SIvaylo Ivanov            const: samsung,exynos2200-dwusb3
8941c69606SIvaylo Ivanov    then:
9041c69606SIvaylo Ivanov      properties:
9141c69606SIvaylo Ivanov        clocks:
9241c69606SIvaylo Ivanov          maxItems: 1
9341c69606SIvaylo Ivanov        clock-names:
9441c69606SIvaylo Ivanov          items:
9541c69606SIvaylo Ivanov            - const: link_aclk
9641c69606SIvaylo Ivanov
9741c69606SIvaylo Ivanov  - if:
9841c69606SIvaylo Ivanov      properties:
9941c69606SIvaylo Ivanov        compatible:
10041c69606SIvaylo Ivanov          contains:
101949ea75bSKrzysztof Kozlowski            const: samsung,exynos5250-dwusb3
102949ea75bSKrzysztof Kozlowski    then:
103949ea75bSKrzysztof Kozlowski      properties:
104949ea75bSKrzysztof Kozlowski        clocks:
105949ea75bSKrzysztof Kozlowski          minItems: 1
106949ea75bSKrzysztof Kozlowski          maxItems: 1
107949ea75bSKrzysztof Kozlowski        clock-names:
108949ea75bSKrzysztof Kozlowski          items:
109949ea75bSKrzysztof Kozlowski            - const: usbdrd30
11043092fcdSKaustabh Chakraborty      required:
11143092fcdSKaustabh Chakraborty        - vdd10-supply
112949ea75bSKrzysztof Kozlowski
113949ea75bSKrzysztof Kozlowski  - if:
114949ea75bSKrzysztof Kozlowski      properties:
115949ea75bSKrzysztof Kozlowski        compatible:
116949ea75bSKrzysztof Kozlowski          contains:
11726f4f835SSam Protsenko            const: samsung,exynos5433-dwusb3
118949ea75bSKrzysztof Kozlowski    then:
119949ea75bSKrzysztof Kozlowski      properties:
120949ea75bSKrzysztof Kozlowski        clocks:
121949ea75bSKrzysztof Kozlowski          minItems: 4
122949ea75bSKrzysztof Kozlowski          maxItems: 4
123949ea75bSKrzysztof Kozlowski        clock-names:
124949ea75bSKrzysztof Kozlowski          items:
125949ea75bSKrzysztof Kozlowski            - const: aclk
126949ea75bSKrzysztof Kozlowski            - const: susp_clk
127949ea75bSKrzysztof Kozlowski            - const: phyclk
1288d4ff135SKrzysztof Kozlowski            - const: pipe_pclk
12943092fcdSKaustabh Chakraborty      required:
13043092fcdSKaustabh Chakraborty        - vdd10-supply
131949ea75bSKrzysztof Kozlowski
132949ea75bSKrzysztof Kozlowski  - if:
133949ea75bSKrzysztof Kozlowski      properties:
134949ea75bSKrzysztof Kozlowski        compatible:
135949ea75bSKrzysztof Kozlowski          contains:
136949ea75bSKrzysztof Kozlowski            const: samsung,exynos7-dwusb3
137949ea75bSKrzysztof Kozlowski    then:
138949ea75bSKrzysztof Kozlowski      properties:
139949ea75bSKrzysztof Kozlowski        clocks:
140949ea75bSKrzysztof Kozlowski          minItems: 3
141949ea75bSKrzysztof Kozlowski          maxItems: 3
142949ea75bSKrzysztof Kozlowski        clock-names:
143949ea75bSKrzysztof Kozlowski          items:
144949ea75bSKrzysztof Kozlowski            - const: usbdrd30
145949ea75bSKrzysztof Kozlowski            - const: usbdrd30_susp_clk
146949ea75bSKrzysztof Kozlowski            - const: usbdrd30_axius_clk
14743092fcdSKaustabh Chakraborty      required:
14843092fcdSKaustabh Chakraborty        - vdd10-supply
14943092fcdSKaustabh Chakraborty
15043092fcdSKaustabh Chakraborty  - if:
15143092fcdSKaustabh Chakraborty      properties:
15243092fcdSKaustabh Chakraborty        compatible:
15343092fcdSKaustabh Chakraborty          contains:
15443092fcdSKaustabh Chakraborty            const: samsung,exynos7870-dwusb3
15543092fcdSKaustabh Chakraborty    then:
15643092fcdSKaustabh Chakraborty      properties:
15743092fcdSKaustabh Chakraborty        clocks:
15843092fcdSKaustabh Chakraborty          minItems: 3
15943092fcdSKaustabh Chakraborty          maxItems: 3
16043092fcdSKaustabh Chakraborty        clock-names:
16143092fcdSKaustabh Chakraborty          items:
16243092fcdSKaustabh Chakraborty            - const: bus_early
16343092fcdSKaustabh Chakraborty            - const: ref
16443092fcdSKaustabh Chakraborty            - const: ctrl
165949ea75bSKrzysztof Kozlowski
1660c2dfb3eSSam Protsenko  - if:
1670c2dfb3eSSam Protsenko      properties:
1680c2dfb3eSSam Protsenko        compatible:
1690c2dfb3eSSam Protsenko          contains:
1700c2dfb3eSSam Protsenko            const: samsung,exynos850-dwusb3
1710c2dfb3eSSam Protsenko    then:
1720c2dfb3eSSam Protsenko      properties:
1730c2dfb3eSSam Protsenko        clocks:
1740c2dfb3eSSam Protsenko          minItems: 2
1750c2dfb3eSSam Protsenko          maxItems: 2
1760c2dfb3eSSam Protsenko        clock-names:
1770c2dfb3eSSam Protsenko          items:
1780c2dfb3eSSam Protsenko            - const: bus_early
1790c2dfb3eSSam Protsenko            - const: ref
18043092fcdSKaustabh Chakraborty      required:
18143092fcdSKaustabh Chakraborty        - vdd10-supply
1820c2dfb3eSSam Protsenko
183*6f399a10SPritam Manohar Sutar  - if:
184*6f399a10SPritam Manohar Sutar      properties:
185*6f399a10SPritam Manohar Sutar        compatible:
186*6f399a10SPritam Manohar Sutar          contains:
187*6f399a10SPritam Manohar Sutar            const: samsung,exynosautov920-dwusb3
188*6f399a10SPritam Manohar Sutar    then:
189*6f399a10SPritam Manohar Sutar      properties:
190*6f399a10SPritam Manohar Sutar        clocks:
191*6f399a10SPritam Manohar Sutar          minItems: 2
192*6f399a10SPritam Manohar Sutar          maxItems: 2
193*6f399a10SPritam Manohar Sutar        clock-names:
194*6f399a10SPritam Manohar Sutar          items:
195*6f399a10SPritam Manohar Sutar            - const: ref
196*6f399a10SPritam Manohar Sutar            - const: susp_clk
197*6f399a10SPritam Manohar Sutar
198949ea75bSKrzysztof KozlowskiadditionalProperties: false
199949ea75bSKrzysztof Kozlowski
200949ea75bSKrzysztof Kozlowskiexamples:
201949ea75bSKrzysztof Kozlowski  - |
202949ea75bSKrzysztof Kozlowski    #include <dt-bindings/clock/exynos5420.h>
203949ea75bSKrzysztof Kozlowski    #include <dt-bindings/interrupt-controller/arm-gic.h>
204949ea75bSKrzysztof Kozlowski
205d4f6b987SKrzysztof Kozlowski    usb@12000000 {
206949ea75bSKrzysztof Kozlowski        compatible = "samsung,exynos5250-dwusb3";
207949ea75bSKrzysztof Kozlowski        #address-cells = <1>;
208949ea75bSKrzysztof Kozlowski        #size-cells = <1>;
209d4f6b987SKrzysztof Kozlowski        ranges = <0x0 0x12000000 0x10000>;
210949ea75bSKrzysztof Kozlowski        clocks = <&clock CLK_USBD300>;
211949ea75bSKrzysztof Kozlowski        clock-names = "usbdrd30";
212949ea75bSKrzysztof Kozlowski        vdd33-supply = <&ldo9_reg>;
213949ea75bSKrzysztof Kozlowski        vdd10-supply = <&ldo11_reg>;
214949ea75bSKrzysztof Kozlowski
215d4f6b987SKrzysztof Kozlowski        usb@0 {
216949ea75bSKrzysztof Kozlowski            compatible = "snps,dwc3";
217d4f6b987SKrzysztof Kozlowski            reg = <0x0 0x10000>;
218949ea75bSKrzysztof Kozlowski            interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
219949ea75bSKrzysztof Kozlowski            phys = <&usbdrd_phy0 0>, <&usbdrd_phy0 1>;
220949ea75bSKrzysztof Kozlowski            phy-names = "usb2-phy", "usb3-phy";
221949ea75bSKrzysztof Kozlowski            snps,dis_u3_susphy_quirk;
222949ea75bSKrzysztof Kozlowski        };
223949ea75bSKrzysztof Kozlowski    };
224