of: MSI: Simplify irqdomain lookup
[linux/fpc-iii.git] / arch / arm / boot / dts / rk3188.dtsi
blob6399942f1840cc4ae485c07040f848d1bc630fea
1 /*
2  * Copyright (c) 2013 MundoReader S.L.
3  * Author: Heiko Stuebner <heiko@sntech.de>
4  *
5  * This file is dual-licensed: you can use it either under the terms
6  * of the GPL or the X11 license, at your option. Note that this dual
7  * licensing only applies to this file, and not this project as a
8  * whole.
9  *
10  *  a) This file is free software; you can redistribute it and/or
11  *     modify it under the terms of the GNU General Public License as
12  *     published by the Free Software Foundation; either version 2 of the
13  *     License, or (at your option) any later version.
14  *
15  *     This file is distributed in the hope that it will be useful,
16  *     but WITHOUT ANY WARRANTY; without even the implied warranty of
17  *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  *     GNU General Public License for more details.
19  *
20  * Or, alternatively,
21  *
22  *  b) Permission is hereby granted, free of charge, to any person
23  *     obtaining a copy of this software and associated documentation
24  *     files (the "Software"), to deal in the Software without
25  *     restriction, including without limitation the rights to use,
26  *     copy, modify, merge, publish, distribute, sublicense, and/or
27  *     sell copies of the Software, and to permit persons to whom the
28  *     Software is furnished to do so, subject to the following
29  *     conditions:
30  *
31  *     The above copyright notice and this permission notice shall be
32  *     included in all copies or substantial portions of the Software.
33  *
34  *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
35  *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
36  *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
37  *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
38  *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
39  *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
40  *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
41  *     OTHER DEALINGS IN THE SOFTWARE.
42  */
44 #include <dt-bindings/gpio/gpio.h>
45 #include <dt-bindings/pinctrl/rockchip.h>
46 #include <dt-bindings/clock/rk3188-cru.h>
47 #include "rk3xxx.dtsi"
49 / {
50         compatible = "rockchip,rk3188";
52         cpus {
53                 #address-cells = <1>;
54                 #size-cells = <0>;
55                 enable-method = "rockchip,rk3066-smp";
57                 cpu0: cpu@0 {
58                         device_type = "cpu";
59                         compatible = "arm,cortex-a9";
60                         next-level-cache = <&L2>;
61                         reg = <0x0>;
62                         operating-points = <
63                                 /* kHz    uV */
64                                 1608000 1350000
65                                 1416000 1250000
66                                 1200000 1150000
67                                 1008000 1075000
68                                  816000  975000
69                                  600000  950000
70                                  504000  925000
71                                  312000  875000
72                         >;
73                         clock-latency = <40000>;
74                         clocks = <&cru ARMCLK>;
75                 };
76                 cpu@1 {
77                         device_type = "cpu";
78                         compatible = "arm,cortex-a9";
79                         next-level-cache = <&L2>;
80                         reg = <0x1>;
81                 };
82                 cpu@2 {
83                         device_type = "cpu";
84                         compatible = "arm,cortex-a9";
85                         next-level-cache = <&L2>;
86                         reg = <0x2>;
87                 };
88                 cpu@3 {
89                         device_type = "cpu";
90                         compatible = "arm,cortex-a9";
91                         next-level-cache = <&L2>;
92                         reg = <0x3>;
93                 };
94         };
96         sram: sram@10080000 {
97                 compatible = "mmio-sram";
98                 reg = <0x10080000 0x8000>;
99                 #address-cells = <1>;
100                 #size-cells = <1>;
101                 ranges = <0 0x10080000 0x8000>;
103                 smp-sram@0 {
104                         compatible = "rockchip,rk3066-smp-sram";
105                         reg = <0x0 0x50>;
106                 };
107         };
109         i2s0: i2s@1011a000 {
110                 compatible = "rockchip,rk3188-i2s", "rockchip,rk3066-i2s";
111                 reg = <0x1011a000 0x2000>;
112                 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
113                 #address-cells = <1>;
114                 #size-cells = <0>;
115                 pinctrl-names = "default";
116                 pinctrl-0 = <&i2s0_bus>;
117                 dmas = <&dmac1_s 6>, <&dmac1_s 7>;
118                 dma-names = "tx", "rx";
119                 clock-names = "i2s_hclk", "i2s_clk";
120                 clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>;
121                 status = "disabled";
122         };
124         spdif: sound@1011e000 {
125                 compatible = "rockchip,rk3188-spdif", "rockchip,rk3066-spdif";
126                 reg = <0x1011e000 0x2000>;
127                 #sound-dai-cells = <0>;
128                 clock-names = "hclk", "mclk";
129                 clocks = <&cru HCLK_SPDIF>, <&cru SCLK_SPDIF>;
130                 dmas = <&dmac1_s 8>;
131                 dma-names = "tx";
132                 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
133                 pinctrl-names = "default";
134                 pinctrl-0 = <&spdif_tx>;
135                 status = "disabled";
136         };
138         cru: clock-controller@20000000 {
139                 compatible = "rockchip,rk3188-cru";
140                 reg = <0x20000000 0x1000>;
141                 rockchip,grf = <&grf>;
143                 #clock-cells = <1>;
144                 #reset-cells = <1>;
145         };
147         usbphy: phy {
148                 compatible = "rockchip,rk3188-usb-phy", "rockchip,rk3288-usb-phy";
149                 rockchip,grf = <&grf>;
150                 #address-cells = <1>;
151                 #size-cells = <0>;
152                 status = "disabled";
154                 usbphy0: usb-phy0 {
155                         #phy-cells = <0>;
156                         reg = <0x10c>;
157                         clocks = <&cru SCLK_OTGPHY0>;
158                         clock-names = "phyclk";
159                 };
161                 usbphy1: usb-phy1 {
162                         #phy-cells = <0>;
163                         reg = <0x11c>;
164                         clocks = <&cru SCLK_OTGPHY1>;
165                         clock-names = "phyclk";
166                 };
167         };
169         pinctrl: pinctrl {
170                 compatible = "rockchip,rk3188-pinctrl";
171                 rockchip,grf = <&grf>;
172                 rockchip,pmu = <&pmu>;
174                 #address-cells = <1>;
175                 #size-cells = <1>;
176                 ranges;
178                 gpio0: gpio0@2000a000 {
179                         compatible = "rockchip,rk3188-gpio-bank0";
180                         reg = <0x2000a000 0x100>;
181                         interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
182                         clocks = <&cru PCLK_GPIO0>;
184                         gpio-controller;
185                         #gpio-cells = <2>;
187                         interrupt-controller;
188                         #interrupt-cells = <2>;
189                 };
191                 gpio1: gpio1@2003c000 {
192                         compatible = "rockchip,gpio-bank";
193                         reg = <0x2003c000 0x100>;
194                         interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
195                         clocks = <&cru PCLK_GPIO1>;
197                         gpio-controller;
198                         #gpio-cells = <2>;
200                         interrupt-controller;
201                         #interrupt-cells = <2>;
202                 };
204                 gpio2: gpio2@2003e000 {
205                         compatible = "rockchip,gpio-bank";
206                         reg = <0x2003e000 0x100>;
207                         interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
208                         clocks = <&cru PCLK_GPIO2>;
210                         gpio-controller;
211                         #gpio-cells = <2>;
213                         interrupt-controller;
214                         #interrupt-cells = <2>;
215                 };
217                 gpio3: gpio3@20080000 {
218                         compatible = "rockchip,gpio-bank";
219                         reg = <0x20080000 0x100>;
220                         interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
221                         clocks = <&cru PCLK_GPIO3>;
223                         gpio-controller;
224                         #gpio-cells = <2>;
226                         interrupt-controller;
227                         #interrupt-cells = <2>;
228                 };
230                 pcfg_pull_up: pcfg_pull_up {
231                         bias-pull-up;
232                 };
234                 pcfg_pull_down: pcfg_pull_down {
235                         bias-pull-down;
236                 };
238                 pcfg_pull_none: pcfg_pull_none {
239                         bias-disable;
240                 };
242                 emmc {
243                         emmc_clk: emmc-clk {
244                                 rockchip,pins = <RK_GPIO0 24 RK_FUNC_2 &pcfg_pull_none>;
245                         };
247                         emmc_cmd: emmc-cmd {
248                                 rockchip,pins = <RK_GPIO0 26 RK_FUNC_2 &pcfg_pull_up>;
249                         };
251                         emmc_rst: emmc-rst {
252                                 rockchip,pins = <RK_GPIO0 27 RK_FUNC_2 &pcfg_pull_none>;
253                         };
255                         /*
256                          * The data pins are shared between nandc and emmc and
257                          * not accessible through pinctrl. Also they should've
258                          * been already set correctly by firmware, as
259                          * flash/emmc is the boot-device.
260                          */
261                 };
263                 emac {
264                         emac_xfer: emac-xfer {
265                                 rockchip,pins = <RK_GPIO3 16 RK_FUNC_2 &pcfg_pull_none>, /* tx_en */
266                                                 <RK_GPIO3 17 RK_FUNC_2 &pcfg_pull_none>, /* txd1 */
267                                                 <RK_GPIO3 18 RK_FUNC_2 &pcfg_pull_none>, /* txd0 */
268                                                 <RK_GPIO3 19 RK_FUNC_2 &pcfg_pull_none>, /* rxd0 */
269                                                 <RK_GPIO3 20 RK_FUNC_2 &pcfg_pull_none>, /* rxd1 */
270                                                 <RK_GPIO3 21 RK_FUNC_2 &pcfg_pull_none>, /* mac_clk */
271                                                 <RK_GPIO3 22 RK_FUNC_2 &pcfg_pull_none>, /* rx_err */
272                                                 <RK_GPIO3 23 RK_FUNC_2 &pcfg_pull_none>; /* crs_dvalid */
273                         };
275                         emac_mdio: emac-mdio {
276                                 rockchip,pins = <RK_GPIO3 24 RK_FUNC_2 &pcfg_pull_none>,
277                                                 <RK_GPIO3 25 RK_FUNC_2 &pcfg_pull_none>;
278                         };
279                 };
281                 i2c0 {
282                         i2c0_xfer: i2c0-xfer {
283                                 rockchip,pins = <RK_GPIO1 24 RK_FUNC_1 &pcfg_pull_none>,
284                                                 <RK_GPIO1 25 RK_FUNC_1 &pcfg_pull_none>;
285                         };
286                 };
288                 i2c1 {
289                         i2c1_xfer: i2c1-xfer {
290                                 rockchip,pins = <RK_GPIO1 26 RK_FUNC_1 &pcfg_pull_none>,
291                                                 <RK_GPIO1 27 RK_FUNC_1 &pcfg_pull_none>;
292                         };
293                 };
295                 i2c2 {
296                         i2c2_xfer: i2c2-xfer {
297                                 rockchip,pins = <RK_GPIO1 28 RK_FUNC_1 &pcfg_pull_none>,
298                                                 <RK_GPIO1 29 RK_FUNC_1 &pcfg_pull_none>;
299                         };
300                 };
302                 i2c3 {
303                         i2c3_xfer: i2c3-xfer {
304                                 rockchip,pins = <RK_GPIO3 14 RK_FUNC_2 &pcfg_pull_none>,
305                                                 <RK_GPIO3 15 RK_FUNC_2 &pcfg_pull_none>;
306                         };
307                 };
309                 i2c4 {
310                         i2c4_xfer: i2c4-xfer {
311                                 rockchip,pins = <RK_GPIO1 30 RK_FUNC_1 &pcfg_pull_none>,
312                                                 <RK_GPIO1 31 RK_FUNC_1 &pcfg_pull_none>;
313                         };
314                 };
316                 pwm0 {
317                         pwm0_out: pwm0-out {
318                                 rockchip,pins = <RK_GPIO3 27 RK_FUNC_1 &pcfg_pull_none>;
319                         };
320                 };
322                 pwm1 {
323                         pwm1_out: pwm1-out {
324                                 rockchip,pins = <RK_GPIO3 28 RK_FUNC_1 &pcfg_pull_none>;
325                         };
326                 };
328                 pwm2 {
329                         pwm2_out: pwm2-out {
330                                 rockchip,pins = <RK_GPIO3 29 RK_FUNC_1 &pcfg_pull_none>;
331                         };
332                 };
334                 pwm3 {
335                         pwm3_out: pwm3-out {
336                                 rockchip,pins = <RK_GPIO3 30 RK_FUNC_1 &pcfg_pull_none>;
337                         };
338                 };
340                 spi0 {
341                         spi0_clk: spi0-clk {
342                                 rockchip,pins = <RK_GPIO1 6 RK_FUNC_2 &pcfg_pull_up>;
343                         };
344                         spi0_cs0: spi0-cs0 {
345                                 rockchip,pins = <RK_GPIO1 7 RK_FUNC_2 &pcfg_pull_up>;
346                         };
347                         spi0_tx: spi0-tx {
348                                 rockchip,pins = <RK_GPIO1 5 RK_FUNC_2 &pcfg_pull_up>;
349                         };
350                         spi0_rx: spi0-rx {
351                                 rockchip,pins = <RK_GPIO1 4 RK_FUNC_2 &pcfg_pull_up>;
352                         };
353                         spi0_cs1: spi0-cs1 {
354                                 rockchip,pins = <RK_GPIO1 15 RK_FUNC_1 &pcfg_pull_up>;
355                         };
356                 };
358                 spi1 {
359                         spi1_clk: spi1-clk {
360                                 rockchip,pins = <RK_GPIO0 30 RK_FUNC_1 &pcfg_pull_up>;
361                         };
362                         spi1_cs0: spi1-cs0 {
363                                 rockchip,pins = <RK_GPIO0 31 RK_FUNC_1 &pcfg_pull_up>;
364                         };
365                         spi1_rx: spi1-rx {
366                                 rockchip,pins = <RK_GPIO0 28 RK_FUNC_1 &pcfg_pull_up>;
367                         };
368                         spi1_tx: spi1-tx {
369                                 rockchip,pins = <RK_GPIO0 29 RK_FUNC_1 &pcfg_pull_up>;
370                         };
371                         spi1_cs1: spi1-cs1 {
372                                 rockchip,pins = <RK_GPIO1 14 RK_FUNC_2 &pcfg_pull_up>;
373                         };
374                 };
376                 uart0 {
377                         uart0_xfer: uart0-xfer {
378                                 rockchip,pins = <RK_GPIO1 0 RK_FUNC_1 &pcfg_pull_up>,
379                                                 <RK_GPIO1 1 RK_FUNC_1 &pcfg_pull_none>;
380                         };
382                         uart0_cts: uart0-cts {
383                                 rockchip,pins = <RK_GPIO1 2 RK_FUNC_1 &pcfg_pull_none>;
384                         };
386                         uart0_rts: uart0-rts {
387                                 rockchip,pins = <RK_GPIO1 3 RK_FUNC_1 &pcfg_pull_none>;
388                         };
389                 };
391                 uart1 {
392                         uart1_xfer: uart1-xfer {
393                                 rockchip,pins = <RK_GPIO1 4 RK_FUNC_1 &pcfg_pull_up>,
394                                                 <RK_GPIO1 5 RK_FUNC_1 &pcfg_pull_none>;
395                         };
397                         uart1_cts: uart1-cts {
398                                 rockchip,pins = <RK_GPIO1 6 RK_FUNC_1 &pcfg_pull_none>;
399                         };
401                         uart1_rts: uart1-rts {
402                                 rockchip,pins = <RK_GPIO1 7 RK_FUNC_1 &pcfg_pull_none>;
403                         };
404                 };
406                 uart2 {
407                         uart2_xfer: uart2-xfer {
408                                 rockchip,pins = <RK_GPIO1 8 RK_FUNC_1 &pcfg_pull_up>,
409                                                 <RK_GPIO1 9 RK_FUNC_1 &pcfg_pull_none>;
410                         };
411                         /* no rts / cts for uart2 */
412                 };
414                 uart3 {
415                         uart3_xfer: uart3-xfer {
416                                 rockchip,pins = <RK_GPIO1 10 RK_FUNC_1 &pcfg_pull_up>,
417                                                 <RK_GPIO1 11 RK_FUNC_1 &pcfg_pull_none>;
418                         };
420                         uart3_cts: uart3-cts {
421                                 rockchip,pins = <RK_GPIO1 12 RK_FUNC_1 &pcfg_pull_none>;
422                         };
424                         uart3_rts: uart3-rts {
425                                 rockchip,pins = <RK_GPIO1 13 RK_FUNC_1 &pcfg_pull_none>;
426                         };
427                 };
429                 sd0 {
430                         sd0_clk: sd0-clk {
431                                 rockchip,pins = <RK_GPIO3 2 RK_FUNC_1 &pcfg_pull_none>;
432                         };
434                         sd0_cmd: sd0-cmd {
435                                 rockchip,pins = <RK_GPIO3 3 RK_FUNC_1 &pcfg_pull_none>;
436                         };
438                         sd0_cd: sd0-cd {
439                                 rockchip,pins = <RK_GPIO3 8 RK_FUNC_1 &pcfg_pull_none>;
440                         };
442                         sd0_wp: sd0-wp {
443                                 rockchip,pins = <RK_GPIO3 9 RK_FUNC_1 &pcfg_pull_none>;
444                         };
446                         sd0_pwr: sd0-pwr {
447                                 rockchip,pins = <RK_GPIO3 1 RK_FUNC_1 &pcfg_pull_none>;
448                         };
450                         sd0_bus1: sd0-bus-width1 {
451                                 rockchip,pins = <RK_GPIO3 4 RK_FUNC_1 &pcfg_pull_none>;
452                         };
454                         sd0_bus4: sd0-bus-width4 {
455                                 rockchip,pins = <RK_GPIO3 4 RK_FUNC_1 &pcfg_pull_none>,
456                                                 <RK_GPIO3 5 RK_FUNC_1 &pcfg_pull_none>,
457                                                 <RK_GPIO3 6 RK_FUNC_1 &pcfg_pull_none>,
458                                                 <RK_GPIO3 7 RK_FUNC_1 &pcfg_pull_none>;
459                         };
460                 };
462                 sd1 {
463                         sd1_clk: sd1-clk {
464                                 rockchip,pins = <RK_GPIO3 21 RK_FUNC_1 &pcfg_pull_none>;
465                         };
467                         sd1_cmd: sd1-cmd {
468                                 rockchip,pins = <RK_GPIO3 16 RK_FUNC_1 &pcfg_pull_none>;
469                         };
471                         sd1_cd: sd1-cd {
472                                 rockchip,pins = <RK_GPIO3 22 RK_FUNC_1 &pcfg_pull_none>;
473                         };
475                         sd1_wp: sd1-wp {
476                                 rockchip,pins = <RK_GPIO3 23 RK_FUNC_1 &pcfg_pull_none>;
477                         };
479                         sd1_bus1: sd1-bus-width1 {
480                                 rockchip,pins = <RK_GPIO3 17 RK_FUNC_1 &pcfg_pull_none>;
481                         };
483                         sd1_bus4: sd1-bus-width4 {
484                                 rockchip,pins = <RK_GPIO3 17 RK_FUNC_1 &pcfg_pull_none>,
485                                                 <RK_GPIO3 18 RK_FUNC_1 &pcfg_pull_none>,
486                                                 <RK_GPIO3 19 RK_FUNC_1 &pcfg_pull_none>,
487                                                 <RK_GPIO3 20 RK_FUNC_1 &pcfg_pull_none>;
488                         };
489                 };
491                 i2s0 {
492                         i2s0_bus: i2s0-bus {
493                                 rockchip,pins = <RK_GPIO1 16 RK_FUNC_1 &pcfg_pull_none>,
494                                                 <RK_GPIO1 17 RK_FUNC_1 &pcfg_pull_none>,
495                                                 <RK_GPIO1 18 RK_FUNC_1 &pcfg_pull_none>,
496                                                 <RK_GPIO1 19 RK_FUNC_1 &pcfg_pull_none>,
497                                                 <RK_GPIO1 20 RK_FUNC_1 &pcfg_pull_none>,
498                                                 <RK_GPIO1 21 RK_FUNC_1 &pcfg_pull_none>;
499                         };
500                 };
502                 spdif {
503                         spdif_tx: spdif-tx {
504                                 rockchip,pins = <RK_GPIO1 14 RK_FUNC_1 &pcfg_pull_none>;
505                         };
506                 };
507         };
510 &emac {
511         compatible = "rockchip,rk3188-emac";
514 &global_timer {
515         interrupts = <GIC_PPI 11 0xf04>;
518 &local_timer {
519         interrupts = <GIC_PPI 13 0xf04>;
522 &i2c0 {
523         compatible = "rockchip,rk3188-i2c";
524         pinctrl-names = "default";
525         pinctrl-0 = <&i2c0_xfer>;
528 &i2c1 {
529         compatible = "rockchip,rk3188-i2c";
530         pinctrl-names = "default";
531         pinctrl-0 = <&i2c1_xfer>;
534 &i2c2 {
535         compatible = "rockchip,rk3188-i2c";
536         pinctrl-names = "default";
537         pinctrl-0 = <&i2c2_xfer>;
540 &i2c3 {
541         compatible = "rockchip,rk3188-i2c";
542         pinctrl-names = "default";
543         pinctrl-0 = <&i2c3_xfer>;
546 &i2c4 {
547         compatible = "rockchip,rk3188-i2c";
548         pinctrl-names = "default";
549         pinctrl-0 = <&i2c4_xfer>;
552 &pwm0 {
553         pinctrl-names = "default";
554         pinctrl-0 = <&pwm0_out>;
557 &pwm1 {
558         pinctrl-names = "default";
559         pinctrl-0 = <&pwm1_out>;
562 &pwm2 {
563         pinctrl-names = "default";
564         pinctrl-0 = <&pwm2_out>;
567 &pwm3 {
568         pinctrl-names = "default";
569         pinctrl-0 = <&pwm3_out>;
572 &spi0 {
573         compatible = "rockchip,rk3188-spi", "rockchip,rk3066-spi";
574         pinctrl-names = "default";
575         pinctrl-0 = <&spi0_clk &spi0_tx &spi0_rx &spi0_cs0>;
578 &spi1 {
579         compatible = "rockchip,rk3188-spi", "rockchip,rk3066-spi";
580         pinctrl-names = "default";
581         pinctrl-0 = <&spi1_clk &spi1_tx &spi1_rx &spi1_cs0>;
584 &uart0 {
585         pinctrl-names = "default";
586         pinctrl-0 = <&uart0_xfer>;
589 &uart1 {
590         pinctrl-names = "default";
591         pinctrl-0 = <&uart1_xfer>;
594 &uart2 {
595         pinctrl-names = "default";
596         pinctrl-0 = <&uart2_xfer>;
599 &uart3 {
600         pinctrl-names = "default";
601         pinctrl-0 = <&uart3_xfer>;
604 &wdt {
605         compatible = "rockchip,rk3188-wdt", "snps,dw-wdt";