This patch adds binding descriptions to support the dwc3 controller
on HiSilicon SoCs and boards like the HiKey960.

Cc: Greg Kroah-Hartman <gre...@linuxfoundation.org>
Cc: Rob Herring <robh...@kernel.org>
Cc: Mark Rutland <mark.rutl...@arm.com>
Cc: John Stultz <john.stu...@linaro.org>
Signed-off-by: Yu Chen <cheny...@huawei.com>
---
 .../devicetree/bindings/usb/dwc3-hisi.txt          | 67 ++++++++++++++++++++++
 1 file changed, 67 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/usb/dwc3-hisi.txt

diff --git a/Documentation/devicetree/bindings/usb/dwc3-hisi.txt 
b/Documentation/devicetree/bindings/usb/dwc3-hisi.txt
new file mode 100644
index 000000000000..d32d2299a0a1
--- /dev/null
+++ b/Documentation/devicetree/bindings/usb/dwc3-hisi.txt
@@ -0,0 +1,67 @@
+HiSilicon DWC3 USB SoC controller
+
+This file documents the parameters for the dwc3-hisi driver.
+
+Required properties:
+- compatible:  should be "hisilicon,hi3660-dwc3"
+- clocks:      A list of phandle + clock-specifier pairs for the
+               clocks listed in clock-names
+- clock-names: Specify clock names
+- resets:      list of phandle and reset specifier pairs.
+
+Sub-nodes:
+The dwc3 core should be added as subnode to HiSilicon DWC3 as shown in the
+example below. The DT binding details of dwc3 can be found in:
+Documentation/devicetree/bindings/usb/dwc3.txt
+
+Example:
+       usb3: hisi_dwc3 {
+               compatible = "hisilicon,hi3660-dwc3";
+               #address-cells = <2>;
+               #size-cells = <2>;
+               ranges;
+
+               clocks = <&crg_ctrl HI3660_CLK_ABB_USB>,
+                        <&crg_ctrl HI3660_ACLK_GATE_USB3OTG>;
+               clock-names = "clk_usb3phy_ref", "aclk_usb3otg";
+               assigned-clocks = <&crg_ctrl HI3660_ACLK_GATE_USB3OTG>;
+               assigned-clock-rates = <229000000>;
+               resets = <&crg_rst 0x90 8>,
+                        <&crg_rst 0x90 7>,
+                        <&crg_rst 0x90 6>,
+                        <&crg_rst 0x90 5>;
+
+               dwc3: dwc3@ff100000 {
+                       compatible = "snps,dwc3";
+                       reg = <0x0 0xff100000 0x0 0x100000>;
+                       interrupts = <0 159 4>, <0 161 4>;
+                       phys = <&usb_phy>;
+                       phy-names = "usb3-phy";
+                       dr_mode = "otg";
+                       maximum-speed = "super-speed";
+                       phy_type = "utmi";
+                       snps,dis-del-phy-power-chg-quirk;
+                       snps,lfps_filter_quirk;
+                       snps,dis_u2_susphy_quirk;
+                       snps,dis_u3_susphy_quirk;
+                       snps,tx_de_emphasis_quirk;
+                       snps,tx_de_emphasis = <1>;
+                       snps,dis_enblslpm_quirk;
+                       snps,gctl-reset-quirk;
+
+                       port {
+                               #address-cells = <1>;
+                               #size-cells = <0>;
+
+                               dwc3_role_switch: endpoint@0 {
+                                       reg = <0>;
+                                       remote-endpoint = <&rt1711h_ep>;
+                               };
+
+                               dwc3_role_switch_notify: endpoint@1 {
+                                       reg = <1>;
+                                       remote-endpoint = <&hikey_usb_ep>;
+                               };
+                       };
+               };
+       };
-- 
2.15.0-rc2

Reply via email to