blob: 6d6cc16669b2c61d457911023767e369e37c24ed [file] [log] [blame]
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001/*
Heiko Stuebnerb1772502015-03-06 19:04:02 +01002 * This file is dual-licensed: you can use it either under the terms
3 * of the GPL or the X11 license, at your option. Note that this dual
4 * licensing only applies to this file, and not this project as a
5 * whole.
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02006 *
Heiko Stuebnerb1772502015-03-06 19:04:02 +01007 * a) This file is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License as
9 * published by the Free Software Foundation; either version 2 of the
10 * License, or (at your option) any later version.
11 *
12 * This file is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * Or, alternatively,
18 *
19 * b) Permission is hereby granted, free of charge, to any person
20 * obtaining a copy of this software and associated documentation
21 * files (the "Software"), to deal in the Software without
22 * restriction, including without limitation the rights to use,
23 * copy, modify, merge, publish, distribute, sublicense, and/or
24 * sell copies of the Software, and to permit persons to whom the
25 * Software is furnished to do so, subject to the following
26 * conditions:
27 *
28 * The above copyright notice and this permission notice shall be
29 * included in all copies or substantial portions of the Software.
30 *
31 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
32 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
33 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
34 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
35 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
36 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
37 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
38 * OTHER DEALINGS IN THE SOFTWARE.
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020039 */
40
41#include <dt-bindings/gpio/gpio.h>
42#include <dt-bindings/interrupt-controller/irq.h>
43#include <dt-bindings/interrupt-controller/arm-gic.h>
44#include <dt-bindings/pinctrl/rockchip.h>
45#include <dt-bindings/clock/rk3288-cru.h>
Caesar Wangb67d6bc2014-11-24 12:59:01 +080046#include <dt-bindings/thermal/thermal.h>
Caesar Wangb63af762015-09-08 14:18:23 +080047#include <dt-bindings/power/rk3288-power.h>
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020048#include "skeleton.dtsi"
49
50/ {
51 compatible = "rockchip,rk3288";
52
53 interrupt-parent = <&gic>;
54
55 aliases {
Sjoerd Simons85ef8d62015-11-06 11:46:37 +010056 ethernet0 = &gmac;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020057 i2c0 = &i2c0;
58 i2c1 = &i2c1;
59 i2c2 = &i2c2;
60 i2c3 = &i2c3;
61 i2c4 = &i2c4;
62 i2c5 = &i2c5;
Doug Andersond7f9a382014-09-03 16:05:23 -070063 mshc0 = &emmc;
64 mshc1 = &sdmmc;
65 mshc2 = &sdio0;
66 mshc3 = &sdio1;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020067 serial0 = &uart0;
68 serial1 = &uart1;
69 serial2 = &uart2;
70 serial3 = &uart3;
71 serial4 = &uart4;
huang lin1f531702014-09-05 09:53:11 -070072 spi0 = &spi0;
73 spi1 = &spi1;
74 spi2 = &spi2;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020075 };
76
Sonny Raof1840782015-04-07 10:52:39 -070077 arm-pmu {
78 compatible = "arm,cortex-a12-pmu";
79 interrupts = <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>,
80 <GIC_SPI 152 IRQ_TYPE_LEVEL_HIGH>,
81 <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>,
82 <GIC_SPI 154 IRQ_TYPE_LEVEL_HIGH>;
Heiko Stuebner4863dcd2015-07-15 23:03:09 +020083 interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
Sonny Raof1840782015-04-07 10:52:39 -070084 };
85
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020086 cpus {
87 #address-cells = <1>;
88 #size-cells = <0>;
Olof Johansson08bcc752014-12-04 23:33:38 -080089 enable-method = "rockchip,rk3066-smp";
Kever Yangfbdbc732014-10-15 10:23:02 -070090 rockchip,pmu = <&pmu>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020091
Heiko Stuebnerbe8a77c2014-09-13 00:34:29 +020092 cpu0: cpu@500 {
Heiko Stuebner2ab557b2014-07-15 20:16:19 +020093 device_type = "cpu";
94 compatible = "arm,cortex-a12";
95 reg = <0x500>;
Kever Yang044542a2014-10-15 10:23:05 -070096 resets = <&cru SRST_CORE0>;
Heiko Stuebnerbe8a77c2014-09-13 00:34:29 +020097 operating-points = <
98 /* KHz uV */
99 1608000 1350000
100 1512000 1300000
101 1416000 1200000
102 1200000 1100000
103 1008000 1050000
104 816000 1000000
105 696000 950000
106 600000 900000
107 408000 900000
108 312000 900000
109 216000 900000
110 126000 900000
111 >;
Caesar Wangb67d6bc2014-11-24 12:59:01 +0800112 #cooling-cells = <2>; /* min followed by max */
Heiko Stuebnerbe8a77c2014-09-13 00:34:29 +0200113 clock-latency = <40000>;
114 clocks = <&cru ARMCLK>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200115 };
Heiko Stuebner4863dcd2015-07-15 23:03:09 +0200116 cpu1: cpu@501 {
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200117 device_type = "cpu";
118 compatible = "arm,cortex-a12";
119 reg = <0x501>;
Kever Yang044542a2014-10-15 10:23:05 -0700120 resets = <&cru SRST_CORE1>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200121 };
Heiko Stuebner4863dcd2015-07-15 23:03:09 +0200122 cpu2: cpu@502 {
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200123 device_type = "cpu";
124 compatible = "arm,cortex-a12";
125 reg = <0x502>;
Kever Yang044542a2014-10-15 10:23:05 -0700126 resets = <&cru SRST_CORE2>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200127 };
Heiko Stuebner4863dcd2015-07-15 23:03:09 +0200128 cpu3: cpu@503 {
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200129 device_type = "cpu";
130 compatible = "arm,cortex-a12";
131 reg = <0x503>;
Kever Yang044542a2014-10-15 10:23:05 -0700132 resets = <&cru SRST_CORE3>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200133 };
134 };
135
Heiko Stübner982891c2014-08-14 23:01:25 +0200136 amba {
137 compatible = "arm,amba-bus";
138 #address-cells = <1>;
139 #size-cells = <1>;
140 ranges;
141
142 dmac_peri: dma-controller@ff250000 {
143 compatible = "arm,pl330", "arm,primecell";
144 reg = <0xff250000 0x4000>;
145 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>,
146 <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
147 #dma-cells = <1>;
148 clocks = <&cru ACLK_DMAC2>;
149 clock-names = "apb_pclk";
150 };
151
152 dmac_bus_ns: dma-controller@ff600000 {
153 compatible = "arm,pl330", "arm,primecell";
154 reg = <0xff600000 0x4000>;
155 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
156 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
157 #dma-cells = <1>;
158 clocks = <&cru ACLK_DMAC1>;
159 clock-names = "apb_pclk";
160 status = "disabled";
161 };
162
163 dmac_bus_s: dma-controller@ffb20000 {
164 compatible = "arm,pl330", "arm,primecell";
165 reg = <0xffb20000 0x4000>;
166 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
167 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
168 #dma-cells = <1>;
169 clocks = <&cru ACLK_DMAC1>;
170 clock-names = "apb_pclk";
171 };
172 };
173
Heiko Stuebnerb21bcfc2015-08-01 13:00:49 +0200174 reserved-memory {
175 #address-cells = <1>;
176 #size-cells = <1>;
177 ranges;
178
179 /*
180 * The rk3288 cannot use the memory area above 0xfe000000
181 * for dma operations for some reason. While there is
182 * probably a better solution available somewhere, we
183 * haven't found it yet and while devices with 2GB of ram
184 * are not affected, this issue prevents 4GB from booting.
185 * So to make these devices at least bootable, block
186 * this area for the time being until the real solution
187 * is found.
188 */
189 dma-unusable@fe000000 {
190 reg = <0xfe000000 0x1000000>;
191 };
192 };
193
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200194 xin24m: oscillator {
195 compatible = "fixed-clock";
196 clock-frequency = <24000000>;
197 clock-output-names = "xin24m";
198 #clock-cells = <0>;
199 };
200
201 timer {
202 compatible = "arm,armv7-timer";
Sonny Raoe2405a52014-11-25 10:54:00 -0800203 arm,cpu-registers-not-fw-configured;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200204 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
205 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
206 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
207 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
208 clock-frequency = <24000000>;
209 };
210
Daniel Lezcanoe48cc182015-01-25 10:42:59 +0100211 timer: timer@ff810000 {
212 compatible = "rockchip,rk3288-timer";
213 reg = <0xff810000 0x20>;
214 interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
215 clocks = <&xin24m>, <&cru PCLK_TIMER>;
216 clock-names = "timer", "pclk";
217 };
218
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800219 display-subsystem {
220 compatible = "rockchip,display-subsystem";
221 ports = <&vopl_out>, <&vopb_out>;
222 };
223
Doug Anderson85095bf2014-08-12 16:21:13 -0700224 sdmmc: dwmmc@ff0c0000 {
225 compatible = "rockchip,rk3288-dw-mshc";
Addy Kef74ba112014-12-04 10:49:35 +0800226 clock-freq-min-max = <400000 150000000>;
Alexandru M Stanf71ddc52015-10-12 14:48:29 +0200227 clocks = <&cru HCLK_SDMMC>, <&cru SCLK_SDMMC>,
228 <&cru SCLK_SDMMC_DRV>, <&cru SCLK_SDMMC_SAMPLE>;
229 clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
Doug Anderson85095bf2014-08-12 16:21:13 -0700230 fifo-depth = <0x100>;
231 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
232 reg = <0xff0c0000 0x4000>;
233 status = "disabled";
234 };
235
Addy Kef1a07232014-08-19 18:21:08 +0800236 sdio0: dwmmc@ff0d0000 {
237 compatible = "rockchip,rk3288-dw-mshc";
Addy Kef74ba112014-12-04 10:49:35 +0800238 clock-freq-min-max = <400000 150000000>;
Alexandru M Stanf71ddc52015-10-12 14:48:29 +0200239 clocks = <&cru HCLK_SDIO0>, <&cru SCLK_SDIO0>,
240 <&cru SCLK_SDIO0_DRV>, <&cru SCLK_SDIO0_SAMPLE>;
241 clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
Addy Kef1a07232014-08-19 18:21:08 +0800242 fifo-depth = <0x100>;
243 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
244 reg = <0xff0d0000 0x4000>;
245 status = "disabled";
246 };
247
248 sdio1: dwmmc@ff0e0000 {
249 compatible = "rockchip,rk3288-dw-mshc";
Addy Kef74ba112014-12-04 10:49:35 +0800250 clock-freq-min-max = <400000 150000000>;
Alexandru M Stanf71ddc52015-10-12 14:48:29 +0200251 clocks = <&cru HCLK_SDIO1>, <&cru SCLK_SDIO1>,
252 <&cru SCLK_SDIO1_DRV>, <&cru SCLK_SDIO1_SAMPLE>;
253 clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
Addy Kef1a07232014-08-19 18:21:08 +0800254 fifo-depth = <0x100>;
255 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
256 reg = <0xff0e0000 0x4000>;
257 status = "disabled";
258 };
259
Doug Anderson85095bf2014-08-12 16:21:13 -0700260 emmc: dwmmc@ff0f0000 {
261 compatible = "rockchip,rk3288-dw-mshc";
Addy Kef74ba112014-12-04 10:49:35 +0800262 clock-freq-min-max = <400000 150000000>;
Alexandru M Stanf71ddc52015-10-12 14:48:29 +0200263 clocks = <&cru HCLK_EMMC>, <&cru SCLK_EMMC>,
264 <&cru SCLK_EMMC_DRV>, <&cru SCLK_EMMC_SAMPLE>;
265 clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
Doug Anderson85095bf2014-08-12 16:21:13 -0700266 fifo-depth = <0x100>;
267 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
268 reg = <0xff0f0000 0x4000>;
269 status = "disabled";
270 };
271
Heiko Stübnerf23a6172014-08-20 21:09:24 +0200272 saradc: saradc@ff100000 {
273 compatible = "rockchip,saradc";
274 reg = <0xff100000 0x100>;
275 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
276 #io-channel-cells = <1>;
277 clocks = <&cru SCLK_SARADC>, <&cru PCLK_SARADC>;
278 clock-names = "saradc", "apb_pclk";
279 status = "disabled";
280 };
281
huang lin1f531702014-09-05 09:53:11 -0700282 spi0: spi@ff110000 {
283 compatible = "rockchip,rk3288-spi", "rockchip,rk3066-spi";
284 clocks = <&cru SCLK_SPI0>, <&cru PCLK_SPI0>;
285 clock-names = "spiclk", "apb_pclk";
Doug Anderson11bd57b2014-10-24 14:42:06 -0700286 dmas = <&dmac_peri 11>, <&dmac_peri 12>;
287 dma-names = "tx", "rx";
huang lin1f531702014-09-05 09:53:11 -0700288 interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
289 pinctrl-names = "default";
290 pinctrl-0 = <&spi0_clk &spi0_tx &spi0_rx &spi0_cs0>;
291 reg = <0xff110000 0x1000>;
292 #address-cells = <1>;
293 #size-cells = <0>;
294 status = "disabled";
295 };
296
297 spi1: spi@ff120000 {
298 compatible = "rockchip,rk3288-spi", "rockchip,rk3066-spi";
299 clocks = <&cru SCLK_SPI1>, <&cru PCLK_SPI1>;
300 clock-names = "spiclk", "apb_pclk";
Doug Anderson11bd57b2014-10-24 14:42:06 -0700301 dmas = <&dmac_peri 13>, <&dmac_peri 14>;
302 dma-names = "tx", "rx";
huang lin1f531702014-09-05 09:53:11 -0700303 interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
304 pinctrl-names = "default";
305 pinctrl-0 = <&spi1_clk &spi1_tx &spi1_rx &spi1_cs0>;
306 reg = <0xff120000 0x1000>;
307 #address-cells = <1>;
308 #size-cells = <0>;
309 status = "disabled";
310 };
311
312 spi2: spi@ff130000 {
313 compatible = "rockchip,rk3288-spi", "rockchip,rk3066-spi";
314 clocks = <&cru SCLK_SPI2>, <&cru PCLK_SPI2>;
315 clock-names = "spiclk", "apb_pclk";
Doug Anderson11bd57b2014-10-24 14:42:06 -0700316 dmas = <&dmac_peri 15>, <&dmac_peri 16>;
317 dma-names = "tx", "rx";
huang lin1f531702014-09-05 09:53:11 -0700318 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
319 pinctrl-names = "default";
320 pinctrl-0 = <&spi2_clk &spi2_tx &spi2_rx &spi2_cs0>;
321 reg = <0xff130000 0x1000>;
322 #address-cells = <1>;
323 #size-cells = <0>;
324 status = "disabled";
325 };
326
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200327 i2c1: i2c@ff140000 {
328 compatible = "rockchip,rk3288-i2c";
329 reg = <0xff140000 0x1000>;
330 interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
331 #address-cells = <1>;
332 #size-cells = <0>;
333 clock-names = "i2c";
334 clocks = <&cru PCLK_I2C1>;
335 pinctrl-names = "default";
336 pinctrl-0 = <&i2c1_xfer>;
337 status = "disabled";
338 };
339
340 i2c3: i2c@ff150000 {
341 compatible = "rockchip,rk3288-i2c";
342 reg = <0xff150000 0x1000>;
343 interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
344 #address-cells = <1>;
345 #size-cells = <0>;
346 clock-names = "i2c";
347 clocks = <&cru PCLK_I2C3>;
348 pinctrl-names = "default";
349 pinctrl-0 = <&i2c3_xfer>;
350 status = "disabled";
351 };
352
353 i2c4: i2c@ff160000 {
354 compatible = "rockchip,rk3288-i2c";
355 reg = <0xff160000 0x1000>;
356 interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
357 #address-cells = <1>;
358 #size-cells = <0>;
359 clock-names = "i2c";
360 clocks = <&cru PCLK_I2C4>;
361 pinctrl-names = "default";
362 pinctrl-0 = <&i2c4_xfer>;
363 status = "disabled";
364 };
365
366 i2c5: i2c@ff170000 {
367 compatible = "rockchip,rk3288-i2c";
368 reg = <0xff170000 0x1000>;
369 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
370 #address-cells = <1>;
371 #size-cells = <0>;
372 clock-names = "i2c";
373 clocks = <&cru PCLK_I2C5>;
374 pinctrl-names = "default";
375 pinctrl-0 = <&i2c5_xfer>;
376 status = "disabled";
377 };
378
379 uart0: serial@ff180000 {
380 compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
381 reg = <0xff180000 0x100>;
382 interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
383 reg-shift = <2>;
384 reg-io-width = <4>;
385 clocks = <&cru SCLK_UART0>, <&cru PCLK_UART0>;
386 clock-names = "baudclk", "apb_pclk";
387 pinctrl-names = "default";
388 pinctrl-0 = <&uart0_xfer>;
389 status = "disabled";
390 };
391
392 uart1: serial@ff190000 {
393 compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
394 reg = <0xff190000 0x100>;
395 interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
396 reg-shift = <2>;
397 reg-io-width = <4>;
398 clocks = <&cru SCLK_UART1>, <&cru PCLK_UART1>;
399 clock-names = "baudclk", "apb_pclk";
400 pinctrl-names = "default";
401 pinctrl-0 = <&uart1_xfer>;
402 status = "disabled";
403 };
404
405 uart2: serial@ff690000 {
406 compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
407 reg = <0xff690000 0x100>;
408 interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
409 reg-shift = <2>;
410 reg-io-width = <4>;
411 clocks = <&cru SCLK_UART2>, <&cru PCLK_UART2>;
412 clock-names = "baudclk", "apb_pclk";
413 pinctrl-names = "default";
414 pinctrl-0 = <&uart2_xfer>;
415 status = "disabled";
416 };
417
418 uart3: serial@ff1b0000 {
419 compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
420 reg = <0xff1b0000 0x100>;
421 interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>;
422 reg-shift = <2>;
423 reg-io-width = <4>;
424 clocks = <&cru SCLK_UART3>, <&cru PCLK_UART3>;
425 clock-names = "baudclk", "apb_pclk";
426 pinctrl-names = "default";
427 pinctrl-0 = <&uart3_xfer>;
428 status = "disabled";
429 };
430
431 uart4: serial@ff1c0000 {
432 compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
433 reg = <0xff1c0000 0x100>;
434 interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
435 reg-shift = <2>;
436 reg-io-width = <4>;
437 clocks = <&cru SCLK_UART4>, <&cru PCLK_UART4>;
438 clock-names = "baudclk", "apb_pclk";
439 pinctrl-names = "default";
440 pinctrl-0 = <&uart4_xfer>;
441 status = "disabled";
442 };
443
Caesar Wangb67d6bc2014-11-24 12:59:01 +0800444 thermal-zones {
445 #include "rk3288-thermal.dtsi"
446 };
447
448 tsadc: tsadc@ff280000 {
449 compatible = "rockchip,rk3288-tsadc";
450 reg = <0xff280000 0x100>;
451 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
452 clocks = <&cru SCLK_TSADC>, <&cru PCLK_TSADC>;
453 clock-names = "tsadc", "apb_pclk";
454 resets = <&cru SRST_TSADC>;
455 reset-names = "tsadc-apb";
456 pinctrl-names = "default";
457 pinctrl-0 = <&otp_out>;
458 #thermal-sensor-cells = <1>;
459 rockchip,hw-tshut-temp = <95000>;
460 status = "disabled";
461 };
462
Roger Chen3d3fb74a2014-12-29 17:44:16 +0800463 gmac: ethernet@ff290000 {
464 compatible = "rockchip,rk3288-gmac";
465 reg = <0xff290000 0x10000>;
466 interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
467 interrupt-names = "macirq";
468 rockchip,grf = <&grf>;
469 clocks = <&cru SCLK_MAC>,
470 <&cru SCLK_MAC_RX>, <&cru SCLK_MAC_TX>,
471 <&cru SCLK_MACREF>, <&cru SCLK_MACREF_OUT>,
472 <&cru ACLK_GMAC>, <&cru PCLK_GMAC>;
473 clock-names = "stmmaceth",
474 "mac_clk_rx", "mac_clk_tx",
475 "clk_mac_ref", "clk_mac_refout",
476 "aclk_mac", "pclk_mac";
Romain Periere6b54642015-06-20 12:27:16 +0000477 resets = <&cru SRST_MAC>;
478 reset-names = "stmmaceth";
Alexandru M Stan54b0bc62015-03-13 17:55:32 -0700479 status = "disabled";
Roger Chen3d3fb74a2014-12-29 17:44:16 +0800480 };
481
Doug Andersonc9c32c52014-08-07 17:44:19 +0200482 usb_host0_ehci: usb@ff500000 {
483 compatible = "generic-ehci";
484 reg = <0xff500000 0x100>;
485 interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
486 clocks = <&cru HCLK_USBHOST0>;
487 clock-names = "usbhost";
Yunzhi Lif6db7022014-12-12 23:12:21 +0800488 phys = <&usbphy1>;
489 phy-names = "usb";
Doug Andersonc9c32c52014-08-07 17:44:19 +0200490 status = "disabled";
491 };
492
493 /* NOTE: ohci@ff520000 doesn't actually work on hardware */
494
Kever Yang12dd3652014-08-08 11:55:58 +0800495 usb_host1: usb@ff540000 {
496 compatible = "rockchip,rk3288-usb", "rockchip,rk3066-usb",
497 "snps,dwc2";
498 reg = <0xff540000 0x40000>;
499 interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
500 clocks = <&cru HCLK_USBHOST1>;
501 clock-names = "otg";
Yunzhi Licabd2ea2015-04-26 17:41:38 +0800502 dr_mode = "host";
Yunzhi Lif6db7022014-12-12 23:12:21 +0800503 phys = <&usbphy2>;
504 phy-names = "usb2-phy";
Kever Yang12dd3652014-08-08 11:55:58 +0800505 status = "disabled";
506 };
507
508 usb_otg: usb@ff580000 {
509 compatible = "rockchip,rk3288-usb", "rockchip,rk3066-usb",
510 "snps,dwc2";
511 reg = <0xff580000 0x40000>;
512 interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
513 clocks = <&cru HCLK_OTG0>;
514 clock-names = "otg";
Yunzhi Licabd2ea2015-04-26 17:41:38 +0800515 dr_mode = "otg";
516 g-np-tx-fifo-size = <16>;
517 g-rx-fifo-size = <275>;
518 g-tx-fifo-size = <256 128 128 64 64 32>;
519 g-use-dma;
Yunzhi Lif6db7022014-12-12 23:12:21 +0800520 phys = <&usbphy0>;
521 phy-names = "usb2-phy";
Kever Yang12dd3652014-08-08 11:55:58 +0800522 status = "disabled";
523 };
524
Doug Andersonc9c32c52014-08-07 17:44:19 +0200525 usb_hsic: usb@ff5c0000 {
526 compatible = "generic-ehci";
527 reg = <0xff5c0000 0x100>;
528 interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
529 clocks = <&cru HCLK_HSIC>;
530 clock-names = "usbhost";
531 status = "disabled";
532 };
533
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200534 i2c0: i2c@ff650000 {
535 compatible = "rockchip,rk3288-i2c";
536 reg = <0xff650000 0x1000>;
537 interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
538 #address-cells = <1>;
539 #size-cells = <0>;
540 clock-names = "i2c";
541 clocks = <&cru PCLK_I2C0>;
542 pinctrl-names = "default";
543 pinctrl-0 = <&i2c0_xfer>;
544 status = "disabled";
545 };
546
547 i2c2: i2c@ff660000 {
548 compatible = "rockchip,rk3288-i2c";
549 reg = <0xff660000 0x1000>;
550 interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
551 #address-cells = <1>;
552 #size-cells = <0>;
553 clock-names = "i2c";
554 clocks = <&cru PCLK_I2C2>;
555 pinctrl-names = "default";
556 pinctrl-0 = <&i2c2_xfer>;
557 status = "disabled";
558 };
559
Doug Andersondf542df2014-08-25 15:59:26 -0700560 pwm0: pwm@ff680000 {
561 compatible = "rockchip,rk3288-pwm";
562 reg = <0xff680000 0x10>;
563 #pwm-cells = <3>;
564 pinctrl-names = "default";
565 pinctrl-0 = <&pwm0_pin>;
566 clocks = <&cru PCLK_PWM>;
567 clock-names = "pwm";
568 status = "disabled";
569 };
570
571 pwm1: pwm@ff680010 {
572 compatible = "rockchip,rk3288-pwm";
573 reg = <0xff680010 0x10>;
574 #pwm-cells = <3>;
575 pinctrl-names = "default";
576 pinctrl-0 = <&pwm1_pin>;
577 clocks = <&cru PCLK_PWM>;
578 clock-names = "pwm";
579 status = "disabled";
580 };
581
582 pwm2: pwm@ff680020 {
583 compatible = "rockchip,rk3288-pwm";
584 reg = <0xff680020 0x10>;
585 #pwm-cells = <3>;
586 pinctrl-names = "default";
587 pinctrl-0 = <&pwm2_pin>;
588 clocks = <&cru PCLK_PWM>;
589 clock-names = "pwm";
590 status = "disabled";
591 };
592
593 pwm3: pwm@ff680030 {
594 compatible = "rockchip,rk3288-pwm";
595 reg = <0xff680030 0x10>;
596 #pwm-cells = <2>;
597 pinctrl-names = "default";
598 pinctrl-0 = <&pwm3_pin>;
599 clocks = <&cru PCLK_PWM>;
600 clock-names = "pwm";
601 status = "disabled";
602 };
603
Kever Yang1123d412014-10-15 10:23:04 -0700604 bus_intmem@ff700000 {
605 compatible = "mmio-sram";
606 reg = <0xff700000 0x18000>;
607 #address-cells = <1>;
608 #size-cells = <1>;
609 ranges = <0 0xff700000 0x18000>;
610 smp-sram@0 {
611 compatible = "rockchip,rk3066-smp-sram";
612 reg = <0x00 0x10>;
613 };
614 };
615
Chris Zhongeecfe982014-12-01 16:52:19 +0800616 sram@ff720000 {
617 compatible = "rockchip,rk3288-pmu-sram", "mmio-sram";
618 reg = <0xff720000 0x1000>;
619 };
620
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200621 pmu: power-management@ff730000 {
Caesar Wangb63af762015-09-08 14:18:23 +0800622 compatible = "rockchip,rk3288-pmu", "syscon", "simple-mfd";
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200623 reg = <0xff730000 0x100>;
Caesar Wangb63af762015-09-08 14:18:23 +0800624
625 power: power-controller {
626 compatible = "rockchip,rk3288-power-controller";
627 #power-domain-cells = <1>;
628 #address-cells = <1>;
629 #size-cells = <0>;
630
631 /*
632 * Note: Although SCLK_* are the working clocks
633 * of device without including on the NOC, needed for
634 * synchronous reset.
635 *
636 * The clocks on the which NOC:
637 * ACLK_IEP/ACLK_VIP/ACLK_VOP0 are on ACLK_VIO0_NIU.
638 * ACLK_ISP/ACLK_VOP1 are on ACLK_VIO1_NIU.
639 * ACLK_RGA is on ACLK_RGA_NIU.
640 * The others (HCLK_*,PLCK_*) are on HCLK_VIO_NIU.
641 *
642 * Which clock are device clocks:
643 * clocks devices
644 * *_IEP IEP:Image Enhancement Processor
645 * *_ISP ISP:Image Signal Processing
646 * *_VIP VIP:Video Input Processor
647 * *_VOP* VOP:Visual Output Processor
648 * *_RGA RGA
649 * *_EDP* EDP
650 * *_LVDS_* LVDS
651 * *_HDMI HDMI
652 * *_MIPI_* MIPI
653 */
654 pd_vio {
655 reg = <RK3288_PD_VIO>;
656 clocks = <&cru ACLK_IEP>,
657 <&cru ACLK_ISP>,
658 <&cru ACLK_RGA>,
659 <&cru ACLK_VIP>,
660 <&cru ACLK_VOP0>,
661 <&cru ACLK_VOP1>,
662 <&cru DCLK_VOP0>,
663 <&cru DCLK_VOP1>,
664 <&cru HCLK_IEP>,
665 <&cru HCLK_ISP>,
666 <&cru HCLK_RGA>,
667 <&cru HCLK_VIP>,
668 <&cru HCLK_VOP0>,
669 <&cru HCLK_VOP1>,
670 <&cru PCLK_EDP_CTRL>,
671 <&cru PCLK_HDMI_CTRL>,
672 <&cru PCLK_LVDS_PHY>,
673 <&cru PCLK_MIPI_CSI>,
674 <&cru PCLK_MIPI_DSI0>,
675 <&cru PCLK_MIPI_DSI1>,
676 <&cru SCLK_EDP_24M>,
677 <&cru SCLK_EDP>,
678 <&cru SCLK_ISP_JPE>,
679 <&cru SCLK_ISP>,
680 <&cru SCLK_RGA>;
681 };
682
683 /*
684 * Note: The following 3 are HEVC(H.265) clocks,
685 * and on the ACLK_HEVC_NIU (NOC).
686 */
687 pd_hevc {
688 reg = <RK3288_PD_HEVC>;
689 clocks = <&cru ACLK_HEVC>,
690 <&cru SCLK_HEVC_CABAC>,
691 <&cru SCLK_HEVC_CORE>;
692 };
693
694 /*
695 * Note: ACLK_VCODEC/HCLK_VCODEC are VCODEC
696 * (video endecoder & decoder) clocks that on the
697 * ACLK_VCODEC_NIU and HCLK_VCODEC_NIU (NOC).
698 */
699 pd_video {
700 reg = <RK3288_PD_VIDEO>;
701 clocks = <&cru ACLK_VCODEC>,
702 <&cru HCLK_VCODEC>;
703 };
704
705 /*
706 * Note: ACLK_GPU is the GPU clock,
707 * and on the ACLK_GPU_NIU (NOC).
708 */
709 pd_gpu {
710 reg = <RK3288_PD_GPU>;
711 clocks = <&cru ACLK_GPU>;
712 };
713 };
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200714 };
715
716 sgrf: syscon@ff740000 {
717 compatible = "rockchip,rk3288-sgrf", "syscon";
718 reg = <0xff740000 0x1000>;
719 };
720
721 cru: clock-controller@ff760000 {
722 compatible = "rockchip,rk3288-cru";
723 reg = <0xff760000 0x1000>;
724 rockchip,grf = <&grf>;
725 #clock-cells = <1>;
726 #reset-cells = <1>;
Kever Yangcd78d0c2014-10-09 21:50:30 -0700727 assigned-clocks = <&cru PLL_GPLL>, <&cru PLL_CPLL>,
728 <&cru PLL_NPLL>, <&cru ACLK_CPU>,
729 <&cru HCLK_CPU>, <&cru PCLK_CPU>,
730 <&cru ACLK_PERI>, <&cru HCLK_PERI>,
731 <&cru PCLK_PERI>;
732 assigned-clock-rates = <594000000>, <400000000>,
733 <500000000>, <300000000>,
734 <150000000>, <75000000>,
735 <300000000>, <150000000>,
736 <75000000>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200737 };
738
739 grf: syscon@ff770000 {
740 compatible = "rockchip,rk3288-grf", "syscon";
741 reg = <0xff770000 0x1000>;
742 };
743
744 wdt: watchdog@ff800000 {
745 compatible = "rockchip,rk3288-wdt", "snps,dw-wdt";
746 reg = <0xff800000 0x100>;
Heiko Stuebner39d05162015-01-20 21:12:16 +0100747 clocks = <&cru PCLK_WDT>;
Heiko Stuebner1a1b6982015-06-19 16:31:14 +0200748 interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200749 status = "disabled";
750 };
751
Sjoerd Simons874e5682015-10-08 15:31:17 +0200752 spdif: sound@ff88b0000 {
753 compatible = "rockchip,rk3288-spdif", "rockchip,rk3066-spdif";
754 reg = <0xff8b0000 0x10000>;
755 #sound-dai-cells = <0>;
756 clock-names = "hclk", "mclk";
757 clocks = <&cru HCLK_SPDIF8CH>, <&cru SCLK_SPDIF8CH>;
758 dmas = <&dmac_bus_s 3>;
759 dma-names = "tx";
760 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
761 pinctrl-names = "default";
762 pinctrl-0 = <&spdif_tx>;
763 rockchip,grf = <&grf>;
764 status = "disabled";
765 };
766
Jianquna0f95e32014-09-12 18:54:55 +0800767 i2s: i2s@ff890000 {
768 compatible = "rockchip,rk3288-i2s", "rockchip,rk3066-i2s";
769 reg = <0xff890000 0x10000>;
770 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
771 #address-cells = <1>;
772 #size-cells = <0>;
773 dmas = <&dmac_bus_s 0>, <&dmac_bus_s 1>;
774 dma-names = "tx", "rx";
775 clock-names = "i2s_hclk", "i2s_clk";
776 clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>;
777 pinctrl-names = "default";
778 pinctrl-0 = <&i2s0_bus>;
Sugar Zhange2416572015-11-10 15:32:09 +0800779 rockchip,playback-channels = <8>;
780 rockchip,capture-channels = <2>;
Jianquna0f95e32014-09-12 18:54:55 +0800781 status = "disabled";
782 };
783
Zain Wangc2cb6162015-11-25 13:43:33 +0800784 crypto: cypto-controller@ff8a0000 {
785 compatible = "rockchip,rk3288-crypto";
786 reg = <0xff8a0000 0x4000>;
787 interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
788 clocks = <&cru ACLK_CRYPTO>, <&cru HCLK_CRYPTO>,
789 <&cru SCLK_CRYPTO>, <&cru ACLK_DMAC1>;
790 clock-names = "aclk", "hclk", "sclk", "apb_pclk";
791 resets = <&cru SRST_CRYPTO>;
792 reset-names = "crypto-rst";
793 status = "okay";
794 };
795
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800796 vopb: vop@ff930000 {
797 compatible = "rockchip,rk3288-vop";
798 reg = <0xff930000 0x19c>;
799 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
800 clocks = <&cru ACLK_VOP0>, <&cru DCLK_VOP0>, <&cru HCLK_VOP0>;
801 clock-names = "aclk_vop", "dclk_vop", "hclk_vop";
Caesar Wangb63af762015-09-08 14:18:23 +0800802 power-domains = <&power RK3288_PD_VIO>;
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800803 resets = <&cru SRST_LCDC0_AXI>, <&cru SRST_LCDC0_AHB>, <&cru SRST_LCDC0_DCLK>;
804 reset-names = "axi", "ahb", "dclk";
805 iommus = <&vopb_mmu>;
806 status = "disabled";
807
808 vopb_out: port {
809 #address-cells = <1>;
810 #size-cells = <0>;
Andy Yand5a1df42014-11-04 13:13:14 +0800811
812 vopb_out_hdmi: endpoint@0 {
813 reg = <0>;
814 remote-endpoint = <&hdmi_in_vopb>;
815 };
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800816 };
817 };
818
Daniel Kurtz7cae0682014-11-03 10:53:29 +0800819 vopb_mmu: iommu@ff930300 {
820 compatible = "rockchip,iommu";
821 reg = <0xff930300 0x100>;
822 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
823 interrupt-names = "vopb_mmu";
Caesar Wangb63af762015-09-08 14:18:23 +0800824 power-domains = <&power RK3288_PD_VIO>;
Daniel Kurtz7cae0682014-11-03 10:53:29 +0800825 #iommu-cells = <0>;
826 status = "disabled";
827 };
828
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800829 vopl: vop@ff940000 {
830 compatible = "rockchip,rk3288-vop";
831 reg = <0xff940000 0x19c>;
832 interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
833 clocks = <&cru ACLK_VOP1>, <&cru DCLK_VOP1>, <&cru HCLK_VOP1>;
834 clock-names = "aclk_vop", "dclk_vop", "hclk_vop";
Caesar Wangb63af762015-09-08 14:18:23 +0800835 power-domains = <&power RK3288_PD_VIO>;
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800836 resets = <&cru SRST_LCDC1_AXI>, <&cru SRST_LCDC1_AHB>, <&cru SRST_LCDC1_DCLK>;
837 reset-names = "axi", "ahb", "dclk";
838 iommus = <&vopl_mmu>;
839 status = "disabled";
840
841 vopl_out: port {
842 #address-cells = <1>;
843 #size-cells = <0>;
Andy Yand5a1df42014-11-04 13:13:14 +0800844
845 vopl_out_hdmi: endpoint@0 {
846 reg = <0>;
847 remote-endpoint = <&hdmi_in_vopl>;
848 };
Daniel Kurtza29cb8c2014-10-10 20:26:14 +0800849 };
850 };
851
Daniel Kurtz7cae0682014-11-03 10:53:29 +0800852 vopl_mmu: iommu@ff940300 {
853 compatible = "rockchip,iommu";
854 reg = <0xff940300 0x100>;
855 interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
856 interrupt-names = "vopl_mmu";
Caesar Wangb63af762015-09-08 14:18:23 +0800857 power-domains = <&power RK3288_PD_VIO>;
Daniel Kurtz7cae0682014-11-03 10:53:29 +0800858 #iommu-cells = <0>;
859 status = "disabled";
860 };
861
Andy Yand5a1df42014-11-04 13:13:14 +0800862 hdmi: hdmi@ff980000 {
863 compatible = "rockchip,rk3288-dw-hdmi";
864 reg = <0xff980000 0x20000>;
865 reg-io-width = <4>;
Andy Yand5a1df42014-11-04 13:13:14 +0800866 rockchip,grf = <&grf>;
867 interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
868 clocks = <&cru PCLK_HDMI_CTRL>, <&cru SCLK_HDMI_HDCP>;
869 clock-names = "iahb", "isfr";
Caesar Wangb63af762015-09-08 14:18:23 +0800870 power-domains = <&power RK3288_PD_VIO>;
Andy Yand5a1df42014-11-04 13:13:14 +0800871 status = "disabled";
872
873 ports {
874 hdmi_in: port {
875 #address-cells = <1>;
876 #size-cells = <0>;
877 hdmi_in_vopb: endpoint@0 {
878 reg = <0>;
879 remote-endpoint = <&vopb_out_hdmi>;
880 };
881 hdmi_in_vopl: endpoint@1 {
882 reg = <1>;
883 remote-endpoint = <&vopl_out_hdmi>;
884 };
885 };
886 };
887 };
888
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200889 gic: interrupt-controller@ffc01000 {
890 compatible = "arm,gic-400";
891 interrupt-controller;
892 #interrupt-cells = <3>;
893 #address-cells = <0>;
894
895 reg = <0xffc01000 0x1000>,
896 <0xffc02000 0x1000>,
897 <0xffc04000 0x2000>,
898 <0xffc06000 0x2000>;
899 interrupts = <GIC_PPI 9 0xf04>;
900 };
901
Yunzhi Lif6db7022014-12-12 23:12:21 +0800902 usbphy: phy {
903 compatible = "rockchip,rk3288-usb-phy";
904 rockchip,grf = <&grf>;
905 #address-cells = <1>;
906 #size-cells = <0>;
907 status = "disabled";
908
909 usbphy0: usb-phy0 {
910 #phy-cells = <0>;
911 reg = <0x320>;
912 clocks = <&cru SCLK_OTGPHY0>;
913 clock-names = "phyclk";
914 };
915
916 usbphy1: usb-phy1 {
917 #phy-cells = <0>;
918 reg = <0x334>;
919 clocks = <&cru SCLK_OTGPHY1>;
920 clock-names = "phyclk";
921 };
922
923 usbphy2: usb-phy2 {
924 #phy-cells = <0>;
925 reg = <0x348>;
926 clocks = <&cru SCLK_OTGPHY2>;
927 clock-names = "phyclk";
928 };
929 };
930
Heiko Stuebner2ab557b2014-07-15 20:16:19 +0200931 pinctrl: pinctrl {
932 compatible = "rockchip,rk3288-pinctrl";
933 rockchip,grf = <&grf>;
934 rockchip,pmu = <&pmu>;
935 #address-cells = <1>;
936 #size-cells = <1>;
937 ranges;
938
939 gpio0: gpio0@ff750000 {
940 compatible = "rockchip,gpio-bank";
941 reg = <0xff750000 0x100>;
942 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
943 clocks = <&cru PCLK_GPIO0>;
944
945 gpio-controller;
946 #gpio-cells = <2>;
947
948 interrupt-controller;
949 #interrupt-cells = <2>;
950 };
951
952 gpio1: gpio1@ff780000 {
953 compatible = "rockchip,gpio-bank";
954 reg = <0xff780000 0x100>;
955 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
956 clocks = <&cru PCLK_GPIO1>;
957
958 gpio-controller;
959 #gpio-cells = <2>;
960
961 interrupt-controller;
962 #interrupt-cells = <2>;
963 };
964
965 gpio2: gpio2@ff790000 {
966 compatible = "rockchip,gpio-bank";
967 reg = <0xff790000 0x100>;
968 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
969 clocks = <&cru PCLK_GPIO2>;
970
971 gpio-controller;
972 #gpio-cells = <2>;
973
974 interrupt-controller;
975 #interrupt-cells = <2>;
976 };
977
978 gpio3: gpio3@ff7a0000 {
979 compatible = "rockchip,gpio-bank";
980 reg = <0xff7a0000 0x100>;
981 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
982 clocks = <&cru PCLK_GPIO3>;
983
984 gpio-controller;
985 #gpio-cells = <2>;
986
987 interrupt-controller;
988 #interrupt-cells = <2>;
989 };
990
991 gpio4: gpio4@ff7b0000 {
992 compatible = "rockchip,gpio-bank";
993 reg = <0xff7b0000 0x100>;
994 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
995 clocks = <&cru PCLK_GPIO4>;
996
997 gpio-controller;
998 #gpio-cells = <2>;
999
1000 interrupt-controller;
1001 #interrupt-cells = <2>;
1002 };
1003
1004 gpio5: gpio5@ff7c0000 {
1005 compatible = "rockchip,gpio-bank";
1006 reg = <0xff7c0000 0x100>;
1007 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
1008 clocks = <&cru PCLK_GPIO5>;
1009
1010 gpio-controller;
1011 #gpio-cells = <2>;
1012
1013 interrupt-controller;
1014 #interrupt-cells = <2>;
1015 };
1016
1017 gpio6: gpio6@ff7d0000 {
1018 compatible = "rockchip,gpio-bank";
1019 reg = <0xff7d0000 0x100>;
1020 interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
1021 clocks = <&cru PCLK_GPIO6>;
1022
1023 gpio-controller;
1024 #gpio-cells = <2>;
1025
1026 interrupt-controller;
1027 #interrupt-cells = <2>;
1028 };
1029
1030 gpio7: gpio7@ff7e0000 {
1031 compatible = "rockchip,gpio-bank";
1032 reg = <0xff7e0000 0x100>;
1033 interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
1034 clocks = <&cru PCLK_GPIO7>;
1035
1036 gpio-controller;
1037 #gpio-cells = <2>;
1038
1039 interrupt-controller;
1040 #interrupt-cells = <2>;
1041 };
1042
1043 gpio8: gpio8@ff7f0000 {
1044 compatible = "rockchip,gpio-bank";
1045 reg = <0xff7f0000 0x100>;
1046 interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
1047 clocks = <&cru PCLK_GPIO8>;
1048
1049 gpio-controller;
1050 #gpio-cells = <2>;
1051
1052 interrupt-controller;
1053 #interrupt-cells = <2>;
1054 };
1055
Douglas Andersone61ccb12015-09-02 14:54:22 -07001056 hdmi {
1057 hdmi_ddc: hdmi-ddc {
1058 rockchip,pins = <7 19 RK_FUNC_2 &pcfg_pull_none>,
1059 <7 20 RK_FUNC_2 &pcfg_pull_none>;
1060 };
1061 };
1062
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001063 pcfg_pull_up: pcfg-pull-up {
1064 bias-pull-up;
1065 };
1066
1067 pcfg_pull_down: pcfg-pull-down {
1068 bias-pull-down;
1069 };
1070
1071 pcfg_pull_none: pcfg-pull-none {
1072 bias-disable;
1073 };
1074
Roger Chen3d3fb74a2014-12-29 17:44:16 +08001075 pcfg_pull_none_12ma: pcfg-pull-none-12ma {
1076 bias-disable;
1077 drive-strength = <12>;
1078 };
1079
Chris Zhongeecfe982014-12-01 16:52:19 +08001080 sleep {
1081 global_pwroff: global-pwroff {
1082 rockchip,pins = <0 0 RK_FUNC_1 &pcfg_pull_none>;
1083 };
1084
1085 ddrio_pwroff: ddrio-pwroff {
1086 rockchip,pins = <0 1 RK_FUNC_1 &pcfg_pull_none>;
1087 };
1088
1089 ddr0_retention: ddr0-retention {
1090 rockchip,pins = <0 2 RK_FUNC_1 &pcfg_pull_up>;
1091 };
1092
1093 ddr1_retention: ddr1-retention {
1094 rockchip,pins = <0 3 RK_FUNC_1 &pcfg_pull_up>;
1095 };
1096 };
1097
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001098 i2c0 {
1099 i2c0_xfer: i2c0-xfer {
1100 rockchip,pins = <0 15 RK_FUNC_1 &pcfg_pull_none>,
1101 <0 16 RK_FUNC_1 &pcfg_pull_none>;
1102 };
1103 };
1104
1105 i2c1 {
1106 i2c1_xfer: i2c1-xfer {
1107 rockchip,pins = <8 4 RK_FUNC_1 &pcfg_pull_none>,
1108 <8 5 RK_FUNC_1 &pcfg_pull_none>;
1109 };
1110 };
1111
1112 i2c2 {
1113 i2c2_xfer: i2c2-xfer {
1114 rockchip,pins = <6 9 RK_FUNC_1 &pcfg_pull_none>,
1115 <6 10 RK_FUNC_1 &pcfg_pull_none>;
1116 };
1117 };
1118
1119 i2c3 {
1120 i2c3_xfer: i2c3-xfer {
1121 rockchip,pins = <2 16 RK_FUNC_1 &pcfg_pull_none>,
1122 <2 17 RK_FUNC_1 &pcfg_pull_none>;
1123 };
1124 };
1125
1126 i2c4 {
1127 i2c4_xfer: i2c4-xfer {
1128 rockchip,pins = <7 17 RK_FUNC_1 &pcfg_pull_none>,
1129 <7 18 RK_FUNC_1 &pcfg_pull_none>;
1130 };
1131 };
1132
1133 i2c5 {
1134 i2c5_xfer: i2c5-xfer {
1135 rockchip,pins = <7 19 RK_FUNC_1 &pcfg_pull_none>,
1136 <7 20 RK_FUNC_1 &pcfg_pull_none>;
1137 };
1138 };
1139
Jianquna0f95e32014-09-12 18:54:55 +08001140 i2s0 {
1141 i2s0_bus: i2s0-bus {
1142 rockchip,pins = <6 0 RK_FUNC_1 &pcfg_pull_none>,
1143 <6 1 RK_FUNC_1 &pcfg_pull_none>,
1144 <6 2 RK_FUNC_1 &pcfg_pull_none>,
1145 <6 3 RK_FUNC_1 &pcfg_pull_none>,
1146 <6 4 RK_FUNC_1 &pcfg_pull_none>,
1147 <6 8 RK_FUNC_1 &pcfg_pull_none>;
1148 };
1149 };
1150
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001151 sdmmc {
1152 sdmmc_clk: sdmmc-clk {
1153 rockchip,pins = <6 20 RK_FUNC_1 &pcfg_pull_none>;
1154 };
1155
1156 sdmmc_cmd: sdmmc-cmd {
1157 rockchip,pins = <6 21 RK_FUNC_1 &pcfg_pull_up>;
1158 };
1159
1160 sdmmc_cd: sdmcc-cd {
1161 rockchip,pins = <6 22 RK_FUNC_1 &pcfg_pull_up>;
1162 };
1163
1164 sdmmc_bus1: sdmmc-bus1 {
1165 rockchip,pins = <6 16 RK_FUNC_1 &pcfg_pull_up>;
1166 };
1167
1168 sdmmc_bus4: sdmmc-bus4 {
1169 rockchip,pins = <6 16 RK_FUNC_1 &pcfg_pull_up>,
1170 <6 17 RK_FUNC_1 &pcfg_pull_up>,
1171 <6 18 RK_FUNC_1 &pcfg_pull_up>,
1172 <6 19 RK_FUNC_1 &pcfg_pull_up>;
1173 };
1174 };
1175
Addy Kef1a07232014-08-19 18:21:08 +08001176 sdio0 {
1177 sdio0_bus1: sdio0-bus1 {
1178 rockchip,pins = <4 20 RK_FUNC_1 &pcfg_pull_up>;
1179 };
1180
1181 sdio0_bus4: sdio0-bus4 {
1182 rockchip,pins = <4 20 RK_FUNC_1 &pcfg_pull_up>,
1183 <4 21 RK_FUNC_1 &pcfg_pull_up>,
1184 <4 22 RK_FUNC_1 &pcfg_pull_up>,
1185 <4 23 RK_FUNC_1 &pcfg_pull_up>;
1186 };
1187
1188 sdio0_cmd: sdio0-cmd {
1189 rockchip,pins = <4 24 RK_FUNC_1 &pcfg_pull_up>;
1190 };
1191
1192 sdio0_clk: sdio0-clk {
1193 rockchip,pins = <4 25 RK_FUNC_1 &pcfg_pull_none>;
1194 };
1195
1196 sdio0_cd: sdio0-cd {
1197 rockchip,pins = <4 26 RK_FUNC_1 &pcfg_pull_up>;
1198 };
1199
1200 sdio0_wp: sdio0-wp {
1201 rockchip,pins = <4 27 RK_FUNC_1 &pcfg_pull_up>;
1202 };
1203
1204 sdio0_pwr: sdio0-pwr {
1205 rockchip,pins = <4 28 RK_FUNC_1 &pcfg_pull_up>;
1206 };
1207
1208 sdio0_bkpwr: sdio0-bkpwr {
1209 rockchip,pins = <4 29 RK_FUNC_1 &pcfg_pull_up>;
1210 };
1211
1212 sdio0_int: sdio0-int {
1213 rockchip,pins = <4 30 RK_FUNC_1 &pcfg_pull_up>;
1214 };
1215 };
1216
1217 sdio1 {
1218 sdio1_bus1: sdio1-bus1 {
1219 rockchip,pins = <3 24 4 &pcfg_pull_up>;
1220 };
1221
1222 sdio1_bus4: sdio1-bus4 {
1223 rockchip,pins = <3 24 4 &pcfg_pull_up>,
1224 <3 25 4 &pcfg_pull_up>,
1225 <3 26 4 &pcfg_pull_up>,
1226 <3 27 4 &pcfg_pull_up>;
1227 };
1228
1229 sdio1_cd: sdio1-cd {
1230 rockchip,pins = <3 28 4 &pcfg_pull_up>;
1231 };
1232
1233 sdio1_wp: sdio1-wp {
1234 rockchip,pins = <3 29 4 &pcfg_pull_up>;
1235 };
1236
1237 sdio1_bkpwr: sdio1-bkpwr {
1238 rockchip,pins = <3 30 4 &pcfg_pull_up>;
1239 };
1240
1241 sdio1_int: sdio1-int {
1242 rockchip,pins = <3 31 4 &pcfg_pull_up>;
1243 };
1244
1245 sdio1_cmd: sdio1-cmd {
1246 rockchip,pins = <4 6 4 &pcfg_pull_up>;
1247 };
1248
1249 sdio1_clk: sdio1-clk {
1250 rockchip,pins = <4 7 4 &pcfg_pull_none>;
1251 };
1252
1253 sdio1_pwr: sdio1-pwr {
1254 rockchip,pins = <4 9 4 &pcfg_pull_up>;
1255 };
1256 };
1257
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001258 emmc {
1259 emmc_clk: emmc-clk {
1260 rockchip,pins = <3 18 RK_FUNC_2 &pcfg_pull_none>;
1261 };
1262
1263 emmc_cmd: emmc-cmd {
1264 rockchip,pins = <3 16 RK_FUNC_2 &pcfg_pull_up>;
1265 };
1266
1267 emmc_pwr: emmc-pwr {
1268 rockchip,pins = <3 9 RK_FUNC_2 &pcfg_pull_up>;
1269 };
1270
1271 emmc_bus1: emmc-bus1 {
1272 rockchip,pins = <3 0 RK_FUNC_2 &pcfg_pull_up>;
1273 };
1274
1275 emmc_bus4: emmc-bus4 {
1276 rockchip,pins = <3 0 RK_FUNC_2 &pcfg_pull_up>,
1277 <3 1 RK_FUNC_2 &pcfg_pull_up>,
1278 <3 2 RK_FUNC_2 &pcfg_pull_up>,
1279 <3 3 RK_FUNC_2 &pcfg_pull_up>;
1280 };
1281
1282 emmc_bus8: emmc-bus8 {
1283 rockchip,pins = <3 0 RK_FUNC_2 &pcfg_pull_up>,
1284 <3 1 RK_FUNC_2 &pcfg_pull_up>,
1285 <3 2 RK_FUNC_2 &pcfg_pull_up>,
1286 <3 3 RK_FUNC_2 &pcfg_pull_up>,
1287 <3 4 RK_FUNC_2 &pcfg_pull_up>,
1288 <3 5 RK_FUNC_2 &pcfg_pull_up>,
1289 <3 6 RK_FUNC_2 &pcfg_pull_up>,
1290 <3 7 RK_FUNC_2 &pcfg_pull_up>;
1291 };
1292 };
1293
huang lin1f531702014-09-05 09:53:11 -07001294 spi0 {
1295 spi0_clk: spi0-clk {
1296 rockchip,pins = <5 12 RK_FUNC_1 &pcfg_pull_up>;
1297 };
1298 spi0_cs0: spi0-cs0 {
1299 rockchip,pins = <5 13 RK_FUNC_1 &pcfg_pull_up>;
1300 };
1301 spi0_tx: spi0-tx {
1302 rockchip,pins = <5 14 RK_FUNC_1 &pcfg_pull_up>;
1303 };
1304 spi0_rx: spi0-rx {
1305 rockchip,pins = <5 15 RK_FUNC_1 &pcfg_pull_up>;
1306 };
1307 spi0_cs1: spi0-cs1 {
1308 rockchip,pins = <5 16 RK_FUNC_1 &pcfg_pull_up>;
1309 };
1310 };
1311 spi1 {
1312 spi1_clk: spi1-clk {
1313 rockchip,pins = <7 12 RK_FUNC_2 &pcfg_pull_up>;
1314 };
1315 spi1_cs0: spi1-cs0 {
1316 rockchip,pins = <7 13 RK_FUNC_2 &pcfg_pull_up>;
1317 };
1318 spi1_rx: spi1-rx {
1319 rockchip,pins = <7 14 RK_FUNC_2 &pcfg_pull_up>;
1320 };
1321 spi1_tx: spi1-tx {
1322 rockchip,pins = <7 15 RK_FUNC_2 &pcfg_pull_up>;
1323 };
1324 };
1325
1326 spi2 {
1327 spi2_cs1: spi2-cs1 {
1328 rockchip,pins = <8 3 RK_FUNC_1 &pcfg_pull_up>;
1329 };
1330 spi2_clk: spi2-clk {
1331 rockchip,pins = <8 6 RK_FUNC_1 &pcfg_pull_up>;
1332 };
1333 spi2_cs0: spi2-cs0 {
1334 rockchip,pins = <8 7 RK_FUNC_1 &pcfg_pull_up>;
1335 };
1336 spi2_rx: spi2-rx {
1337 rockchip,pins = <8 8 RK_FUNC_1 &pcfg_pull_up>;
1338 };
1339 spi2_tx: spi2-tx {
1340 rockchip,pins = <8 9 RK_FUNC_1 &pcfg_pull_up>;
1341 };
1342 };
1343
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001344 uart0 {
1345 uart0_xfer: uart0-xfer {
1346 rockchip,pins = <4 16 RK_FUNC_1 &pcfg_pull_up>,
1347 <4 17 RK_FUNC_1 &pcfg_pull_none>;
1348 };
1349
1350 uart0_cts: uart0-cts {
Alexandru M Stan8915f362015-09-02 16:27:58 -07001351 rockchip,pins = <4 18 RK_FUNC_1 &pcfg_pull_up>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001352 };
1353
1354 uart0_rts: uart0-rts {
1355 rockchip,pins = <4 19 RK_FUNC_1 &pcfg_pull_none>;
1356 };
1357 };
1358
1359 uart1 {
1360 uart1_xfer: uart1-xfer {
1361 rockchip,pins = <5 8 RK_FUNC_1 &pcfg_pull_up>,
1362 <5 9 RK_FUNC_1 &pcfg_pull_none>;
1363 };
1364
1365 uart1_cts: uart1-cts {
Alexandru M Stan8915f362015-09-02 16:27:58 -07001366 rockchip,pins = <5 10 RK_FUNC_1 &pcfg_pull_up>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001367 };
1368
1369 uart1_rts: uart1-rts {
1370 rockchip,pins = <5 11 RK_FUNC_1 &pcfg_pull_none>;
1371 };
1372 };
1373
1374 uart2 {
1375 uart2_xfer: uart2-xfer {
1376 rockchip,pins = <7 22 RK_FUNC_1 &pcfg_pull_up>,
1377 <7 23 RK_FUNC_1 &pcfg_pull_none>;
1378 };
1379 /* no rts / cts for uart2 */
1380 };
1381
1382 uart3 {
1383 uart3_xfer: uart3-xfer {
1384 rockchip,pins = <7 7 RK_FUNC_1 &pcfg_pull_up>,
1385 <7 8 RK_FUNC_1 &pcfg_pull_none>;
1386 };
1387
1388 uart3_cts: uart3-cts {
Alexandru M Stan8915f362015-09-02 16:27:58 -07001389 rockchip,pins = <7 9 RK_FUNC_1 &pcfg_pull_up>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001390 };
1391
1392 uart3_rts: uart3-rts {
1393 rockchip,pins = <7 10 RK_FUNC_1 &pcfg_pull_none>;
1394 };
1395 };
1396
1397 uart4 {
1398 uart4_xfer: uart4-xfer {
1399 rockchip,pins = <5 12 3 &pcfg_pull_up>,
1400 <5 13 3 &pcfg_pull_none>;
1401 };
1402
1403 uart4_cts: uart4-cts {
Alexandru M Stan8915f362015-09-02 16:27:58 -07001404 rockchip,pins = <5 14 3 &pcfg_pull_up>;
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001405 };
1406
1407 uart4_rts: uart4-rts {
1408 rockchip,pins = <5 15 3 &pcfg_pull_none>;
1409 };
1410 };
Doug Andersondf542df2014-08-25 15:59:26 -07001411
Caesar Wangb67d6bc2014-11-24 12:59:01 +08001412 tsadc {
1413 otp_out: otp-out {
1414 rockchip,pins = <0 10 RK_FUNC_1 &pcfg_pull_none>;
1415 };
1416 };
1417
Doug Andersondf542df2014-08-25 15:59:26 -07001418 pwm0 {
1419 pwm0_pin: pwm0-pin {
1420 rockchip,pins = <7 0 RK_FUNC_1 &pcfg_pull_none>;
1421 };
1422 };
1423
1424 pwm1 {
1425 pwm1_pin: pwm1-pin {
1426 rockchip,pins = <7 1 RK_FUNC_1 &pcfg_pull_none>;
1427 };
1428 };
1429
1430 pwm2 {
1431 pwm2_pin: pwm2-pin {
1432 rockchip,pins = <7 22 3 &pcfg_pull_none>;
1433 };
1434 };
1435
1436 pwm3 {
1437 pwm3_pin: pwm3-pin {
1438 rockchip,pins = <7 23 3 &pcfg_pull_none>;
1439 };
1440 };
Roger Chen3d3fb74a2014-12-29 17:44:16 +08001441
1442 gmac {
1443 rgmii_pins: rgmii-pins {
1444 rockchip,pins = <3 30 3 &pcfg_pull_none>,
1445 <3 31 3 &pcfg_pull_none>,
1446 <3 26 3 &pcfg_pull_none>,
1447 <3 27 3 &pcfg_pull_none>,
1448 <3 28 3 &pcfg_pull_none_12ma>,
1449 <3 29 3 &pcfg_pull_none_12ma>,
1450 <3 24 3 &pcfg_pull_none_12ma>,
1451 <3 25 3 &pcfg_pull_none_12ma>,
1452 <4 0 3 &pcfg_pull_none>,
1453 <4 5 3 &pcfg_pull_none>,
1454 <4 6 3 &pcfg_pull_none>,
1455 <4 9 3 &pcfg_pull_none_12ma>,
1456 <4 4 3 &pcfg_pull_none_12ma>,
1457 <4 1 3 &pcfg_pull_none>,
1458 <4 3 3 &pcfg_pull_none>;
1459 };
1460
1461 rmii_pins: rmii-pins {
1462 rockchip,pins = <3 30 3 &pcfg_pull_none>,
1463 <3 31 3 &pcfg_pull_none>,
1464 <3 28 3 &pcfg_pull_none>,
1465 <3 29 3 &pcfg_pull_none>,
1466 <4 0 3 &pcfg_pull_none>,
1467 <4 5 3 &pcfg_pull_none>,
1468 <4 4 3 &pcfg_pull_none>,
1469 <4 1 3 &pcfg_pull_none>,
1470 <4 2 3 &pcfg_pull_none>,
1471 <4 3 3 &pcfg_pull_none>;
1472 };
1473 };
Sjoerd Simons874e5682015-10-08 15:31:17 +02001474
1475 spdif {
1476 spdif_tx: spdif-tx {
1477 rockchip,pins = <RK_GPIO6 11 RK_FUNC_1 &pcfg_pull_none>;
1478 };
1479 };
Heiko Stuebner2ab557b2014-07-15 20:16:19 +02001480 };
1481};