1// SPDX-License-Identifier: BSD-3-Clause
2/*
3 * Copyright (c) 2020, Linaro Ltd.
4 */
5
6/dts-v1/;
7
8#include <dt-bindings/leds/common.h>
9#include <dt-bindings/regulator/qcom,rpmh-regulator.h>
10#include <dt-bindings/sound/qcom,q6afe.h>
11#include <dt-bindings/sound/qcom,q6asm.h>
12#include "sm8250.dtsi"
13#include "pm8150.dtsi"
14#include "pm8150b.dtsi"
15#include "pm8150l.dtsi"
16
17/ {
18	model = "Qualcomm Technologies, Inc. Robotics RB5";
19	compatible = "qcom,qrb5165-rb5", "qcom,sm8250";
20	qcom,msm-id = <455 0x20001>;
21	qcom,board-id = <11 3>;
22
23	aliases {
24		serial0 = &uart12;
25		sdhc2 = &sdhc_2;
26	};
27
28	chosen {
29		stdout-path = "serial0:115200n8";
30	};
31
32	/* Fixed crystal oscillator dedicated to MCP2518FD */
33	clk40M: can-clock {
34		compatible = "fixed-clock";
35		#clock-cells = <0>;
36		clock-frequency = <40000000>;
37	};
38
39	dc12v: dc12v-regulator {
40		compatible = "regulator-fixed";
41		regulator-name = "DC12V";
42		regulator-min-microvolt = <12000000>;
43		regulator-max-microvolt = <12000000>;
44		regulator-always-on;
45	};
46
47	hdmi-out {
48		compatible = "hdmi-connector";
49		type = "a";
50
51		port {
52			hdmi_con: endpoint {
53				remote-endpoint = <&lt9611_out>;
54			};
55		};
56	};
57
58	leds {
59		compatible = "gpio-leds";
60
61		led-user4 {
62			label = "green:user4";
63			function = LED_FUNCTION_INDICATOR;
64			color = <LED_COLOR_ID_GREEN>;
65			gpios = <&pm8150_gpios 10 GPIO_ACTIVE_HIGH>;
66			linux,default-trigger = "panic-indicator";
67			default-state = "off";
68		};
69
70		led-wlan {
71			label = "yellow:wlan";
72			function = LED_FUNCTION_WLAN;
73			color = <LED_COLOR_ID_YELLOW>;
74			gpios = <&pm8150_gpios 9 GPIO_ACTIVE_HIGH>;
75			linux,default-trigger = "phy0tx";
76			default-state = "off";
77		};
78
79		led-bt {
80			label = "blue:bt";
81			function = LED_FUNCTION_BLUETOOTH;
82			color = <LED_COLOR_ID_BLUE>;
83			gpios = <&pm8150_gpios 7 GPIO_ACTIVE_HIGH>;
84			linux,default-trigger = "bluetooth-power";
85			default-state = "off";
86		};
87	};
88
89	lt9611_1v2: lt9611-vdd12-regulator {
90		compatible = "regulator-fixed";
91		regulator-name = "LT9611_1V2";
92
93		vin-supply = <&vdc_3v3>;
94		regulator-min-microvolt = <1200000>;
95		regulator-max-microvolt = <1200000>;
96	};
97
98	lt9611_3v3: lt9611-3v3 {
99		compatible = "regulator-fixed";
100		regulator-name = "LT9611_3V3";
101
102		vin-supply = <&vdc_3v3>;
103		regulator-min-microvolt = <3300000>;
104		regulator-max-microvolt = <3300000>;
105		regulator-boot-on;
106		regulator-always-on;
107	};
108
109	thermal-zones {
110		conn-thermal {
111			polling-delay-passive = <0>;
112			polling-delay = <0>;
113			thermal-sensors = <&pm8150b_adc_tm 0>;
114
115			trips {
116				active-config0 {
117					temperature = <125000>;
118					hysteresis = <1000>;
119					type = "critical";
120				};
121			};
122		};
123
124		pm8150l-pcb-thermal {
125			polling-delay-passive = <0>;
126			polling-delay = <0>;
127			thermal-sensors = <&pm8150l_adc_tm 1>;
128
129			trips {
130				active-config0 {
131					temperature = <50000>;
132					hysteresis = <4000>;
133					type = "passive";
134				};
135			};
136		};
137
138		skin-msm-thermal {
139			polling-delay-passive = <0>;
140			polling-delay = <0>;
141			thermal-sensors = <&pm8150l_adc_tm 0>;
142
143			trips {
144				active-config0 {
145					temperature = <50000>;
146					hysteresis = <4000>;
147					type = "passive";
148				};
149			};
150		};
151
152		wifi-thermal {
153			polling-delay-passive = <0>;
154			polling-delay = <0>;
155			thermal-sensors = <&pm8150_adc_tm 1>;
156
157			trips {
158				active-config0 {
159					temperature = <52000>;
160					hysteresis = <4000>;
161					type = "passive";
162				};
163			};
164		};
165
166		xo-thermal {
167			polling-delay-passive = <0>;
168			polling-delay = <0>;
169			thermal-sensors = <&pm8150_adc_tm 0>;
170
171			trips {
172				active-config0 {
173					temperature = <50000>;
174					hysteresis = <4000>;
175					type = "passive";
176				};
177			};
178		};
179	};
180
181	vbat: vbat-regulator {
182		compatible = "regulator-fixed";
183		regulator-name = "VBAT";
184		vin-supply = <&vreg_l11c_3p3>;
185		regulator-min-microvolt = <4200000>;
186		regulator-max-microvolt = <4200000>;
187		regulator-always-on;
188	};
189
190	vbat_som: vbat-som-regulator {
191		compatible = "regulator-fixed";
192		regulator-name = "VBAT_SOM";
193		vin-supply = <&dc12v>;
194		regulator-min-microvolt = <4200000>;
195		regulator-max-microvolt = <4200000>;
196		regulator-always-on;
197	};
198
199	vdc_3v3: vdc-3v3-regulator {
200		compatible = "regulator-fixed";
201		regulator-name = "VDC_3V3";
202		vin-supply = <&vreg_l11c_3p3>;
203		regulator-min-microvolt = <3300000>;
204		regulator-max-microvolt = <3300000>;
205		regulator-always-on;
206	};
207
208	vdc_5v: vdc-5v-regulator {
209		compatible = "regulator-fixed";
210		regulator-name = "VDC_5V";
211
212		regulator-min-microvolt = <5000000>;
213		regulator-max-microvolt = <5000000>;
214		regulator-always-on;
215		vin-supply = <&vreg_l11c_3p3>;
216	};
217
218	vph_pwr: vph-pwr-regulator {
219		compatible = "regulator-fixed";
220		regulator-name = "vph_pwr";
221		regulator-min-microvolt = <3700000>;
222		regulator-max-microvolt = <3700000>;
223		regulator-always-on;
224	};
225
226	vreg_s4a_1p8: vreg-s4a-1p8 {
227		compatible = "regulator-fixed";
228		regulator-name = "vreg_s4a_1p8";
229		regulator-min-microvolt = <1800000>;
230		regulator-max-microvolt = <1800000>;
231		regulator-always-on;
232	};
233};
234
235&adsp {
236	status = "okay";
237	firmware-name = "qcom/sm8250/adsp.mbn";
238};
239
240&apps_rsc {
241	regulators-0 {
242		compatible = "qcom,pm8009-1-rpmh-regulators";
243		qcom,pmic-id = "f";
244
245		vdd-s1-supply = <&vph_pwr>;
246		vdd-s2-supply = <&vph_pwr>;
247		vdd-l2-supply = <&vreg_s8c_1p3>;
248		vdd-l5-l6-supply = <&vreg_bob>;
249		vdd-l7-supply = <&vreg_s4a_1p8>;
250
251		vreg_s2f_0p95: smps2 {
252			regulator-name = "vreg_s2f_0p95";
253			regulator-min-microvolt = <900000>;
254			regulator-max-microvolt = <952000>;
255			regulator-initial-mode = <RPMH_REGULATOR_MODE_AUTO>;
256		};
257
258		vreg_l1f_1p1: ldo1 {
259			regulator-name = "vreg_l1f_1p1";
260			regulator-min-microvolt = <1104000>;
261			regulator-max-microvolt = <1104000>;
262			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
263		};
264
265		vreg_l2f_1p2: ldo2 {
266			regulator-name = "vreg_l2f_1p2";
267			regulator-min-microvolt = <1200000>;
268			regulator-max-microvolt = <1200000>;
269			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
270		};
271
272		vreg_l6f_2p8: ldo6 {
273			regulator-name = "vreg_l6f_2p8";
274			regulator-min-microvolt = <2800000>;
275			regulator-max-microvolt = <2800000>;
276			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
277		};
278
279		vreg_l7f_1p8: ldo7 {
280			regulator-name = "vreg_l7f_1p8";
281			regulator-min-microvolt = <1800000>;
282			regulator-max-microvolt = <1800000>;
283			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
284		};
285	};
286
287	regulators-1 {
288		compatible = "qcom,pm8150-rpmh-regulators";
289		qcom,pmic-id = "a";
290
291		vdd-s1-supply = <&vph_pwr>;
292		vdd-s2-supply = <&vph_pwr>;
293		vdd-s3-supply = <&vph_pwr>;
294		vdd-s4-supply = <&vph_pwr>;
295		vdd-s5-supply = <&vph_pwr>;
296		vdd-s6-supply = <&vph_pwr>;
297		vdd-s7-supply = <&vph_pwr>;
298		vdd-s8-supply = <&vph_pwr>;
299		vdd-s9-supply = <&vph_pwr>;
300		vdd-s10-supply = <&vph_pwr>;
301		vdd-l2-l10-supply = <&vreg_bob>;
302		vdd-l3-l4-l5-l18-supply = <&vreg_s6a_0p95>;
303		vdd-l6-l9-supply = <&vreg_s8c_1p3>;
304		vdd-l7-l12-l14-l15-supply = <&vreg_s5a_1p9>;
305		vdd-l13-l16-l17-supply = <&vreg_bob>;
306
307		vreg_l2a_3p1: ldo2 {
308			regulator-name = "vreg_l2a_3p1";
309			regulator-min-microvolt = <3072000>;
310			regulator-max-microvolt = <3072000>;
311			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
312		};
313
314		vreg_l3a_0p9: ldo3 {
315			regulator-name = "vreg_l3a_0p9";
316			regulator-min-microvolt = <928000>;
317			regulator-max-microvolt = <932000>;
318			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
319		};
320
321		vreg_l5a_0p88: ldo5 {
322			regulator-name = "vreg_l5a_0p88";
323			regulator-min-microvolt = <880000>;
324			regulator-max-microvolt = <880000>;
325			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
326		};
327
328		vreg_l6a_1p2: ldo6 {
329			regulator-name = "vreg_l6a_1p2";
330			regulator-min-microvolt = <1200000>;
331			regulator-max-microvolt = <1200000>;
332			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
333		};
334
335		vreg_l7a_1p7: ldo7 {
336			regulator-name = "vreg_l7a_1p7";
337			regulator-min-microvolt = <1704000>;
338			regulator-max-microvolt = <1800000>;
339			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
340		};
341
342		vreg_l9a_1p2: ldo9 {
343			regulator-name = "vreg_l9a_1p2";
344			regulator-min-microvolt = <1200000>;
345			regulator-max-microvolt = <1200000>;
346			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
347		};
348
349		vreg_l10a_1p8: ldo10 {
350			regulator-name = "vreg_l10a_1p8";
351			regulator-min-microvolt = <1800000>;
352			regulator-max-microvolt = <1800000>;
353			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
354		};
355
356		vreg_l12a_1p8: ldo12 {
357			regulator-name = "vreg_l12a_1p8";
358			regulator-min-microvolt = <1800000>;
359			regulator-max-microvolt = <1800000>;
360			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
361		};
362
363		vreg_l13a_ts_3p0: ldo13 {
364			regulator-name = "vreg_l13a_ts_3p0";
365			regulator-min-microvolt = <3008000>;
366			regulator-max-microvolt = <3008000>;
367			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
368		};
369
370		vreg_l14a_1p8: ldo14 {
371			regulator-name = "vreg_l14a_1p8";
372			regulator-min-microvolt = <1800000>;
373			regulator-max-microvolt = <1880000>;
374			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
375		};
376
377		vreg_l15a_1p8: ldo15 {
378			regulator-name = "vreg_l15a_1p8";
379			regulator-min-microvolt = <1800000>;
380			regulator-max-microvolt = <1800000>;
381			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
382		};
383
384		vreg_l16a_2p7: ldo16 {
385			regulator-name = "vreg_l16a_2p7";
386			regulator-min-microvolt = <2704000>;
387			regulator-max-microvolt = <2960000>;
388			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
389		};
390
391		vreg_l17a_3p0: ldo17 {
392			regulator-name = "vreg_l17a_3p0";
393			regulator-min-microvolt = <2856000>;
394			regulator-max-microvolt = <3008000>;
395			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
396		};
397
398		vreg_l18a_0p92: ldo18 {
399			regulator-name = "vreg_l18a_0p92";
400			regulator-min-microvolt = <800000>;
401			regulator-max-microvolt = <912000>;
402			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
403		};
404
405		vreg_s5a_1p9: smps5 {
406			regulator-name = "vreg_s5a_1p9";
407			regulator-min-microvolt = <1904000>;
408			regulator-max-microvolt = <2000000>;
409			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
410		};
411
412		vreg_s6a_0p95: smps6 {
413			regulator-name = "vreg_s6a_0p95";
414			regulator-min-microvolt = <920000>;
415			regulator-max-microvolt = <1128000>;
416			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
417		};
418	};
419
420	regulators-2 {
421		compatible = "qcom,pm8150l-rpmh-regulators";
422		qcom,pmic-id = "c";
423
424		vdd-s1-supply = <&vph_pwr>;
425		vdd-s2-supply = <&vph_pwr>;
426		vdd-s3-supply = <&vph_pwr>;
427		vdd-s4-supply = <&vph_pwr>;
428		vdd-s5-supply = <&vph_pwr>;
429		vdd-s6-supply = <&vph_pwr>;
430		vdd-s7-supply = <&vph_pwr>;
431		vdd-s8-supply = <&vph_pwr>;
432		vdd-l1-l8-supply = <&vreg_s4a_1p8>;
433		vdd-l2-l3-supply = <&vreg_s8c_1p3>;
434		vdd-l4-l5-l6-supply = <&vreg_bob>;
435		vdd-l7-l11-supply = <&vreg_bob>;
436		vdd-l9-l10-supply = <&vreg_bob>;
437		vdd-bob-supply = <&vph_pwr>;
438
439		vreg_bob: bob {
440			regulator-name = "vreg_bob";
441			regulator-min-microvolt = <3008000>;
442			regulator-max-microvolt = <4000000>;
443			regulator-initial-mode = <RPMH_REGULATOR_MODE_AUTO>;
444		};
445
446		vreg_l1c_1p8: ldo1 {
447			regulator-name = "vreg_l1c_1p8";
448			regulator-min-microvolt = <1800000>;
449			regulator-max-microvolt = <1800000>;
450			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
451		};
452
453		vreg_l2c_1p2: ldo2 {
454			regulator-name = "vreg_l2c_1p2";
455			regulator-min-microvolt = <1200000>;
456			regulator-max-microvolt = <1200000>;
457			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
458		};
459
460		vreg_l3c_0p8: ldo3 {
461			regulator-name = "vreg_l3c_0p8";
462			regulator-min-microvolt = <800000>;
463			regulator-max-microvolt = <800000>;
464			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
465		};
466
467		vreg_l4c_1p7: ldo4 {
468			regulator-name = "vreg_l4c_1p7";
469			regulator-min-microvolt = <1704000>;
470			regulator-max-microvolt = <2928000>;
471			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
472		};
473
474		vreg_l5c_1p8: ldo5 {
475			regulator-name = "vreg_l5c_1p8";
476			regulator-min-microvolt = <1800000>;
477			regulator-max-microvolt = <2928000>;
478			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
479		};
480
481		vreg_l6c_2p96: ldo6 {
482			regulator-name = "vreg_l6c_2p96";
483			regulator-min-microvolt = <1800000>;
484			regulator-max-microvolt = <2960000>;
485			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
486		};
487
488		vreg_l7c_cam_vcm0_2p85: ldo7 {
489			regulator-name = "vreg_l7c_cam_vcm0_2p85";
490			regulator-min-microvolt = <2856000>;
491			regulator-max-microvolt = <3104000>;
492			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
493		};
494
495		vreg_l8c_1p8: ldo8 {
496			regulator-name = "vreg_l8c_1p8";
497			regulator-min-microvolt = <1800000>;
498			regulator-max-microvolt = <1800000>;
499			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
500		};
501
502		vreg_l9c_2p96: ldo9 {
503			regulator-name = "vreg_l9c_2p96";
504			regulator-min-microvolt = <2704000>;
505			regulator-max-microvolt = <2960000>;
506			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
507		};
508
509		vreg_l10c_3p0: ldo10 {
510			regulator-name = "vreg_l10c_3p0";
511			regulator-min-microvolt = <3000000>;
512			regulator-max-microvolt = <3000000>;
513			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
514		};
515
516		vreg_l11c_3p3: ldo11 {
517			regulator-name = "vreg_l11c_3p3";
518			regulator-min-microvolt = <3296000>;
519			regulator-max-microvolt = <3296000>;
520			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
521			regulator-always-on;
522		};
523
524		vreg_s8c_1p3: smps8 {
525			regulator-name = "vreg_s8c_1p3";
526			regulator-min-microvolt = <1352000>;
527			regulator-max-microvolt = <1352000>;
528			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
529		};
530	};
531};
532
533&cdsp {
534	status = "okay";
535	firmware-name = "qcom/sm8250/cdsp.mbn";
536};
537
538&gmu {
539	status = "okay";
540};
541
542&gpu {
543	status = "okay";
544
545	zap-shader {
546		memory-region = <&gpu_mem>;
547		firmware-name = "qcom/sm8250/a650_zap.mbn";
548	};
549};
550
551/* LS-I2C0 */
552&i2c4 {
553	status = "okay";
554};
555
556&i2c5 {
557	status = "okay";
558	clock-frequency = <400000>;
559
560	lt9611_codec: hdmi-bridge@2b {
561		compatible = "lontium,lt9611uxc";
562		reg = <0x2b>;
563		#sound-dai-cells = <1>;
564
565		interrupts-extended = <&tlmm 63 IRQ_TYPE_EDGE_FALLING>;
566
567		reset-gpios = <&pm8150l_gpios 5 GPIO_ACTIVE_HIGH>;
568
569		vdd-supply = <&lt9611_1v2>;
570		vcc-supply = <&lt9611_3v3>;
571
572		pinctrl-names = "default";
573		pinctrl-0 = <&lt9611_irq_pin &lt9611_rst_pin>;
574
575		ports {
576			#address-cells = <1>;
577			#size-cells = <0>;
578
579			port@0 {
580				reg = <0>;
581
582				lt9611_a: endpoint {
583					remote-endpoint = <&mdss_dsi0_out>;
584				};
585			};
586
587#if 0
588			port@1 {
589				reg = <1>;
590
591				lt9611_b: endpoint {
592					remote-endpoint = <&mdss_dsi1_out>;
593				};
594			};
595#endif
596
597			port@2 {
598				reg = <2>;
599
600				lt9611_out: endpoint {
601					remote-endpoint = <&hdmi_con>;
602				};
603			};
604
605		};
606	};
607};
608
609/* LS-I2C1 */
610&i2c15 {
611	status = "okay";
612};
613
614&mdss {
615	status = "okay";
616};
617
618&mdss_dsi0 {
619	status = "okay";
620	vdda-supply = <&vreg_l9a_1p2>;
621
622#if 0
623	qcom,dual-dsi-mode;
624	qcom,master-dsi;
625#endif
626
627	ports {
628		port@1 {
629			endpoint {
630				remote-endpoint = <&lt9611_a>;
631				data-lanes = <0 1 2 3>;
632			};
633		};
634	};
635};
636
637&mdss_dsi0_phy {
638	status = "okay";
639	vdds-supply = <&vreg_l5a_0p88>;
640};
641
642&pm8150_adc {
643	channel@4c {
644		reg = <ADC5_XO_THERM_100K_PU>;
645		qcom,ratiometric;
646		qcom,hw-settle-time = <200>;
647		label = "xo_therm";
648	};
649
650	channel@4e {
651		reg = <ADC5_AMUX_THM2_100K_PU>;
652		qcom,ratiometric;
653		qcom,hw-settle-time = <200>;
654		label = "wifi_therm";
655	};
656};
657
658&pm8150_adc_tm {
659	status = "okay";
660
661	xo-therm@0 {
662		reg = <0>;
663		io-channels = <&pm8150_adc ADC5_XO_THERM_100K_PU>;
664		qcom,ratiometric;
665		qcom,hw-settle-time-us = <200>;
666	};
667
668	wifi-therm@1 {
669		reg = <1>;
670		io-channels = <&pm8150_adc ADC5_AMUX_THM2_100K_PU>;
671		qcom,ratiometric;
672		qcom,hw-settle-time-us = <200>;
673	};
674};
675
676&pcie0 {
677	status = "okay";
678};
679
680&pcie0_phy {
681	status = "okay";
682	vdda-phy-supply = <&vreg_l5a_0p88>;
683	vdda-pll-supply = <&vreg_l9a_1p2>;
684};
685
686&pcie1 {
687	status = "okay";
688};
689
690&pcie1_phy {
691	status = "okay";
692	vdda-phy-supply = <&vreg_l5a_0p88>;
693	vdda-pll-supply = <&vreg_l9a_1p2>;
694};
695
696&pcie2 {
697	status = "okay";
698};
699
700&pcie2_phy {
701	status = "okay";
702	vdda-phy-supply = <&vreg_l5a_0p88>;
703	vdda-pll-supply = <&vreg_l9a_1p2>;
704};
705
706&pm8150_gpios {
707	gpio-reserved-ranges = <1 1>, <3 2>, <7 1>;
708	gpio-line-names =
709		"NC",
710		"OPTION2",
711		"PM_GPIO-F",
712		"PM_SLP_CLK_IN",
713		"OPTION1",
714		"VOL_UP_N",
715		"PM8250_GPIO7", /* Blue LED */
716		"SP_ARI_PWR_ALARM",
717		"GPIO_9_P", /* Yellow LED */
718		"GPIO_10_P"; /* Green LED */
719};
720
721&pm8150b_adc {
722	channel@4f {
723		reg = <ADC5_AMUX_THM3_100K_PU>;
724		qcom,ratiometric;
725		qcom,hw-settle-time = <200>;
726		label = "conn_therm";
727	};
728};
729
730&pm8150b_adc_tm {
731	status = "okay";
732
733	conn-therm@0 {
734		reg = <0>;
735		io-channels = <&pm8150b_adc ADC5_AMUX_THM3_100K_PU>;
736		qcom,ratiometric;
737		qcom,hw-settle-time-us = <200>;
738	};
739};
740
741&pm8150b_gpios {
742	gpio-line-names =
743		"NC",
744		"NC",
745		"NC",
746		"NC",
747		"HAP_BOOST_EN", /* SOM */
748		"SMB_STAT", /* SOM */
749		"NC",
750		"NC",
751		"SDM_FORCE_USB_BOOT",
752		"NC",
753		"NC",
754		"NC";
755};
756
757&pm8150l_adc {
758	channel@4e {
759		reg = <ADC5_AMUX_THM2_100K_PU>;
760		qcom,ratiometric;
761		qcom,hw-settle-time = <200>;
762		label = "skin_msm_therm";
763	};
764
765	channel@4f {
766		reg = <ADC5_AMUX_THM3_100K_PU>;
767		qcom,ratiometric;
768		qcom,hw-settle-time = <200>;
769		label = "pm8150l_therm";
770	};
771};
772
773&pm8150l_adc_tm {
774	status = "okay";
775
776	skin-msm-therm@0 {
777		reg = <0>;
778		io-channels = <&pm8150l_adc ADC5_AMUX_THM2_100K_PU>;
779		qcom,ratiometric;
780		qcom,hw-settle-time-us = <200>;
781	};
782
783	pm8150l-therm@1 {
784		reg = <1>;
785		io-channels = <&pm8150l_adc ADC5_AMUX_THM3_100K_PU>;
786		qcom,ratiometric;
787		qcom,hw-settle-time-us = <200>;
788	};
789};
790
791&pm8150l_gpios {
792	gpio-line-names =
793		"NC",
794		"PM3003A_EN",
795		"NC",
796		"NC",
797		"PM_GPIO5", /* HDMI RST_N */
798		"PM_GPIO-A", /* PWM */
799		"PM_GPIO7",
800		"NC",
801		"NC",
802		"PM_GPIO-B",
803		"NC",
804		"PM3003A_MODE";
805
806	lt9611_rst_pin: lt9611-rst-state {
807		pins = "gpio5";
808		function = "normal";
809
810		output-high;
811		input-disable;
812		power-source = <0>;
813	};
814};
815
816&pm8150l_lpg {
817	status = "okay";
818
819	#address-cells = <1>;
820	#size-cells = <0>;
821
822	led@1 {
823		reg = <1>;
824		color = <LED_COLOR_ID_GREEN>;
825		function = LED_FUNCTION_HEARTBEAT;
826		function-enumerator = <3>;
827
828		linux,default-trigger = "heartbeat";
829		default-state = "on";
830	};
831
832	led@2 {
833		reg = <2>;
834		color = <LED_COLOR_ID_GREEN>;
835		function = LED_FUNCTION_INDICATOR;
836		function-enumerator = <2>;
837		default-state = "on";
838	};
839
840	led@3 {
841		reg = <3>;
842		color = <LED_COLOR_ID_GREEN>;
843		function = LED_FUNCTION_INDICATOR;
844		function-enumerator = <1>;
845	};
846};
847
848&pon_pwrkey {
849	status = "okay";
850};
851
852&pon_resin {
853	status = "okay";
854
855	linux,code = <KEY_VOLUMEDOWN>;
856};
857
858&qupv3_id_0 {
859	status = "okay";
860};
861
862&qupv3_id_1 {
863	status = "okay";
864};
865
866&qupv3_id_2 {
867	status = "okay";
868};
869
870&q6afedai {
871	dai@16 {
872		reg = <PRIMARY_MI2S_RX>;
873		qcom,sd-lines = <0 1 2 3>;
874	};
875};
876
877/* TERT I2S Uses 1 I2S SD Lines for audio on LT9611 HDMI Bridge */
878&q6afedai {
879	dai@20 {
880		reg = <TERTIARY_MI2S_RX>;
881		qcom,sd-lines = <0>;
882	};
883};
884
885&q6asmdai {
886	dai@0 {
887		reg = <0>;
888	};
889
890	dai@1 {
891		reg = <1>;
892	};
893
894	dai@2 {
895		reg = <2>;
896	};
897};
898
899&sdhc_2 {
900	status = "okay";
901	pinctrl-names = "default";
902	pinctrl-0 = <&sdc2_default_state &sdc2_card_det_n>;
903	vmmc-supply = <&vreg_l9c_2p96>;
904	vqmmc-supply = <&vreg_l6c_2p96>;
905	cd-gpios = <&tlmm 77 GPIO_ACTIVE_LOW>;
906	bus-width = <4>;
907	no-sdio;
908	no-mmc;
909};
910
911&sound {
912	compatible = "qcom,qrb5165-rb5-sndcard";
913	pinctrl-0 = <&tert_mi2s_active>;
914	pinctrl-names = "default";
915	model = "Qualcomm-RB5-WSA8815-Speakers-DMIC0";
916	audio-routing =
917		"SpkrLeft IN", "WSA_SPK1 OUT",
918		"SpkrRight IN", "WSA_SPK2 OUT",
919		"VA DMIC0", "vdd-micb",
920		"VA DMIC1", "vdd-micb",
921		"MM_DL1",  "MultiMedia1 Playback",
922		"MM_DL2",  "MultiMedia2 Playback",
923		"MultiMedia3 Capture", "MM_UL3";
924
925	mm1-dai-link {
926		link-name = "MultiMedia1";
927		cpu {
928			sound-dai = <&q6asmdai  MSM_FRONTEND_DAI_MULTIMEDIA1>;
929		};
930	};
931
932	mm2-dai-link {
933		link-name = "MultiMedia2";
934		cpu {
935			sound-dai = <&q6asmdai  MSM_FRONTEND_DAI_MULTIMEDIA2>;
936		};
937	};
938
939	mm3-dai-link {
940		link-name = "MultiMedia3";
941		cpu {
942			sound-dai = <&q6asmdai  MSM_FRONTEND_DAI_MULTIMEDIA3>;
943		};
944	};
945
946	hdmi-dai-link {
947		link-name = "HDMI Playback";
948		cpu {
949			sound-dai = <&q6afedai TERTIARY_MI2S_RX>;
950		};
951
952		platform {
953			sound-dai = <&q6routing>;
954		};
955
956		codec {
957			sound-dai = <&lt9611_codec 0>;
958		};
959	};
960
961	dma-dai-link {
962		link-name = "WSA Playback";
963		cpu {
964			sound-dai = <&q6afedai WSA_CODEC_DMA_RX_0>;
965		};
966
967		platform {
968			sound-dai = <&q6routing>;
969		};
970
971		codec {
972			sound-dai = <&left_spkr>, <&right_spkr>, <&swr0 0>, <&wsamacro 0>;
973		};
974	};
975
976	va-dai-link {
977		link-name = "VA Capture";
978		cpu {
979			sound-dai = <&q6afedai VA_CODEC_DMA_TX_0>;
980		};
981
982		platform {
983			sound-dai = <&q6routing>;
984		};
985
986		codec {
987			sound-dai = <&vamacro 0>;
988		};
989	};
990};
991
992/* CAN */
993&spi0 {
994	status = "okay";
995	pinctrl-names = "default";
996	pinctrl-0 = <&qup_spi0_data_clk>, <&qup_spi0_cs_gpio>;
997	cs-gpios = <&tlmm 31 GPIO_ACTIVE_LOW>;
998
999	can@0 {
1000		compatible = "microchip,mcp2518fd";
1001		reg = <0>;
1002		clocks = <&clk40M>;
1003		interrupts-extended = <&tlmm 15 IRQ_TYPE_LEVEL_LOW>;
1004		spi-max-frequency = <10000000>;
1005		vdd-supply = <&vdc_5v>;
1006		xceiver-supply = <&vdc_5v>;
1007	};
1008};
1009
1010&swr0 {
1011	status = "okay";
1012
1013	left_spkr: speaker@0,3 {
1014		compatible = "sdw10217211000";
1015		reg = <0 3>;
1016		powerdown-gpios = <&tlmm 130 GPIO_ACTIVE_LOW>;
1017		#thermal-sensor-cells = <0>;
1018		sound-name-prefix = "SpkrLeft";
1019		#sound-dai-cells = <0>;
1020	};
1021
1022	right_spkr: speaker@0,4 {
1023		compatible = "sdw10217211000";
1024		reg = <0 4>;
1025		powerdown-gpios = <&tlmm 130 GPIO_ACTIVE_LOW>;
1026		#thermal-sensor-cells = <0>;
1027		sound-name-prefix = "SpkrRight";
1028		#sound-dai-cells = <0>;
1029	};
1030};
1031
1032&tlmm {
1033	gpio-reserved-ranges = <40 4>;
1034	gpio-line-names =
1035		"GPIO-MM",
1036		"GPIO-NN",
1037		"GPIO-OO",
1038		"GPIO-PP",
1039		"GPIO-A",
1040		"GPIO-C",
1041		"GPIO-E",
1042		"GPIO-D",
1043		"I2C0-SDA",
1044		"I2C0-SCL",
1045		"GPIO-TT", /* GPIO_10 */
1046		"NC",
1047		"GPIO_12_I2C_SDA",
1048		"GPIO_13_I2C_SCL",
1049		"GPIO-X",
1050		"GPIO_15_RGMII_INT",
1051		"HST_BT_UART_CTS",
1052		"HST_BT_UART_RFR",
1053		"HST_BT_UART_TX",
1054		"HST_BT_UART_RX",
1055		"HST_WLAN_EN", /* GPIO_20 */
1056		"HST_BT_EN",
1057		"GPIO-AAA",
1058		"GPIO-BBB",
1059		"GPIO-CCC",
1060		"GPIO-Z",
1061		"GPIO-DDD",
1062		"GPIO-BB",
1063		"GPIO_28_CAN_SPI_MISO",
1064		"GPIO_29_CAN_SPI_MOSI",
1065		"GPIO_30_CAN_SPI_CLK", /* GPIO_30 */
1066		"GPIO_31_CAN_SPI_CS",
1067		"GPIO-UU",
1068		"NC",
1069		"UART1_TXD_SOM",
1070		"UART1_RXD_SOM",
1071		"UART0_CTS",
1072		"UART0_RTS",
1073		"UART0_TXD",
1074		"UART0_RXD",
1075		"SPI1_MISO", /* GPIO_40 */
1076		"SPI1_MOSI",
1077		"SPI1_CLK",
1078		"SPI1_CS",
1079		"I2C1_SDA",
1080		"I2C1_SCL",
1081		"GPIO-F",
1082		"GPIO-JJ",
1083		"Board_ID1",
1084		"Board_ID2",
1085		"NC", /* GPIO_50 */
1086		"NC",
1087		"SPI0_MISO",
1088		"SPI0_MOSI",
1089		"SPI0_SCLK",
1090		"SPI0_CS",
1091		"GPIO-QQ",
1092		"GPIO-RR",
1093		"USB2LAN_RESET",
1094		"USB2LAN_EXTWAKE",
1095		"NC", /* GPIO_60 */
1096		"NC",
1097		"NC",
1098		"LT9611_INT",
1099		"GPIO-AA",
1100		"USB_CC_DIR",
1101		"GPIO-G",
1102		"GPIO-LL",
1103		"USB_DP_HPD_1P8",
1104		"NC",
1105		"NC", /* GPIO_70 */
1106		"SD_CMD",
1107		"SD_DAT3",
1108		"SD_SCLK",
1109		"SD_DAT2",
1110		"SD_DAT1",
1111		"SD_DAT0", /* BOOT_CFG3 */
1112		"SD_UFS_CARD_DET_N",
1113		"GPIO-II",
1114		"PCIE0_RST_N",
1115		"PCIE0_CLK_REQ_N", /* GPIO_80 */
1116		"PCIE0_WAKE_N",
1117		"GPIO-CC",
1118		"GPIO-DD",
1119		"GPIO-EE",
1120		"GPIO-FF",
1121		"GPIO-GG",
1122		"GPIO-HH",
1123		"GPIO-VV",
1124		"GPIO-WW",
1125		"NC", /* GPIO_90 */
1126		"NC",
1127		"GPIO-K",
1128		"GPIO-I",
1129		"CSI0_MCLK",
1130		"CSI1_MCLK",
1131		"CSI2_MCLK",
1132		"CSI3_MCLK",
1133		"GPIO-AA", /* CSI4_MCLK */
1134		"GPIO-BB", /* CSI5_MCLK */
1135		"GPIO-KK", /* GPIO_100 */
1136		"CCI_I2C_SDA0",
1137		"CCI_I2C_SCL0",
1138		"CCI_I2C_SDA1",
1139		"CCI_I2C_SCL1",
1140		"CCI_I2C_SDA2",
1141		"CCI_I2C_SCL2",
1142		"CCI_I2C_SDA3",
1143		"CCI_I2C_SCL3",
1144		"GPIO-L",
1145		"NC", /* GPIO_110 */
1146		"NC",
1147		"ACCEL_INT",
1148		"GYRO_INT",
1149		"GPIO-J",
1150		"GPIO-YY",
1151		"GPIO-H",
1152		"GPIO-ZZ",
1153		"NC",
1154		"NC",
1155		"NC", /* GPIO_120 */
1156		"NC",
1157		"MAG_INT",
1158		"MAG_DRDY_INT",
1159		"HST_SW_CTRL",
1160		"GPIO-M",
1161		"GPIO-N",
1162		"GPIO-O",
1163		"GPIO-P",
1164		"PS_INT",
1165		"WSA1_EN", /* GPIO_130 */
1166		"USB_HUB_RESET",
1167		"SDM_FORCE_USB_BOOT",
1168		"I2S1_CLK_HDMI",
1169		"I2S1_DATA0_HDMI",
1170		"I2S1_WS_HDMI",
1171		"GPIO-B",
1172		"GPIO_137", /* To LT9611_I2S_MCLK_3V3 */
1173		"PCM_CLK",
1174		"PCM_DI",
1175		"PCM_DO", /* GPIO_140 */
1176		"PCM_FS",
1177		"HST_SLIM_CLK",
1178		"HST_SLIM_DATA",
1179		"GPIO-U",
1180		"GPIO-Y",
1181		"GPIO-R",
1182		"GPIO-Q",
1183		"GPIO-S",
1184		"GPIO-T",
1185		"GPIO-V", /* GPIO_150 */
1186		"GPIO-W",
1187		"DMIC_CLK1",
1188		"DMIC_DATA1",
1189		"DMIC_CLK2",
1190		"DMIC_DATA2",
1191		"WSA_SWR_CLK",
1192		"WSA_SWR_DATA",
1193		"DMIC_CLK3",
1194		"DMIC_DATA3",
1195		"I2C4_SDA", /* GPIO_160 */
1196		"I2C4_SCL",
1197		"SPI3_CS1",
1198		"SPI3_CS2",
1199		"SPI2_MISO_LS3",
1200		"SPI2_MOSI_LS3",
1201		"SPI2_CLK_LS3",
1202		"SPI2_ACCEL_CS_LS3",
1203		"SPI2_CS1",
1204		"NC",
1205		"GPIO-SS", /* GPIO_170 */
1206		"GPIO-XX",
1207		"SPI3_MISO",
1208		"SPI3_MOSI",
1209		"SPI3_CLK",
1210		"SPI3_CS",
1211		"HST_BLE_SNS_UART_TX",
1212		"HST_BLE_SNS_UART_RX",
1213		"HST_WLAN_UART_TX",
1214		"HST_WLAN_UART_RX";
1215
1216	lt9611_irq_pin: lt9611-irq-state {
1217		pins = "gpio63";
1218		function = "gpio";
1219		bias-disable;
1220	};
1221
1222	sdc2_default_state: sdc2-default-state {
1223		clk-pins {
1224			pins = "sdc2_clk";
1225			bias-disable;
1226			drive-strength = <16>;
1227		};
1228
1229		cmd-pins {
1230			pins = "sdc2_cmd";
1231			bias-pull-up;
1232			drive-strength = <10>;
1233		};
1234
1235		data-pins {
1236			pins = "sdc2_data";
1237			bias-pull-up;
1238			drive-strength = <10>;
1239		};
1240	};
1241
1242	sdc2_card_det_n: sd-card-det-n-state {
1243		pins = "gpio77";
1244		function = "gpio";
1245		bias-pull-up;
1246	};
1247};
1248
1249&uart12 {
1250	status = "okay";
1251};
1252
1253&ufs_mem_hc {
1254	status = "okay";
1255
1256	vcc-supply = <&vreg_l17a_3p0>;
1257	vcc-max-microamp = <800000>;
1258	vccq-supply = <&vreg_l6a_1p2>;
1259	vccq-max-microamp = <800000>;
1260	vccq2-supply = <&vreg_s4a_1p8>;
1261	vccq2-max-microamp = <800000>;
1262};
1263
1264&ufs_mem_phy {
1265	status = "okay";
1266
1267	vdda-phy-supply = <&vreg_l5a_0p88>;
1268	vdda-pll-supply = <&vreg_l9a_1p2>;
1269};
1270
1271&usb_1 {
1272	status = "okay";
1273};
1274
1275&usb_1_dwc3 {
1276	dr_mode = "peripheral";
1277};
1278
1279&usb_1_hsphy {
1280	status = "okay";
1281
1282	vdda-pll-supply = <&vreg_l5a_0p88>;
1283	vdda33-supply = <&vreg_l2a_3p1>;
1284	vdda18-supply = <&vreg_l12a_1p8>;
1285};
1286
1287&usb_1_qmpphy {
1288	status = "okay";
1289
1290	vdda-phy-supply = <&vreg_l9a_1p2>;
1291	vdda-pll-supply = <&vreg_l18a_0p92>;
1292};
1293
1294&usb_2 {
1295	status = "okay";
1296};
1297
1298&usb_2_dwc3 {
1299	dr_mode = "host";
1300};
1301
1302&usb_2_hsphy {
1303	status = "okay";
1304
1305	vdda-pll-supply = <&vreg_l5a_0p88>;
1306	vdda33-supply = <&vreg_l2a_3p1>;
1307	vdda18-supply = <&vreg_l12a_1p8>;
1308};
1309
1310&usb_2_qmpphy {
1311	status = "okay";
1312
1313	vdda-phy-supply = <&vreg_l9a_1p2>;
1314	vdda-pll-supply = <&vreg_l18a_0p92>;
1315};
1316
1317&vamacro {
1318	pinctrl-0 = <&dmic01_active>;
1319	pinctrl-names = "default";
1320	vdd-micb-supply = <&vreg_s4a_1p8>;
1321	qcom,dmic-sample-rate = <600000>;
1322};
1323
1324&venus {
1325	status = "okay";
1326};
1327
1328&wsamacro {
1329	status = "okay";
1330};
1331
1332/* PINCTRL - additions to nodes defined in sm8250.dtsi */
1333&qup_spi0_cs_gpio {
1334	drive-strength = <6>;
1335	bias-disable;
1336};
1337
1338&qup_spi0_data_clk {
1339	drive-strength = <6>;
1340	bias-disable;
1341};
1342