Linux Audio

Check our new training course

Loading...
v6.2
  1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
  2/*
  3 * Copyright (c) 2018 MundoReader S.L.
  4 * Author:  Heiko Stuebner <heiko.stuebner@bq.com>
  5 */
  6
  7/dts-v1/;
  8#include <dt-bindings/i2c/i2c.h>
  9#include <dt-bindings/input/input.h>
 10#include <dt-bindings/interrupt-controller/irq.h>
 11#include "rk3188.dtsi"
 12
 13/ {
 14	model = "BQ Edison2 Quad-Core";
 15	compatible = "mundoreader,bq-edison2qc", "rockchip,rk3188";
 16
 17	aliases {
 18		mmc0 = &mmc0;
 19		mmc1 = &mmc1;
 20		mmc2 = &emmc;
 21	};
 22
 23	memory@60000000 {
 24		device_type = "memory";
 25		reg = <0x60000000 0x80000000>;
 26	};
 27
 28	backlight: backlight {
 29		compatible = "pwm-backlight";
 30		power-supply = <&vsys>;
 31		pwms = <&pwm1 0 25000>;
 32	};
 33
 34	gpio-keys {
 35		compatible = "gpio-keys";
 36		autorepeat;
 37		pinctrl-names = "default";
 38		pinctrl-0 = <&pwr_key &usb_int>;
 39
 40		key-power {
 41			gpios = <&gpio0 RK_PA4 GPIO_ACTIVE_LOW>;
 42			linux,code = <KEY_POWER>;
 43			label = "GPIO Key Power";
 44			linux,input-type = <1>;
 45			debounce-interval = <100>;
 46			wakeup-source;
 47		};
 48
 49		wake_on_usb: key-wake-on-usb {
 50			label = "Wake-on-USB";
 51			gpios = <&gpio0 RK_PA7 GPIO_ACTIVE_LOW>;
 52			linux,code = <KEY_WAKEUP>;
 53			wakeup-source;
 54		};
 55	};
 56
 57	gpio-poweroff {
 58		compatible = "gpio-poweroff";
 59		gpios = <&gpio0 RK_PA0 GPIO_ACTIVE_LOW>;
 60		pinctrl-names = "default";
 61		pinctrl-0 = <&pwr_hold>;
 62		/* only drive the pin low until device is off */
 63		active-delay-ms = <3000>;
 64	};
 65
 66	lvds-encoder {
 67		compatible = "ti,sn75lvds83", "lvds-encoder";
 68
 69		ports {
 70			#address-cells = <1>;
 71			#size-cells = <0>;
 72
 73			port@0 {
 74				reg = <0>;
 75
 76				lvds_in_vop0: endpoint {
 77					remote-endpoint = <&vop0_out_lvds>;
 78				};
 79			};
 80
 81			port@1 {
 82				reg = <1>;
 83
 84				lvds_out_panel: endpoint {
 85					remote-endpoint = <&panel_in_lvds>;
 86				};
 87			};
 88		};
 89	};
 90
 91	panel {
 92		compatible = "innolux,ee101ia-01d", "panel-lvds";
 93		backlight = <&backlight>;
 94
 95		/* pin LCD_CS, Nshtdn input of lvds-encoder */
 96		enable-gpios = <&gpio3 RK_PD6 GPIO_ACTIVE_HIGH>;
 97		pinctrl-names = "default";
 98		pinctrl-0 = <&lcd_cs>;
 99		power-supply = <&vcc_lcd>;
100
101		data-mapping = "vesa-24";
102		height-mm = <163>;
103		width-mm = <261>;
104
105		panel-timing {
106			clock-frequency = <72000000>;
107			hactive = <1280>;
108			vactive = <800>;
109			hback-porch = <160>;
110			hfront-porch = <16>;
111			hsync-len = <10>;
112			vback-porch = <23>;
113			vfront-porch = <12>;
114			vsync-len = <3>;
115		};
116
117		port {
118			panel_in_lvds: endpoint {
119				remote-endpoint = <&lvds_out_panel>;
120			};
121		};
122	};
123
124	sdio_pwrseq: sdio-pwrseq {
125		compatible = "mmc-pwrseq-simple";
126		clocks = <&hym8563>;
127		clock-names = "ext_clock";
128		pinctrl-names = "default";
129		pinctrl-0 = <&wifi_reg_on>;
130		reset-gpios = <&gpio3 RK_PD0 GPIO_ACTIVE_LOW>;
131	};
132
133	avdd_cif: cif-avdd-regulator {
134		compatible = "regulator-fixed";
135		regulator-name = "avdd-cif";
136		regulator-min-microvolt = <2800000>;
137		regulator-max-microvolt = <2800000>;
138		gpio = <&gpio1 RK_PA6 GPIO_ACTIVE_LOW>;
139		pinctrl-names = "default";
140		pinctrl-0 = <&cif_avdd_en>;
141		startup-delay-us = <100000>;
142		vin-supply = <&vcc28_cif>;
143	};
144
145	vcc_5v: vcc-5v-regulator {
146		compatible = "regulator-fixed";
147		regulator-name = "vcc-5v";
148		regulator-min-microvolt = <5000000>;
149		regulator-max-microvolt = <5000000>;
150		enable-active-high;
151		gpio = <&gpio0 RK_PA3 GPIO_ACTIVE_HIGH>;
152		pinctrl-names = "default";
153		pinctrl-0 = <&v5_drv>;
154		vin-supply = <&vsys>;
155	};
156
157	vcc_lcd: lcd-regulator {
158		compatible = "regulator-fixed";
159		regulator-name = "vcc-lcd";
160		gpio = <&gpio0 RK_PB0 GPIO_ACTIVE_LOW>;
161		pinctrl-names = "default";
162		pinctrl-0 = <&lcd_en>;
163		startup-delay-us = <50000>;
164		vin-supply = <&vcc_io>;
165	};
166
167	vcc_otg: usb-otg-regulator {
168		compatible = "regulator-fixed";
169		regulator-name = "vcc-otg";
170		regulator-min-microvolt = <5000000>;
171		regulator-max-microvolt = <5000000>;
172		enable-active-high;
173		gpio = <&gpio3 RK_PB1 GPIO_ACTIVE_HIGH>;
174		pinctrl-names = "default";
175		pinctrl-0 = <&otg_drv>;
176		startup-delay-us = <100000>;
177		vin-supply = <&vcc_5v>;
178	};
179
180	vcc_sd: sdmmc-regulator {
181		compatible = "regulator-fixed";
182		regulator-name = "vcc-sd";
183		regulator-min-microvolt = <3300000>;
184		regulator-max-microvolt = <3300000>;
185		gpio = <&gpio3 RK_PA1 GPIO_ACTIVE_LOW>;
186		pinctrl-names = "default";
187		pinctrl-0 = <&sdmmc_pwr>;
188		startup-delay-us = <100000>;
189		vin-supply = <&vcc_io>;
190	};
191
192	vccq_emmc: emmc-vccq-regulator {
193		compatible = "regulator-fixed";
194		regulator-name = "vccq-emmc";
195		regulator-min-microvolt = <2800000>;
196		regulator-max-microvolt = <2800000>;
197		vin-supply = <&vcc_io>;
198	};
199
200	/* supplied from the bq24196 */
201	vsys: vsys-regulator {
202		compatible = "regulator-fixed";
203		regulator-name = "vsys";
204		regulator-min-microvolt = <5000000>;
205		regulator-max-microvolt = <5000000>;
206		regulator-boot-on;
207	};
208};
209
210&cpu0 {
211	cpu-supply = <&vdd_arm>;
212};
213
214&cpu1 {
215	cpu-supply = <&vdd_arm>;
216};
217
218&cpu2 {
219	cpu-supply = <&vdd_arm>;
220};
221
222&cpu3 {
223	cpu-supply = <&vdd_arm>;
224};
225
226&cru {
227	assigned-clocks = <&cru PLL_GPLL>, <&cru PLL_CPLL>,
228			  <&cru ACLK_CPU>,
229			  <&cru HCLK_CPU>, <&cru PCLK_CPU>,
230			  <&cru ACLK_PERI>, <&cru HCLK_PERI>,
231			  <&cru PCLK_PERI>;
232	assigned-clock-rates = <594000000>, <504000000>,
233			       <300000000>,
234			       <150000000>, <75000000>,
235			       <300000000>, <150000000>,
236			       <75000000>;
237};
238
239&emmc {
240	bus-width = <8>;
241	cap-mmc-highspeed;
242	non-removable;
243	pinctrl-names = "default";
244	pinctrl-0 = <&emmc_clk &emmc_cmd>;
245	vmmc-supply = <&vcc_io>;
246	vqmmc-supply = <&vccq_emmc>;
247	status = "okay";
248};
249
250&gpu {
251	status = "okay";
252};
253
254&i2c0 {
255	clock-frequency = <400000>;
256	status = "okay";
257
258	lis3de: accelerometer@29 {
259		compatible = "st,lis3de";
260		reg = <0x29>;
261		interrupt-parent = <&gpio0>;
262		interrupts = <RK_PB7 IRQ_TYPE_EDGE_RISING>;
263		pinctrl-names = "default";
264		pinctrl-0 = <&gsensor_int>;
265		rotation-matrix = "1", "0", "0",
266				  "0", "-1", "0",
267				  "0", "0", "1";
268		vdd-supply = <&vcc_io>;
269	};
270};
271
272&i2c1 {
273	clock-frequency = <400000>;
274	status = "okay";
275
276	tmp108@48 {
277		compatible = "ti,tmp108";
278		reg = <0x48>;
279		interrupt-parent = <&gpio1>;
280		interrupts = <RK_PA7 IRQ_TYPE_LEVEL_LOW>;
281		pinctrl-names = "default";
282		pinctrl-0 = <&tmp_alrt>;
283		#thermal-sensor-cells = <0>;
284	};
285
286	hym8563: rtc@51 {
287		compatible = "haoyu,hym8563";
288		reg = <0x51>;
289		interrupt-parent = <&gpio0>;
290		interrupts = <RK_PB5 IRQ_TYPE_EDGE_FALLING>;
291		pinctrl-names = "default";
292		pinctrl-0 = <&rtc_int>;
293		#clock-cells = <0>;
294		clock-output-names = "xin32k";
295	};
296
297	bat: battery@55 {
298		compatible = "ti,bq27541";
299		reg = <0x55>;
300		power-supplies = <&bq24196>;
301	};
302
303	act8846: pmic@5a {
304		compatible = "active-semi,act8846";
305		reg = <0x5a>;
306		pinctrl-names = "default";
307		pinctrl-0 = <&dvs0_ctl &pmic_int>;
308
309		vp1-supply = <&vsys>;
310		vp2-supply = <&vsys>;
311		vp3-supply = <&vsys>;
312		vp4-supply = <&vsys>;
313		inl1-supply = <&vcc_io>;
314		inl2-supply = <&vsys>;
315		inl3-supply = <&vsys>;
316
317		regulators {
318			vcc_ddr: REG1 {
319				regulator-name = "VCC_DDR";
320				regulator-min-microvolt = <1200000>;
321				regulator-max-microvolt = <1200000>;
322				regulator-always-on;
323			};
324
325			vdd_log: REG2 {
326				regulator-name = "VDD_LOG";
327				regulator-min-microvolt = <1000000>;
328				regulator-max-microvolt = <1200000>;
329				regulator-always-on;
330			};
331
332			vdd_arm: REG3 {
333				regulator-name = "VDD_ARM";
334				regulator-min-microvolt = <875000>;
335				regulator-max-microvolt = <1350000>;
336				regulator-always-on;
337			};
338
339			vcc_io: vcc_hdmi: REG4 {
340				regulator-name = "VCC_IO";
341				regulator-min-microvolt = <3000000>;
342				regulator-max-microvolt = <3000000>;
343				regulator-always-on;
344			};
345
346			vdd_10: REG5 {
347				regulator-name = "VDD_10";
348				regulator-min-microvolt = <1000000>;
349				regulator-max-microvolt = <1000000>;
350				regulator-always-on;
351			};
352
353			vdd_12: REG6 {
354				regulator-name = "VDD_12";
355				regulator-min-microvolt = <1200000>;
356				regulator-max-microvolt = <1200000>;
357				regulator-always-on;
358			};
359
360			vcc18_cif: REG7 {
361				regulator-name = "VCC18_CIF";
362				regulator-min-microvolt = <1800000>;
363				regulator-max-microvolt = <1800000>;
364				regulator-always-on;
365			};
366
367			vcca_33: REG8 {
368				regulator-name = "VCCA_33";
369				regulator-min-microvolt = <3300000>;
370				regulator-max-microvolt = <3300000>;
371				regulator-always-on;
372			};
373
374			vcc_tp: REG9 {
375				regulator-name = "VCC_TP";
376				regulator-min-microvolt = <3300000>;
377				regulator-max-microvolt = <3300000>;
378				regulator-always-on;
379			};
380
381			vccio_wl: REG10 {
382				regulator-name = "VCCIO_WL";
383				regulator-min-microvolt = <2800000>;
384				regulator-max-microvolt = <2800000>;
385				regulator-always-on;
386			};
387
388			vcc_18: REG11 {
389				regulator-name = "VCC_18";
390				regulator-min-microvolt = <1800000>;
391				regulator-max-microvolt = <1800000>;
392				regulator-always-on;
393			};
394
395			vcc28_cif: REG12 {
396				regulator-name = "VCC28_CIF";
397				regulator-min-microvolt = <2800000>;
398				regulator-max-microvolt = <2800000>;
399				regulator-always-on;
400			};
401		};
402	};
403
404	bq24196: charger@6b {
405		compatible = "ti,bq24196";
406		reg = <0x6b>;
407		interrupt-parent = <&gpio0>;
408		interrupts = <RK_PD7 IRQ_TYPE_EDGE_FALLING>;
409		pinctrl-names = "default";
410		pinctrl-0 = <&charger_int &chg_ctl &otg_en>;
411		ti,system-minimum-microvolt = <3200000>;
412		monitored-battery = <&bat>;
413		omit-battery-class;
414
415		usb_otg_vbus: usb-otg-vbus { };
416	};
417};
418
419&i2c2 {
420	clock-frequency = <400000>;
421	status = "okay";
422
423	ft5606: touchscreen@3e {
424		compatible = "edt,edt-ft5506";
425		reg = <0x3e>;
426		interrupt-parent = <&gpio1>;
427		interrupts = <RK_PB7 IRQ_TYPE_EDGE_FALLING>;
428		pinctrl-names = "default";
429		pinctrl-0 = <&tp_int &tp_rst>;
430		reset-gpios = <&gpio0 RK_PB6 GPIO_ACTIVE_LOW>;
431		touchscreen-inverted-y;
432		/* hw ts resolution does not match display */
433		touchscreen-size-y = <1024>;
434		touchscreen-size-x = <768>;
435		touchscreen-swapped-x-y;
436	};
437};
438
439&i2c3 {
440	clock-frequency = <400000>;
441	status = "okay";
442};
443
444&i2c4 {
445	clock-frequency = <400000>;
446	status = "okay";
447
448	rt5616: codec@1b {
449		compatible = "realtek,rt5616";
450		reg = <0x1b>;
451		clocks = <&cru SCLK_I2S0>;
452		clock-names = "mclk";
453		#sound-dai-cells = <0>;
454	};
455};
456
457&i2s0 {
458	status = "okay";
459};
460
461&mmc0 {
462	bus-width = <4>;
463	cap-mmc-highspeed;
464	cap-sd-highspeed;
465	disable-wp;
466	pinctrl-names = "default";
467	pinctrl-0 = <&sd0_clk>, <&sd0_cmd>, <&sd0_cd>, <&sd0_bus4>;
468	vmmc-supply = <&vcc_sd>;
469	status = "okay";
470};
471
472&mmc1 {
473	bus-width = <4>;
474	cap-sd-highspeed;
475	keep-power-in-suspend;
476	mmc-pwrseq = <&sdio_pwrseq>;
477	non-removable;
478	pinctrl-names = "default";
479	pinctrl-0 = <&sd1_clk>, <&sd1_cmd>, <&sd1_bus4>;
480	vqmmc-supply = <&vccio_wl>;
481	#address-cells = <1>;
482	#size-cells = <0>;
483	status = "okay";
484
485	brcmf: wifi@1 {
486		reg = <1>;
487		compatible = "brcm,bcm4329-fmac";
488		interrupt-parent = <&gpio3>;
489		interrupts = <RK_PD2 IRQ_TYPE_NONE>;
490		interrupt-names = "host-wake";
491		brcm,drive-strength = <5>;
492		pinctrl-names = "default";
493		pinctrl-0 = <&wifi_host_wake>;
494	};
495};
496
497&pwm1 {
498	status = "okay";
499};
500
501&pinctrl {
502	pcfg_output_high: pcfg-output-high {
503		output-high;
504	};
505
506	pcfg_output_low: pcfg-output-low {
507		output-low;
508	};
509
510	act8846 {
511		dvs0_ctl: dvs0-ctl {
512			rockchip,pins = <3 RK_PD3 RK_FUNC_GPIO &pcfg_output_low>;
513		};
514
515		pmic_int: pmic-int {
516			rockchip,pins = <0 RK_PB3 RK_FUNC_GPIO &pcfg_pull_up>;
517		};
518	};
519
520	bq24196 {
521		charger_int: charger-int {
522			rockchip,pins = <0 RK_PD7 RK_FUNC_GPIO &pcfg_pull_up>;
523		};
524
525		/* pin hog to make it select usb profile */
526		chg_ctl: chg-ctl {
527			rockchip,pins = <0 RK_PA1 RK_FUNC_GPIO &pcfg_output_high>;
528		};
529
530		/* low: charging, high: complete, fault: blinking */
531		chg_det: chg-det {
532			rockchip,pins = <0 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
533		};
534
535		/* charging enabled when pin low and register set */
536		chg_en: chg-en {
537			rockchip,pins = <0 RK_PC1 RK_FUNC_GPIO &pcfg_output_low>;
538		};
539
540		/* bq29196 powergood (when low) signal */
541		dc_det: dc-det {
542			rockchip,pins = <0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;
543		};
544
545		/* wire bq24196 otg pin to high, to enable 500mA charging */
546		otg_en: otg-en {
547			rockchip,pins = <0 RK_PB1 RK_FUNC_GPIO &pcfg_output_high>;
548		};
549	};
550
551	camera {
552		cif0_pdn: cif0-pdn {
553			rockchip,pins = <3 RK_PB4 RK_FUNC_GPIO &pcfg_pull_none>;
554		};
555
556		cif1_pdn: cif1-pdn {
557			rockchip,pins = <3 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>;
558		};
559
560		cif_avdd_en: cif-avdd-en {
561			rockchip,pins = <1 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
562		};
563	};
564
565	display {
566		lcd_cs: lcd-cs {
567			rockchip,pins = <3 RK_PD6 RK_FUNC_GPIO &pcfg_pull_none>;
568		};
569
570		lcd_en: lcd-en {
571			rockchip,pins = <0 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>;
572		};
573	};
574
575	ft5606 {
576		tp_int: tp-int {
577			rockchip,pins = <1 RK_PB7 RK_FUNC_GPIO &pcfg_pull_up>;
578		};
579
580		tp_rst: tp-rst {
581			rockchip,pins = <0 RK_PB6 RK_FUNC_GPIO &pcfg_pull_none>;
582		};
583	};
584
585	hdmi {
586		hdmi_int: hdmi-int {
587			rockchip,pins = <2 RK_PD6 RK_FUNC_GPIO &pcfg_pull_up>;
588		};
589
590		hdmi_rst: hdmi-rst {
591			rockchip,pins = <3 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;
592		};
593	};
594
595	hym8563 {
596		rtc_int: rtc-int {
597			rockchip,pins = <0 RK_PB5 RK_FUNC_GPIO &pcfg_pull_up>;
598		};
599	};
600
601	keys {
602		pwr_hold: pwr-hold {
603			rockchip,pins = <0 RK_PA0 RK_FUNC_GPIO &pcfg_pull_up>;
604		};
605
606		pwr_key: pwr-key {
607			rockchip,pins = <0 RK_PA4 RK_FUNC_GPIO &pcfg_pull_up>;
608		};
609	};
610
611	lis3de {
612		gsensor_int: gsensor-int {
613			rockchip,pins = <0 RK_PB7 RK_FUNC_GPIO &pcfg_pull_none>;
614		};
615	};
616
617	mmc {
618		sdmmc_pwr: sdmmc-pwr {
619			rockchip,pins = <3 RK_PA1 RK_FUNC_GPIO &pcfg_pull_none>;
620		};
621	};
622
623	tmp108 {
624		tmp_alrt: tmp-alrt {
625			rockchip,pins = <1 RK_PA7 RK_FUNC_GPIO &pcfg_pull_none>;
626		};
627	};
628
629	usb {
630		v5_drv: v5-drv {
631			rockchip,pins = <0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;
632		};
633
634		otg_drv: otg-drv {
635			rockchip,pins = <3 RK_PB1 RK_FUNC_GPIO &pcfg_pull_none>;
636		};
637
638		usb_int: usb-int {
639			rockchip,pins = <0 RK_PA7 RK_FUNC_GPIO &pcfg_pull_up>;
640		};
641	};
642
643	rk903 {
644		bt_host_wake: bt-host-wake {
645			rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>;
646		};
647
648		bt_reg_on: bt-reg-on {
649			rockchip,pins = <3 RK_PC7 RK_FUNC_GPIO &pcfg_pull_none>;
650		};
651
652		/* pin hog to pull the reset high */
653		bt_rst: bt-rst {
654			rockchip,pins = <3 RK_PD1 RK_FUNC_GPIO &pcfg_output_high>;
655		};
656
657		bt_wake: bt-wake {
658			rockchip,pins = <3 RK_PC6 RK_FUNC_GPIO &pcfg_pull_none>;
659		};
660
661		wifi_host_wake: wifi-host-wake {
662			rockchip,pins = <3 RK_PD2 RK_FUNC_GPIO &pcfg_pull_up>;
663		};
664
665		wifi_reg_on: wifi-reg-on {
666			rockchip,pins = <3 RK_PD0 RK_FUNC_GPIO &pcfg_pull_none>;
667		};
668	};
669};
670
671&saradc {
672	vref-supply = <&vcc_18>;
673	status = "okay";
674};
675
676&spdif {
677	status = "okay";
678};
679
680&uart0 {
681	pinctrl-0 = <&uart0_xfer &uart0_cts &uart0_rts>;
682	status = "okay";
683
684	bluetooth {
685		compatible = "brcm,bcm43438-bt";
686		max-speed = <2000000>;
687		device-wakeup-gpios = <&gpio3 RK_PC6 GPIO_ACTIVE_HIGH>;
688		host-wakeup-gpios = <&gpio0 RK_PA5 GPIO_ACTIVE_HIGH>;
689		shutdown-gpios = <&gpio3 RK_PC7 GPIO_ACTIVE_HIGH>;
690		pinctrl-names = "default";
691		pinctrl-0 = <&bt_host_wake &bt_reg_on &bt_rst &bt_wake>;
692	};
693};
694
695&uart1 {
696	status = "okay";
697};
698
699&uart2 {
700	status = "okay";
701};
702
703&uart3 {
704	pinctrl-0 = <&uart3_xfer &uart3_cts &uart3_rts>;
705	status = "okay";
706};
707
708&usbphy {
709	status = "okay";
710};
711
712&usb_host {
713	status = "okay";
714};
715
716&usb_otg {
717	status = "okay";
718};
719
720&vop0 {
721	status = "okay";
722};
723
724&vop0_out {
725	vop0_out_lvds: endpoint {
726		remote-endpoint = <&lvds_in_vop0>;
727	};
728};
729
730&vop1 {
731	pinctrl-names = "default";
732	pinctrl-0 = <&lcdc1_dclk &lcdc1_den &lcdc1_hsync
733		     &lcdc1_vsync &lcdc1_rgb24>;
734	status = "okay";
735};
736
737&wdt {
738	status = "okay";
739};
v5.9
  1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
  2/*
  3 * Copyright (c) 2018 MundoReader S.L.
  4 * Author:  Heiko Stuebner <heiko.stuebner@bq.com>
  5 */
  6
  7/dts-v1/;
  8#include <dt-bindings/i2c/i2c.h>
  9#include <dt-bindings/input/input.h>
 
 10#include "rk3188.dtsi"
 11
 12/ {
 13	model = "BQ Edison2 Quad-Core";
 14	compatible = "mundoreader,bq-edison2qc", "rockchip,rk3188";
 15
 
 
 
 
 
 
 16	memory@60000000 {
 17		device_type = "memory";
 18		reg = <0x60000000 0x80000000>;
 19	};
 20
 21	backlight: backlight {
 22		compatible = "pwm-backlight";
 23		power-supply = <&vsys>;
 24		pwms = <&pwm1 0 25000>;
 25	};
 26
 27	gpio-keys {
 28		compatible = "gpio-keys";
 29		autorepeat;
 30		pinctrl-names = "default";
 31		pinctrl-0 = <&pwr_key &usb_int>;
 32
 33		power {
 34			gpios = <&gpio0 RK_PA4 GPIO_ACTIVE_LOW>;
 35			linux,code = <KEY_POWER>;
 36			label = "GPIO Key Power";
 37			linux,input-type = <1>;
 38			debounce-interval = <100>;
 39			wakeup-source;
 40		};
 41
 42		wake_on_usb: wake-on-usb {
 43			label = "Wake-on-USB";
 44			gpios = <&gpio0 RK_PA7 GPIO_ACTIVE_LOW>;
 45			linux,code = <KEY_WAKEUP>;
 46			wakeup-source;
 47		};
 48	};
 49
 50	gpio-poweroff {
 51		compatible = "gpio-poweroff";
 52		gpios = <&gpio0 RK_PA0 GPIO_ACTIVE_LOW>;
 53		pinctrl-names = "default";
 54		pinctrl-0 = <&pwr_hold>;
 55		/* only drive the pin low until device is off */
 56		active-delay-ms = <3000>;
 57	};
 58
 59	lvds-encoder {
 60		compatible = "ti,sn75lvds83", "lvds-encoder";
 61
 62		ports {
 63			#address-cells = <1>;
 64			#size-cells = <0>;
 65
 66			port@0 {
 67				reg = <0>;
 68
 69				lvds_in_vop0: endpoint {
 70					remote-endpoint = <&vop0_out_lvds>;
 71				};
 72			};
 73
 74			port@1 {
 75				reg = <1>;
 76
 77				lvds_out_panel: endpoint {
 78					remote-endpoint = <&panel_in_lvds>;
 79				};
 80			};
 81		};
 82	};
 83
 84	panel {
 85		compatible = "innolux,ee101ia-01d", "panel-lvds";
 86		backlight = <&backlight>;
 87
 88		/* pin LCD_CS, Nshtdn input of lvds-encoder */
 89		enable-gpios = <&gpio3 RK_PD6 GPIO_ACTIVE_HIGH>;
 90		pinctrl-names = "default";
 91		pinctrl-0 = <&lcd_cs>;
 92		power-supply = <&vcc_lcd>;
 93
 94		data-mapping = "vesa-24";
 95		height-mm = <163>;
 96		width-mm = <261>;
 97
 98		panel-timing {
 99			clock-frequency = <72000000>;
100			hactive = <1280>;
101			vactive = <800>;
102			hback-porch = <160>;
103			hfront-porch = <16>;
104			hsync-len = <10>;
105			vback-porch = <23>;
106			vfront-porch = <12>;
107			vsync-len = <3>;
108		};
109
110		port {
111			panel_in_lvds: endpoint {
112				remote-endpoint = <&lvds_out_panel>;
113			};
114		};
115	};
116
117	sdio_pwrseq: sdio-pwrseq {
118		compatible = "mmc-pwrseq-simple";
119		clocks = <&hym8563>;
120		clock-names = "ext_clock";
121		pinctrl-names = "default";
122		pinctrl-0 = <&wifi_reg_on>;
123		reset-gpios = <&gpio3 RK_PD0 GPIO_ACTIVE_LOW>;
124	};
125
126	avdd_cif: cif-avdd-regulator {
127		compatible = "regulator-fixed";
128		regulator-name = "avdd-cif";
129		regulator-min-microvolt = <2800000>;
130		regulator-max-microvolt = <2800000>;
131		gpio = <&gpio1 RK_PA6 GPIO_ACTIVE_LOW>;
132		pinctrl-names = "default";
133		pinctrl-0 = <&cif_avdd_en>;
134		startup-delay-us = <100000>;
135		vin-supply = <&vcc28_cif>;
136	};
137
138	vcc_5v: vcc-5v-regulator {
139		compatible = "regulator-fixed";
140		regulator-name = "vcc-5v";
141		regulator-min-microvolt = <5000000>;
142		regulator-max-microvolt = <5000000>;
143		enable-active-high;
144		gpio = <&gpio0 RK_PA3 GPIO_ACTIVE_HIGH>;
145		pinctrl-names = "default";
146		pinctrl-0 = <&v5_drv>;
147		vin-supply = <&vsys>;
148	};
149
150	vcc_lcd: lcd-regulator {
151		compatible = "regulator-fixed";
152		regulator-name = "vcc-lcd";
153		gpio = <&gpio0 RK_PB0 GPIO_ACTIVE_LOW>;
154		pinctrl-names = "default";
155		pinctrl-0 = <&lcd_en>;
156		startup-delay-us = <50000>;
157		vin-supply = <&vcc_io>;
158	};
159
160	vcc_otg: usb-otg-regulator {
161		compatible = "regulator-fixed";
162		regulator-name = "vcc-otg";
163		regulator-min-microvolt = <5000000>;
164		regulator-max-microvolt = <5000000>;
165		enable-active-high;
166		gpio = <&gpio3 RK_PB1 GPIO_ACTIVE_HIGH>;
167		pinctrl-names = "default";
168		pinctrl-0 = <&otg_drv>;
169		startup-delay-us = <100000>;
170		vin-supply = <&vcc_5v>;
171	};
172
173	vcc_sd: sdmmc-regulator {
174		compatible = "regulator-fixed";
175		regulator-name = "vcc-sd";
176		regulator-min-microvolt = <3300000>;
177		regulator-max-microvolt = <3300000>;
178		gpio = <&gpio3 RK_PA1 GPIO_ACTIVE_LOW>;
179		pinctrl-names = "default";
180		pinctrl-0 = <&sdmmc_pwr>;
181		startup-delay-us = <100000>;
182		vin-supply = <&vcc_io>;
183	};
184
185	vccq_emmc: emmc-vccq-regulator {
186		compatible = "regulator-fixed";
187		regulator-name = "vccq-emmc";
188		regulator-min-microvolt = <2800000>;
189		regulator-max-microvolt = <2800000>;
190		vin-supply = <&vcc_io>;
191	};
192
193	/* supplied from the bq24196 */
194	vsys: vsys-regulator {
195		compatible = "regulator-fixed";
196		regulator-name = "vsys";
197		regulator-min-microvolt = <5000000>;
198		regulator-max-microvolt = <5000000>;
199		regulator-boot-on;
200	};
201};
202
203&cpu0 {
204	cpu-supply = <&vdd_arm>;
205};
206
207&cpu1 {
208	cpu-supply = <&vdd_arm>;
209};
210
211&cpu2 {
212	cpu-supply = <&vdd_arm>;
213};
214
215&cpu3 {
216	cpu-supply = <&vdd_arm>;
217};
218
219&cru {
220	assigned-clocks = <&cru PLL_GPLL>, <&cru PLL_CPLL>,
221			  <&cru ACLK_CPU>,
222			  <&cru HCLK_CPU>, <&cru PCLK_CPU>,
223			  <&cru ACLK_PERI>, <&cru HCLK_PERI>,
224			  <&cru PCLK_PERI>;
225	assigned-clock-rates = <594000000>, <504000000>,
226			       <300000000>,
227			       <150000000>, <75000000>,
228			       <300000000>, <150000000>,
229			       <75000000>;
230};
231
232&emmc {
233	bus-width = <8>;
234	cap-mmc-highspeed;
235	non-removable;
236	pinctrl-names = "default";
237	pinctrl-0 = <&emmc_clk &emmc_cmd>;
238	vmmc-supply = <&vcc_io>;
239	vqmmc-supply = <&vccq_emmc>;
240	status = "okay";
241};
242
243&gpu {
244	status = "okay";
245};
246
247&i2c0 {
248	clock-frequency = <400000>;
249	status = "okay";
250
251	lis3de: accelerometer@29 {
252		compatible = "st,lis3de";
253		reg = <0x29>;
254		interrupt-parent = <&gpio0>;
255		interrupts = <RK_PB7 IRQ_TYPE_EDGE_RISING>;
256		pinctrl-names = "default";
257		pinctrl-0 = <&gsensor_int>;
258		rotation-matrix = "1", "0", "0",
259				  "0", "-1", "0",
260				  "0", "0", "1";
261		vdd-supply = <&vcc_io>;
262	};
263};
264
265&i2c1 {
266	clock-frequency = <400000>;
267	status = "okay";
268
269	tmp108@48 {
270		compatible = "ti,tmp108";
271		reg = <0x48>;
272		interrupt-parent = <&gpio1>;
273		interrupts = <RK_PA7 IRQ_TYPE_LEVEL_LOW>;
274		pinctrl-names = "default";
275		pinctrl-0 = <&tmp_alrt>;
276		#thermal-sensor-cells = <0>;
277	};
278
279	hym8563: rtc@51 {
280		compatible = "haoyu,hym8563";
281		reg = <0x51>;
282		interrupt-parent = <&gpio0>;
283		interrupts = <RK_PB5 IRQ_TYPE_EDGE_FALLING>;
284		pinctrl-names = "default";
285		pinctrl-0 = <&rtc_int>;
286		#clock-cells = <0>;
287		clock-output-names = "xin32k";
288	};
289
290	bat: battery@55 {
291		compatible = "ti,bq27541";
292		reg = <0x55>;
293		power-supplies = <&bq24196>;
294	};
295
296	act8846: pmic@5a {
297		compatible = "active-semi,act8846";
298		reg = <0x5a>;
299		pinctrl-names = "default";
300		pinctrl-0 = <&dvs0_ctl &pmic_int>;
301
302		vp1-supply = <&vsys>;
303		vp2-supply = <&vsys>;
304		vp3-supply = <&vsys>;
305		vp4-supply = <&vsys>;
306		inl1-supply = <&vcc_io>;
307		inl2-supply = <&vsys>;
308		inl3-supply = <&vsys>;
309
310		regulators {
311			vcc_ddr: REG1 {
312				regulator-name = "VCC_DDR";
313				regulator-min-microvolt = <1200000>;
314				regulator-max-microvolt = <1200000>;
315				regulator-always-on;
316			};
317
318			vdd_log: REG2 {
319				regulator-name = "VDD_LOG";
320				regulator-min-microvolt = <1000000>;
321				regulator-max-microvolt = <1200000>;
322				regulator-always-on;
323			};
324
325			vdd_arm: REG3 {
326				regulator-name = "VDD_ARM";
327				regulator-min-microvolt = <875000>;
328				regulator-max-microvolt = <1350000>;
329				regulator-always-on;
330			};
331
332			vcc_io: vcc_hdmi: REG4 {
333				regulator-name = "VCC_IO";
334				regulator-min-microvolt = <3000000>;
335				regulator-max-microvolt = <3000000>;
336				regulator-always-on;
337			};
338
339			vdd_10: REG5 {
340				regulator-name = "VDD_10";
341				regulator-min-microvolt = <1000000>;
342				regulator-max-microvolt = <1000000>;
343				regulator-always-on;
344			};
345
346			vdd_12: REG6 {
347				regulator-name = "VDD_12";
348				regulator-min-microvolt = <1200000>;
349				regulator-max-microvolt = <1200000>;
350				regulator-always-on;
351			};
352
353			vcc18_cif: REG7 {
354				regulator-name = "VCC18_CIF";
355				regulator-min-microvolt = <1800000>;
356				regulator-max-microvolt = <1800000>;
357				regulator-always-on;
358			};
359
360			vcca_33: REG8 {
361				regulator-name = "VCCA_33";
362				regulator-min-microvolt = <3300000>;
363				regulator-max-microvolt = <3300000>;
364				regulator-always-on;
365			};
366
367			vcc_tp: REG9 {
368				regulator-name = "VCC_TP";
369				regulator-min-microvolt = <3300000>;
370				regulator-max-microvolt = <3300000>;
371				regulator-always-on;
372			};
373
374			vccio_wl: REG10 {
375				regulator-name = "VCCIO_WL";
376				regulator-min-microvolt = <2800000>;
377				regulator-max-microvolt = <2800000>;
378				regulator-always-on;
379			};
380
381			vcc_18: REG11 {
382				regulator-name = "VCC_18";
383				regulator-min-microvolt = <1800000>;
384				regulator-max-microvolt = <1800000>;
385				regulator-always-on;
386			};
387
388			vcc28_cif: REG12 {
389				regulator-name = "VCC28_CIF";
390				regulator-min-microvolt = <2800000>;
391				regulator-max-microvolt = <2800000>;
392				regulator-always-on;
393			};
394		};
395	};
396
397	bq24196: charger@6b {
398		compatible = "ti,bq24196";
399		reg = <0x6b>;
400		interrupt-parent = <&gpio0>;
401		interrupts = <RK_PD7 IRQ_TYPE_EDGE_FALLING>;
402		pinctrl-names = "default";
403		pinctrl-0 = <&charger_int &chg_ctl &otg_en>;
404		ti,system-minimum-microvolt = <3200000>;
405		monitored-battery = <&bat>;
406		omit-battery-class;
407
408		usb_otg_vbus: usb-otg-vbus { };
409	};
410};
411
412&i2c2 {
413	clock-frequency = <400000>;
414	status = "okay";
415
416	ft5606: touchscreen@3e {
417		compatible = "edt,edt-ft5506";
418		reg = <0x3e>;
419		interrupt-parent = <&gpio1>;
420		interrupts = <RK_PB7 IRQ_TYPE_EDGE_FALLING>;
421		pinctrl-names = "default";
422		pinctrl-0 = <&tp_int &tp_rst>;
423		reset-gpios = <&gpio0 RK_PB6 GPIO_ACTIVE_LOW>;
424		touchscreen-inverted-y;
425		/* hw ts resolution does not match display */
426		touchscreen-size-y = <1024>;
427		touchscreen-size-x = <768>;
428		touchscreen-swapped-x-y;
429	};
430};
431
432&i2c3 {
433	clock-frequency = <400000>;
434	status = "okay";
435};
436
437&i2c4 {
438	clock-frequency = <400000>;
439	status = "okay";
440
441	rt5616: codec@1b {
442		compatible = "realtek,rt5616";
443		reg = <0x1b>;
444		clocks = <&cru SCLK_I2S0>;
445		clock-names = "mclk";
446		#sound-dai-cells = <0>;
447	};
448};
449
450&i2s0 {
451	status = "okay";
452};
453
454&mmc0 {
455	bus-width = <4>;
456	cap-mmc-highspeed;
457	cap-sd-highspeed;
458	disable-wp;
459	pinctrl-names = "default";
460	pinctrl-0 = <&sd0_clk>, <&sd0_cmd>, <&sd0_cd>, <&sd0_bus4>;
461	vmmc-supply = <&vcc_sd>;
462	status = "okay";
463};
464
465&mmc1 {
466	bus-width = <4>;
467	cap-sd-highspeed;
468	keep-power-in-suspend;
469	mmc-pwrseq = <&sdio_pwrseq>;
470	non-removable;
471	pinctrl-names = "default";
472	pinctrl-0 = <&sd1_clk>, <&sd1_cmd>, <&sd1_bus4>;
473	vqmmc-supply = <&vccio_wl>;
474	#address-cells = <1>;
475	#size-cells = <0>;
476	status = "okay";
477
478	brcmf: wifi@1 {
479		reg = <1>;
480		compatible = "brcm,bcm4329-fmac";
481		interrupt-parent = <&gpio3>;
482		interrupts = <RK_PD2 GPIO_ACTIVE_HIGH>;
483		interrupt-names = "host-wake";
484		brcm,drive-strength = <5>;
485		pinctrl-names = "default";
486		pinctrl-0 = <&wifi_host_wake>;
487	};
488};
489
490&pwm1 {
491	status = "okay";
492};
493
494&pinctrl {
495	pcfg_output_high: pcfg-output-high {
496		output-high;
497	};
498
499	pcfg_output_low: pcfg-output-low {
500		output-low;
501	};
502
503	act8846 {
504		dvs0_ctl: dvs0-ctl {
505			rockchip,pins = <3 RK_PD3 RK_FUNC_GPIO &pcfg_output_low>;
506		};
507
508		pmic_int: pmic-int {
509			rockchip,pins = <0 RK_PB3 RK_FUNC_GPIO &pcfg_pull_up>;
510		};
511	};
512
513	bq24196 {
514		charger_int: charger-int {
515			rockchip,pins = <0 RK_PD7 RK_FUNC_GPIO &pcfg_pull_up>;
516		};
517
518		/* pin hog to make it select usb profile */
519		chg_ctl: chg-ctl {
520			rockchip,pins = <0 RK_PA1 RK_FUNC_GPIO &pcfg_output_high>;
521		};
522
523		/* low: charging, high: complete, fault: blinking */
524		chg_det: chg-det {
525			rockchip,pins = <0 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
526		};
527
528		/* charging enabled when pin low and register set */
529		chg_en: chg-en {
530			rockchip,pins = <0 RK_PC1 RK_FUNC_GPIO &pcfg_output_low>;
531		};
532
533		/* bq29196 powergood (when low) signal */
534		dc_det: dc-det {
535			rockchip,pins = <0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;
536		};
537
538		/* wire bq24196 otg pin to high, to enable 500mA charging */
539		otg_en: otg-en {
540			rockchip,pins = <0 RK_PB1 RK_FUNC_GPIO &pcfg_output_high>;
541		};
542	};
543
544	camera {
545		cif0_pdn: cif0-pdn {
546			rockchip,pins = <3 RK_PB4 RK_FUNC_GPIO &pcfg_pull_none>;
547		};
548
549		cif1_pdn: cif1-pdn {
550			rockchip,pins = <3 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>;
551		};
552
553		cif_avdd_en: cif-avdd-en {
554			rockchip,pins = <1 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
555		};
556	};
557
558	display {
559		lcd_cs: lcd-cs {
560			rockchip,pins = <3 RK_PD6 RK_FUNC_GPIO &pcfg_pull_none>;
561		};
562
563		lcd_en: lcd-en {
564			rockchip,pins = <0 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>;
565		};
566	};
567
568	ft5606 {
569		tp_int: tp-int {
570			rockchip,pins = <1 RK_PB7 RK_FUNC_GPIO &pcfg_pull_up>;
571		};
572
573		tp_rst: tp-rst {
574			rockchip,pins = <0 RK_PB6 RK_FUNC_GPIO &pcfg_pull_none>;
575		};
576	};
577
578	hdmi {
579		hdmi_int: hdmi-int {
580			rockchip,pins = <2 RK_PD6 RK_FUNC_GPIO &pcfg_pull_up>;
581		};
582
583		hdmi_rst: hdmi-rst {
584			rockchip,pins = <3 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;
585		};
586	};
587
588	hym8563 {
589		rtc_int: rtc-int {
590			rockchip,pins = <0 RK_PB5 RK_FUNC_GPIO &pcfg_pull_up>;
591		};
592	};
593
594	keys {
595		pwr_hold: pwr-hold {
596			rockchip,pins = <0 RK_PA0 RK_FUNC_GPIO &pcfg_pull_up>;
597		};
598
599		pwr_key: pwr-key {
600			rockchip,pins = <0 RK_PA4 RK_FUNC_GPIO &pcfg_pull_up>;
601		};
602	};
603
604	lis3de {
605		gsensor_int: gsensor-int {
606			rockchip,pins = <0 RK_PB7 RK_FUNC_GPIO &pcfg_pull_none>;
607		};
608	};
609
610	mmc {
611		sdmmc_pwr: sdmmc-pwr {
612			rockchip,pins = <3 RK_PA1 RK_FUNC_GPIO &pcfg_pull_none>;
613		};
614	};
615
616	tmp108 {
617		tmp_alrt: tmp-alrt {
618			rockchip,pins = <1 RK_PA7 RK_FUNC_GPIO &pcfg_pull_none>;
619		};
620	};
621
622	usb {
623		v5_drv: v5-drv {
624			rockchip,pins = <0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;
625		};
626
627		otg_drv: otg-drv {
628			rockchip,pins = <3 RK_PB1 RK_FUNC_GPIO &pcfg_pull_none>;
629		};
630
631		usb_int: usb-int {
632			rockchip,pins = <0 RK_PA7 RK_FUNC_GPIO &pcfg_pull_up>;
633		};
634	};
635
636	rk903 {
637		bt_host_wake: bt-host-wake {
638			rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>;
639		};
640
641		bt_reg_on: bt-reg-on {
642			rockchip,pins = <3 RK_PC7 RK_FUNC_GPIO &pcfg_pull_none>;
643		};
644
645		/* pin hog to pull the reset high */
646		bt_rst: bt-rst {
647			rockchip,pins = <3 RK_PD1 RK_FUNC_GPIO &pcfg_output_high>;
648		};
649
650		bt_wake: bt-wake {
651			rockchip,pins = <3 RK_PC6 RK_FUNC_GPIO &pcfg_pull_none>;
652		};
653
654		wifi_host_wake: wifi-host-wake {
655			rockchip,pins = <3 RK_PD2 RK_FUNC_GPIO &pcfg_pull_up>;
656		};
657
658		wifi_reg_on: wifi-reg-on {
659			rockchip,pins = <3 RK_PD0 RK_FUNC_GPIO &pcfg_pull_none>;
660		};
661	};
662};
663
664&saradc {
665	vref-supply = <&vcc_18>;
666	status = "okay";
667};
668
669&spdif {
670	status = "okay";
671};
672
673&uart0 {
674	pinctrl-0 = <&uart0_xfer &uart0_cts &uart0_rts>;
675	status = "okay";
676
677	bluetooth {
678		compatible = "brcm,bcm43438-bt";
679		max-speed = <2000000>;
680		device-wakeup-gpios = <&gpio3 RK_PC6 GPIO_ACTIVE_HIGH>;
681		host-wakeup-gpios = <&gpio0 RK_PA5 GPIO_ACTIVE_HIGH>;
682		shutdown-gpios = <&gpio3 RK_PC7 GPIO_ACTIVE_HIGH>;
683		pinctrl-names = "default";
684		pinctrl-0 = <&bt_host_wake &bt_reg_on &bt_rst &bt_wake>;
685	};
686};
687
688&uart1 {
689	status = "okay";
690};
691
692&uart2 {
693	status = "okay";
694};
695
696&uart3 {
697	pinctrl-0 = <&uart3_xfer &uart3_cts &uart3_rts>;
698	status = "okay";
699};
700
701&usbphy {
702	status = "okay";
703};
704
705&usb_host {
706	status = "okay";
707};
708
709&usb_otg {
710	status = "okay";
711};
712
713&vop0 {
714	status = "okay";
715};
716
717&vop0_out {
718	vop0_out_lvds: endpoint {
719		remote-endpoint = <&lvds_in_vop0>;
720	};
721};
722
723&vop1 {
724	pinctrl-names = "default";
725	pinctrl-0 = <&lcdc1_dclk &lcdc1_den &lcdc1_hsync
726		     &lcdc1_vsync &lcdc1_rgb24>;
727	status = "okay";
728};
729
730&wdt {
731	status = "okay";
732};