blob: f4262ed60582d31bcb807f7d5ac2f2b1ae66462d [file] [log] [blame]
Jean-Christophe PLAGNIOL-VILLARD24197302011-11-21 06:55:18 +08001Atmel SOC USB controllers
2
3OHCI
4
5Required properties:
6 - compatible: Should be "atmel,at91rm9200-ohci" for USB controllers
7 used in host mode.
Boris Brezillonb34e96b2015-03-17 17:15:48 +01008 - reg: Address and length of the register set for the device
9 - interrupts: Should contain ehci interrupt
10 - clocks: Should reference the peripheral, host and system clocks
11 - clock-names: Should contains two strings
12 "ohci_clk" for the peripheral clock
13 "hclk" for the host clock
14 "uhpck" for the system clock
Jean-Christophe PLAGNIOL-VILLARD24197302011-11-21 06:55:18 +080015 - num-ports: Number of ports.
16 - atmel,vbus-gpio: If present, specifies a gpio that needs to be
17 activated for the bus to be powered.
18 - atmel,oc-gpio: If present, specifies a gpio that needs to be
19 activated for the overcurrent detection.
20
21usb0: ohci@00500000 {
22 compatible = "atmel,at91rm9200-ohci", "usb-ohci";
23 reg = <0x00500000 0x100000>;
Boris Brezillonb34e96b2015-03-17 17:15:48 +010024 clocks = <&uhphs_clk>, <&uhphs_clk>, <&uhpck>;
25 clock-names = "ohci_clk", "hclk", "uhpck";
Jean-Christophe PLAGNIOL-VILLARD24197302011-11-21 06:55:18 +080026 interrupts = <20 4>;
27 num-ports = <2>;
28};
Jean-Christophe PLAGNIOL-VILLARD9d843002011-11-22 12:11:13 +080029
30EHCI
31
32Required properties:
33 - compatible: Should be "atmel,at91sam9g45-ehci" for USB controllers
34 used in host mode.
Boris Brezillonb34e96b2015-03-17 17:15:48 +010035 - reg: Address and length of the register set for the device
36 - interrupts: Should contain ehci interrupt
37 - clocks: Should reference the peripheral and the UTMI clocks
38 - clock-names: Should contains two strings
39 "ehci_clk" for the peripheral clock
40 "usb_clk" for the UTMI clock
Jean-Christophe PLAGNIOL-VILLARD9d843002011-11-22 12:11:13 +080041
42usb1: ehci@00800000 {
43 compatible = "atmel,at91sam9g45-ehci", "usb-ehci";
44 reg = <0x00800000 0x100000>;
45 interrupts = <22 4>;
Boris Brezillonb34e96b2015-03-17 17:15:48 +010046 clocks = <&utmi>, <&uhphs_clk>;
47 clock-names = "usb_clk", "ehci_clk";
Jean-Christophe PLAGNIOL-VILLARD9d843002011-11-22 12:11:13 +080048};
Jean-Christophe PLAGNIOL-VILLARDd1494a32012-01-28 22:35:36 +080049
50AT91 USB device controller
51
52Required properties:
Boris Brezillon62b986c2015-01-14 17:22:03 +010053 - compatible: Should be one of the following
54 "atmel,at91rm9200-udc"
55 "atmel,at91sam9260-udc"
56 "atmel,at91sam9261-udc"
57 "atmel,at91sam9263-udc"
Jean-Christophe PLAGNIOL-VILLARDd1494a32012-01-28 22:35:36 +080058 - reg: Address and length of the register set for the device
59 - interrupts: Should contain macb interrupt
Boris Brezillon31b817b2015-01-14 17:21:59 +010060 - clocks: Should reference the peripheral and the AHB clocks
61 - clock-names: Should contains two strings
62 "pclk" for the peripheral clock
63 "hclk" for the AHB clock
Jean-Christophe PLAGNIOL-VILLARDd1494a32012-01-28 22:35:36 +080064
65Optional properties:
66 - atmel,vbus-gpio: If present, specifies a gpio that needs to be
67 activated for the bus to be powered.
68
69usb1: gadget@fffa4000 {
70 compatible = "atmel,at91rm9200-udc";
71 reg = <0xfffa4000 0x4000>;
72 interrupts = <10 4>;
Boris Brezillonb34e96b2015-03-17 17:15:48 +010073 clocks = <&udc_clk>, <&udpck>;
74 clock-names = "pclk", "hclk";
Jean-Christophe PLAGNIOL-VILLARDd1494a32012-01-28 22:35:36 +080075 atmel,vbus-gpio = <&pioC 5 0>;
76};
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +080077
78Atmel High-Speed USB device controller
79
80Required properties:
Boris Brezillon3280e672015-01-06 14:46:58 +010081 - compatible: Should be one of the following
Nicolas Ferre50f0a442015-06-17 10:59:04 +020082 "atmel,at91sam9rl-udc"
83 "atmel,at91sam9g45-udc"
84 "atmel,sama5d3-udc"
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +080085 - reg: Address and length of the register set for the device
86 - interrupts: Should contain usba interrupt
Boris Brezillonb34e96b2015-03-17 17:15:48 +010087 - clocks: Should reference the peripheral and host clocks
88 - clock-names: Should contains two strings
89 "pclk" for the peripheral clock
90 "hclk" for the host clock
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +080091 - ep childnode: To specify the number of endpoints and their properties.
92
93Optional properties:
Alexandre Belloni028ab4d2014-02-27 16:45:10 +010094 - atmel,vbus-gpio: If present, specifies a gpio that allows to detect whether
95 vbus is present (USB is connected).
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +080096
97Required child node properties:
98 - name: Name of the endpoint.
99 - reg: Num of the endpoint.
100 - atmel,fifo-size: Size of the fifo.
101 - atmel,nb-banks: Number of banks.
102 - atmel,can-dma: Boolean to specify if the endpoint support DMA.
103 - atmel,can-isoc: Boolean to specify if the endpoint support ISOC.
104
105usb2: gadget@fff78000 {
106 #address-cells = <1>;
107 #size-cells = <0>;
108 compatible = "atmel,at91sam9rl-udc";
109 reg = <0x00600000 0x80000
110 0xfff78000 0x400>;
111 interrupts = <27 4 0>;
Boris Brezillonb34e96b2015-03-17 17:15:48 +0100112 clocks = <&utmi>, <&udphs_clk>;
113 clock-names = "hclk", "pclk";
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800114 atmel,vbus-gpio = <&pioB 19 0>;
115
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200116 ep@0 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800117 reg = <0>;
118 atmel,fifo-size = <64>;
119 atmel,nb-banks = <1>;
120 };
121
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200122 ep@1 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800123 reg = <1>;
124 atmel,fifo-size = <1024>;
125 atmel,nb-banks = <2>;
126 atmel,can-dma;
127 atmel,can-isoc;
128 };
129
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200130 ep@2 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800131 reg = <2>;
132 atmel,fifo-size = <1024>;
133 atmel,nb-banks = <2>;
134 atmel,can-dma;
135 atmel,can-isoc;
136 };
137
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200138 ep@3 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800139 reg = <3>;
140 atmel,fifo-size = <1024>;
141 atmel,nb-banks = <3>;
142 atmel,can-dma;
143 };
144
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200145 ep@4 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800146 reg = <4>;
147 atmel,fifo-size = <1024>;
148 atmel,nb-banks = <3>;
149 atmel,can-dma;
150 };
151
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200152 ep@5 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800153 reg = <5>;
154 atmel,fifo-size = <1024>;
155 atmel,nb-banks = <3>;
156 atmel,can-dma;
157 atmel,can-isoc;
158 };
159
Alexandre Belloni60ec83e2016-07-12 22:45:47 +0200160 ep@6 {
Jean-Christophe PLAGNIOL-VILLARD4a3ae932013-05-03 20:22:57 +0800161 reg = <6>;
162 atmel,fifo-size = <1024>;
163 atmel,nb-banks = <3>;
164 atmel,can-dma;
165 atmel,can-isoc;
166 };
167};