ARM: shmobile: marzen: Add DU external pixel clock to DT
[linux-2.6-block.git] / arch / arm / boot / dts / r8a7791-koelsch.dts
CommitLineData
1f52c659
HN
1/*
2 * Device Tree Source for the Koelsch board
3 *
4 * Copyright (C) 2013 Renesas Electronics Corporation
08e8f0f3
SS
5 * Copyright (C) 2013-2014 Renesas Solutions Corp.
6 * Copyright (C) 2014 Cogent Embedded, Inc.
1f52c659
HN
7 *
8 * This file is licensed under the terms of the GNU General Public License
9 * version 2. This program is licensed "as is" without any warranty of any
10 * kind, whether express or implied.
11 */
12
b160f615
KM
13/*
14 * SSI-AK4643
15 *
16 * SW1: 1: AK4643
17 * 2: CN22
18 * 3: ADV7511
19 *
20 * This command is required when Playback/Capture
21 *
22 * amixer set "LINEOUT Mixer DACL" on
5c6d4b94
KM
23 * amixer set "DVC Out" 100%
24 * amixer set "DVC In" 100%
25 *
26 * You can use Mute
27 *
28 * amixer set "DVC Out Mute" on
29 * amixer set "DVC In Mute" on
ce474816
KM
30 *
31 * You can use Volume Ramp
32 *
33 * amixer set "DVC Out Ramp Up Rate" "0.125 dB/64 steps"
34 * amixer set "DVC Out Ramp Down Rate" "0.125 dB/512 steps"
35 * amixer set "DVC Out Ramp" on
36 * aplay xxx.wav &
37 * amixer set "DVC Out" 80% // Volume Down
38 * amixer set "DVC Out" 100% // Volume Up
b160f615
KM
39 */
40
1f52c659 41/dts-v1/;
31c46cbf 42#include "r8a7791.dtsi"
f8e2535d 43#include <dt-bindings/gpio/gpio.h>
7f168b1e 44#include <dt-bindings/input/input.h>
1f52c659
HN
45
46/ {
47 model = "Koelsch";
48 compatible = "renesas,koelsch", "renesas,r8a7791";
49
5ba55fa8 50 aliases {
1f75cdac
LP
51 serial0 = &scif0;
52 serial1 = &scif1;
5ba55fa8
LP
53 };
54
1f52c659 55 chosen {
79e69d17 56 bootargs = "ignore_loglevel rw root=/dev/nfs ip=dhcp";
17323b36 57 stdout-path = &scif0;
1f52c659
HN
58 };
59
60 memory@40000000 {
61 device_type = "memory";
4cd1bad4
TY
62 reg = <0 0x40000000 0 0x40000000>;
63 };
64
65 memory@200000000 {
66 device_type = "memory";
67 reg = <2 0x00000000 0 0x40000000>;
1f52c659
HN
68 };
69
70 lbsc {
71 #address-cells = <1>;
72 #size-cells = <1>;
73 };
f8e2535d 74
d3aaec83 75 keyboard {
aff5274f
LP
76 compatible = "gpio-keys";
77
7f168b1e
MD
78 key-1 {
79 gpios = <&gpio5 0 GPIO_ACTIVE_LOW>;
80 linux,code = <KEY_1>;
81 label = "SW2-1";
82 gpio-key,wakeup;
83 debounce-interval = <20>;
84 };
85 key-2 {
86 gpios = <&gpio5 1 GPIO_ACTIVE_LOW>;
87 linux,code = <KEY_2>;
88 label = "SW2-2";
89 gpio-key,wakeup;
90 debounce-interval = <20>;
91 };
92 key-3 {
93 gpios = <&gpio5 2 GPIO_ACTIVE_LOW>;
94 linux,code = <KEY_3>;
95 label = "SW2-3";
96 gpio-key,wakeup;
97 debounce-interval = <20>;
98 };
99 key-4 {
100 gpios = <&gpio5 3 GPIO_ACTIVE_LOW>;
101 linux,code = <KEY_4>;
102 label = "SW2-4";
103 gpio-key,wakeup;
104 debounce-interval = <20>;
105 };
aff5274f
LP
106 key-a {
107 gpios = <&gpio7 0 GPIO_ACTIVE_LOW>;
7f168b1e 108 linux,code = <KEY_A>;
aff5274f
LP
109 label = "SW30";
110 gpio-key,wakeup;
111 debounce-interval = <20>;
112 };
113 key-b {
114 gpios = <&gpio7 1 GPIO_ACTIVE_LOW>;
7f168b1e 115 linux,code = <KEY_B>;
aff5274f
LP
116 label = "SW31";
117 gpio-key,wakeup;
118 debounce-interval = <20>;
119 };
120 key-c {
121 gpios = <&gpio7 2 GPIO_ACTIVE_LOW>;
7f168b1e 122 linux,code = <KEY_C>;
aff5274f
LP
123 label = "SW32";
124 gpio-key,wakeup;
125 debounce-interval = <20>;
126 };
127 key-d {
128 gpios = <&gpio7 3 GPIO_ACTIVE_LOW>;
7f168b1e 129 linux,code = <KEY_D>;
aff5274f
LP
130 label = "SW33";
131 gpio-key,wakeup;
132 debounce-interval = <20>;
133 };
134 key-e {
135 gpios = <&gpio7 4 GPIO_ACTIVE_LOW>;
7f168b1e 136 linux,code = <KEY_E>;
aff5274f
LP
137 label = "SW34";
138 gpio-key,wakeup;
139 debounce-interval = <20>;
140 };
141 key-f {
142 gpios = <&gpio7 5 GPIO_ACTIVE_LOW>;
7f168b1e 143 linux,code = <KEY_F>;
aff5274f
LP
144 label = "SW35";
145 gpio-key,wakeup;
146 debounce-interval = <20>;
147 };
148 key-g {
149 gpios = <&gpio7 6 GPIO_ACTIVE_LOW>;
7f168b1e 150 linux,code = <KEY_G>;
aff5274f
LP
151 label = "SW36";
152 gpio-key,wakeup;
153 debounce-interval = <20>;
154 };
155 };
156
f8e2535d
LP
157 leds {
158 compatible = "gpio-leds";
159 led6 {
160 gpios = <&gpio2 19 GPIO_ACTIVE_HIGH>;
352faa5f 161 label = "LED6";
f8e2535d
LP
162 };
163 led7 {
164 gpios = <&gpio2 20 GPIO_ACTIVE_HIGH>;
352faa5f 165 label = "LED7";
f8e2535d
LP
166 };
167 led8 {
168 gpios = <&gpio2 21 GPIO_ACTIVE_HIGH>;
352faa5f 169 label = "LED8";
f8e2535d
LP
170 };
171 };
2c60a7df
MD
172
173 vcc_sdhi0: regulator@0 {
174 compatible = "regulator-fixed";
175
176 regulator-name = "SDHI0 Vcc";
177 regulator-min-microvolt = <3300000>;
178 regulator-max-microvolt = <3300000>;
179
180 gpio = <&gpio7 17 GPIO_ACTIVE_HIGH>;
181 enable-active-high;
182 };
183
184 vccq_sdhi0: regulator@1 {
185 compatible = "regulator-gpio";
186
187 regulator-name = "SDHI0 VccQ";
188 regulator-min-microvolt = <1800000>;
189 regulator-max-microvolt = <3300000>;
190
191 gpios = <&gpio2 12 GPIO_ACTIVE_HIGH>;
192 gpios-states = <1>;
193 states = <3300000 1
194 1800000 0>;
195 };
196
197 vcc_sdhi1: regulator@2 {
198 compatible = "regulator-fixed";
199
200 regulator-name = "SDHI1 Vcc";
201 regulator-min-microvolt = <3300000>;
202 regulator-max-microvolt = <3300000>;
203
204 gpio = <&gpio7 18 GPIO_ACTIVE_HIGH>;
205 enable-active-high;
206 };
207
208 vccq_sdhi1: regulator@3 {
209 compatible = "regulator-gpio";
210
211 regulator-name = "SDHI1 VccQ";
212 regulator-min-microvolt = <1800000>;
213 regulator-max-microvolt = <3300000>;
214
215 gpios = <&gpio2 13 GPIO_ACTIVE_HIGH>;
216 gpios-states = <1>;
217 states = <3300000 1
218 1800000 0>;
219 };
220
221 vcc_sdhi2: regulator@4 {
222 compatible = "regulator-fixed";
223
224 regulator-name = "SDHI2 Vcc";
225 regulator-min-microvolt = <3300000>;
226 regulator-max-microvolt = <3300000>;
227
228 gpio = <&gpio7 19 GPIO_ACTIVE_HIGH>;
229 enable-active-high;
230 };
231
232 vccq_sdhi2: regulator@5 {
233 compatible = "regulator-gpio";
234
235 regulator-name = "SDHI2 VccQ";
236 regulator-min-microvolt = <1800000>;
237 regulator-max-microvolt = <3300000>;
238
239 gpios = <&gpio2 26 GPIO_ACTIVE_HIGH>;
240 gpios-states = <1>;
241 states = <3300000 1
242 1800000 0>;
243 };
b160f615
KM
244
245 sound {
246 compatible = "simple-audio-card";
247
248 simple-audio-card,format = "left_j";
249 simple-audio-card,bitclock-master = <&sndcodec>;
250 simple-audio-card,frame-master = <&sndcodec>;
251
252 sndcpu: simple-audio-card,cpu {
253 sound-dai = <&rcar_sound>;
254 };
255
256 sndcodec: simple-audio-card,codec {
257 sound-dai = <&ak4643>;
258 system-clock-frequency = <11289600>;
259 };
260 };
83a0731b
LP
261
262 hdmi-out {
263 compatible = "hdmi-connector";
264 type = "a";
265
266 port {
267 hdmi_con: endpoint {
268 remote-endpoint = <&adv7511_out>;
269 };
270 };
271 };
f8e2535d
LP
272};
273
0ee56d40
LP
274&du {
275 pinctrl-0 = <&du_pins>;
276 pinctrl-names = "default";
277 status = "okay";
278
279 ports {
83a0731b
LP
280 port@0 {
281 endpoint {
282 remote-endpoint = <&adv7511_in>;
283 };
284 };
0ee56d40
LP
285 port@1 {
286 lvds_connector: endpoint {
287 };
288 };
289 };
290};
291
fcf0c725
LP
292&extal_clk {
293 clock-frequency = <20000000>;
294};
295
f8e2535d 296&pfc {
e6a4c001 297 i2c2_pins: i2c2 {
38c53516
WS
298 renesas,groups = "i2c2";
299 renesas,function = "i2c2";
300 };
301
afba941c 302 du_pins: du {
83a0731b 303 renesas,groups = "du_rgb666", "du_sync", "du_disp", "du_clk_out_0";
afba941c
LP
304 renesas,function = "du";
305 };
306
f8e2535d
LP
307 scif0_pins: serial0 {
308 renesas,groups = "scif0_data_d";
309 renesas,function = "scif0";
310 };
311
312 scif1_pins: serial1 {
313 renesas,groups = "scif1_data_d";
314 renesas,function = "scif1";
315 };
e02ee513 316
08e8f0f3
SS
317 ether_pins: ether {
318 renesas,groups = "eth_link", "eth_mdio", "eth_rmii";
319 renesas,function = "eth";
320 };
321
322 phy1_pins: phy1 {
323 renesas,groups = "intc_irq0";
324 renesas,function = "intc";
325 };
326
2c60a7df 327 sdhi0_pins: sd0 {
d5dda038 328 renesas,groups = "sdhi0_data4", "sdhi0_ctrl";
2c60a7df
MD
329 renesas,function = "sdhi0";
330 };
331
332 sdhi1_pins: sd1 {
d5dda038 333 renesas,groups = "sdhi1_data4", "sdhi1_ctrl";
2c60a7df
MD
334 renesas,function = "sdhi1";
335 };
336
337 sdhi2_pins: sd2 {
d5dda038 338 renesas,groups = "sdhi2_data4", "sdhi2_ctrl";
2c60a7df
MD
339 renesas,function = "sdhi2";
340 };
341
6f3e4ee3 342 qspi_pins: spi0 {
e02ee513
GU
343 renesas,groups = "qspi_ctrl", "qspi_data4";
344 renesas,function = "qspi";
345 };
b16f05ab
GU
346
347 msiof0_pins: spi1 {
348 renesas,groups = "msiof0_clk", "msiof0_sync", "msiof0_rx",
349 "msiof0_tx";
350 renesas,function = "msiof0";
351 };
1d41f36a 352
7540aeb0
SS
353 usb0_pins: usb0 {
354 renesas,groups = "usb0";
355 renesas,function = "usb0";
356 };
357
358 usb1_pins: usb1 {
359 renesas,groups = "usb1";
360 renesas,function = "usb1";
361 };
2cf08810 362
363 vin1_pins: vin1 {
364 renesas,groups = "vin1_data8", "vin1_clk";
365 renesas,function = "vin1";
366 };
b160f615
KM
367
368 sound_pins: sound {
369 renesas,groups = "ssi0129_ctrl", "ssi0_data", "ssi1_data";
370 renesas,function = "ssi";
371 };
372
373 sound_clk_pins: sound_clk {
374 renesas,groups = "audio_clk_a";
375 renesas,function = "audio_clk";
376 };
1f52c659 377};
760c277b 378
08e8f0f3
SS
379&ether {
380 pinctrl-0 = <&ether_pins &phy1_pins>;
381 pinctrl-names = "default";
382
383 phy-handle = <&phy1>;
384 renesas,ether-link-active-low;
815446d6 385 status = "okay";
08e8f0f3
SS
386
387 phy1: ethernet-phy@1 {
388 reg = <1>;
389 interrupt-parent = <&irqc0>;
390 interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
19f647cb 391 micrel,led-mode = <1>;
08e8f0f3
SS
392 };
393};
394
6a1d9460 395&cmt0 {
815446d6 396 status = "okay";
6a1d9460
LP
397};
398
760c277b
VB
399&sata0 {
400 status = "okay";
401};
e02ee513 402
5ba55fa8
LP
403&scif0 {
404 pinctrl-0 = <&scif0_pins>;
405 pinctrl-names = "default";
406
407 status = "okay";
408};
409
410&scif1 {
411 pinctrl-0 = <&scif1_pins>;
412 pinctrl-names = "default";
413
414 status = "okay";
415};
416
2c60a7df
MD
417&sdhi0 {
418 pinctrl-0 = <&sdhi0_pins>;
419 pinctrl-names = "default";
420
421 vmmc-supply = <&vcc_sdhi0>;
422 vqmmc-supply = <&vccq_sdhi0>;
423 cd-gpios = <&gpio6 6 GPIO_ACTIVE_LOW>;
424 wp-gpios = <&gpio6 7 GPIO_ACTIVE_HIGH>;
425 status = "okay";
426};
427
428&sdhi1 {
429 pinctrl-0 = <&sdhi1_pins>;
430 pinctrl-names = "default";
431
432 vmmc-supply = <&vcc_sdhi1>;
433 vqmmc-supply = <&vccq_sdhi1>;
434 cd-gpios = <&gpio6 14 GPIO_ACTIVE_LOW>;
435 wp-gpios = <&gpio6 15 GPIO_ACTIVE_HIGH>;
436 status = "okay";
437};
438
439&sdhi2 {
440 pinctrl-0 = <&sdhi2_pins>;
441 pinctrl-names = "default";
442
443 vmmc-supply = <&vcc_sdhi2>;
444 vqmmc-supply = <&vccq_sdhi2>;
445 cd-gpios = <&gpio6 22 GPIO_ACTIVE_LOW>;
446 status = "okay";
447};
448
6f3e4ee3 449&qspi {
e02ee513
GU
450 pinctrl-0 = <&qspi_pins>;
451 pinctrl-names = "default";
452
453 status = "okay";
454
455 flash: flash@0 {
456 #address-cells = <1>;
457 #size-cells = <1>;
458 compatible = "spansion,s25fl512s";
459 reg = <0>;
460 spi-max-frequency = <30000000>;
ed56083a
GU
461 spi-tx-bus-width = <4>;
462 spi-rx-bus-width = <4>;
9c5becce
HN
463 spi-cpha;
464 spi-cpol;
e02ee513
GU
465 m25p,fast-read;
466
467 partition@0 {
468 label = "loader";
469 reg = <0x00000000 0x00080000>;
470 read-only;
471 };
472 partition@80000 {
5f950e62
SH
473 label = "user";
474 reg = <0x00080000 0x00580000>;
e02ee513
GU
475 read-only;
476 };
5f950e62
SH
477 partition@600000 {
478 label = "flash";
479 reg = <0x00600000 0x03a00000>;
e02ee513
GU
480 };
481 };
482};
b16f05ab
GU
483
484&msiof0 {
485 pinctrl-0 = <&msiof0_pins>;
486 pinctrl-names = "default";
487
488 status = "okay";
489
490 pmic: pmic@0 {
491 compatible = "renesas,r2a11302ft";
492 reg = <0>;
493 spi-max-frequency = <6000000>;
494 spi-cpol;
495 spi-cpha;
496 };
497};
1d41f36a 498
897dfdbc
SH
499&i2c2 {
500 pinctrl-0 = <&i2c2_pins>;
501 pinctrl-names = "default";
502
503 status = "okay";
a8d943ed 504 clock-frequency = <100000>;
897dfdbc 505
b160f615
KM
506 ak4643: sound-codec@12 {
507 compatible = "asahi-kasei,ak4643";
508 #sound-dai-cells = <0>;
509 reg = <0x12>;
510 };
897dfdbc 511
2cf08810 512 composite-in@20 {
513 compatible = "adi,adv7180";
514 reg = <0x20>;
515 remote = <&vin1>;
516
517 port {
518 adv7180: endpoint {
519 bus-width = <8>;
520 remote-endpoint = <&vin1ep>;
521 };
522 };
523 };
524
83a0731b
LP
525 hdmi@39 {
526 compatible = "adi,adv7511w";
527 reg = <0x39>;
528 interrupt-parent = <&gpio3>;
529 interrupts = <29 IRQ_TYPE_EDGE_FALLING>;
530
531 adi,input-depth = <8>;
532 adi,input-colorspace = "rgb";
533 adi,input-clock = "1x";
534 adi,input-style = <1>;
535 adi,input-justification = "evenly";
536
537 ports {
538 #address-cells = <1>;
539 #size-cells = <0>;
540
541 port@0 {
542 reg = <0>;
543 adv7511_in: endpoint {
544 remote-endpoint = <&du_out_rgb>;
545 };
546 };
547
548 port@1 {
549 reg = <1>;
550 adv7511_out: endpoint {
551 remote-endpoint = <&hdmi_con>;
552 };
553 };
554 };
555 };
556
897dfdbc
SH
557 eeprom@50 {
558 compatible = "renesas,24c02";
559 reg = <0x50>;
560 pagesize = <16>;
561 };
562};
563
1d41f36a 564&i2c6 {
1d41f36a 565 status = "okay";
897dfdbc 566 clock-frequency = <100000>;
1d41f36a
GI
567
568 vdd_dvfs: regulator@68 {
bd597f47 569 compatible = "dlg,da9210";
1d41f36a
GI
570 reg = <0x68>;
571
572 regulator-min-microvolt = <1000000>;
573 regulator-max-microvolt = <1000000>;
574 regulator-boot-on;
575 regulator-always-on;
576 };
577};
a57004ec 578
7540aeb0
SS
579&pci0 {
580 status = "okay";
581 pinctrl-0 = <&usb0_pins>;
582 pinctrl-names = "default";
583};
584
585&pci1 {
586 status = "okay";
587 pinctrl-0 = <&usb1_pins>;
588 pinctrl-names = "default";
589};
590
fc4a00b7
YS
591&hsusb {
592 status = "okay";
593 pinctrl-0 = <&usb0_pins>;
594 pinctrl-names = "default";
595 renesas,enable-gpio = <&gpio5 31 GPIO_ACTIVE_HIGH>;
596};
597
dc80d8bc
SS
598&usbphy {
599 status = "okay";
600};
601
998d7d64
PE
602&pcie_bus_clk {
603 status = "okay";
604};
605
606&pciec {
607 status = "okay";
608};
609
a57004ec
GI
610&cpu0 {
611 cpu0-supply = <&vdd_dvfs>;
612};
2cf08810 613
614/* composite video input */
615&vin1 {
815446d6 616 status = "okay";
2cf08810 617 pinctrl-0 = <&vin1_pins>;
618 pinctrl-names = "default";
619
620 port {
621 #address-cells = <1>;
622 #size-cells = <0>;
623
624 vin1ep: endpoint {
625 remote-endpoint = <&adv7180>;
626 bus-width = <8>;
627 };
628 };
629};
b160f615
KM
630
631&rcar_sound {
632 pinctrl-0 = <&sound_pins &sound_clk_pins>;
633 pinctrl-names = "default";
634
d2b541c9 635 /* Single DAI */
b160f615
KM
636 #sound-dai-cells = <0>;
637
638 status = "okay";
639
640 rcar_sound,dai {
641 dai0 {
5c6d4b94
KM
642 playback = <&ssi0 &src2 &dvc0>;
643 capture = <&ssi1 &src3 &dvc1>;
b160f615
KM
644 };
645 };
646};
647
b160f615 648&ssi1 {
b160f615
KM
649 shared-pin;
650};