1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Copyright (c) 2022, Alexander Martinz <amartinz@shiftphones.com>
4 * Copyright (c) 2022, Caleb Connolly <caleb@connolly.tech>
5 * Copyright (c) 2022, Dylan Van Assche <me@dylanvanassche.be>
6 */
7
8/dts-v1/;
9
10#include <dt-bindings/gpio/gpio.h>
11#include <dt-bindings/leds/common.h>
12#include <dt-bindings/regulator/qcom,rpmh-regulator.h>
13#include "sdm845.dtsi"
14#include "pm8998.dtsi"
15#include "pmi8998.dtsi"
16
17/ {
18	model = "SHIFT SHIFT6mq";
19	compatible = "shift,axolotl", "qcom,sdm845";
20	qcom,msm-id = <321 0x20001>;
21	qcom,board-id = <11 0>;
22
23	aliases {
24		display0 = &framebuffer0;
25		serial0 = &uart9;
26		serial1 = &uart6;
27	};
28
29	chosen {
30		#address-cells = <2>;
31		#size-cells = <2>;
32		ranges;
33
34		stdout-path = "serial0";
35
36		/* Use framebuffer setup by the bootloader. */
37		framebuffer0: framebuffer@9d400000 {
38			compatible = "simple-framebuffer";
39			reg = <0x0 0x9d400000 0x0 (1080 * 2160 * 4)>;
40			width = <1080>;
41			height = <2160>;
42			stride = <(1080 * 4)>;
43			format = "a8r8g8b8";
44		};
45	};
46
47	gpio-keys {
48		compatible = "gpio-keys";
49		autorepeat;
50
51		pinctrl-names = "default";
52		pinctrl-0 = <&volume_up_gpio>;
53
54		key-vol-up {
55			label = "volume_up";
56			linux,code = <KEY_VOLUMEUP>;
57			gpios = <&pm8998_gpios 6 GPIO_ACTIVE_LOW>;
58			debounce-interval = <15>;
59		};
60	};
61
62	reserved-memory {
63		framebuffer_region@9d400000 {
64			reg = <0x0 0x9d400000 0x0 (1080 * 2160 * 4)>;
65			no-map;
66		};
67
68		ramoops: ramoops@b0000000 {
69			compatible = "ramoops";
70			reg = <0 0xb0000000 0 0x00400000>;
71			record-size = <0x40000>;
72			console-size = <0x40000>;
73			ftrace-size = <0x40000>;
74			pmsg-size = <0x200000>;
75			ecc-size = <0x0>;
76		};
77	};
78
79	battery: battery {
80		compatible = "simple-battery";
81
82		charge-full-design-microamp-hours = <3850000>;
83		voltage-min-design-microvolt = <3600000>;
84		voltage-max-design-microvolt = <4400000>;
85	};
86
87	vph_pwr: vph-pwr-regulator {
88		compatible = "regulator-fixed";
89		regulator-name = "vph_pwr";
90		regulator-min-microvolt = <3700000>;
91		regulator-max-microvolt = <3700000>;
92	};
93
94	vreg_s4a_1p8: pm8998-smps4 {
95		compatible = "regulator-fixed";
96		regulator-name = "vreg_s4a_1p8";
97
98		regulator-min-microvolt = <1800000>;
99		regulator-max-microvolt = <1800000>;
100
101		regulator-always-on;
102		regulator-boot-on;
103
104		vin-supply = <&vph_pwr>;
105	};
106};
107
108&adsp_pas {
109	status = "okay";
110	firmware-name = "qcom/sdm845/axolotl/adsp.mbn";
111};
112
113&apps_rsc {
114	regulators-0 {
115		compatible = "qcom,pm8998-rpmh-regulators";
116		qcom,pmic-id = "a";
117
118		vdd-s1-supply = <&vph_pwr>;
119		vdd-s2-supply = <&vph_pwr>;
120		vdd-s3-supply = <&vph_pwr>;
121		vdd-s4-supply = <&vph_pwr>;
122		vdd-s5-supply = <&vph_pwr>;
123		vdd-s6-supply = <&vph_pwr>;
124		vdd-s7-supply = <&vph_pwr>;
125		vdd-s8-supply = <&vph_pwr>;
126		vdd-s9-supply = <&vph_pwr>;
127		vdd-s10-supply = <&vph_pwr>;
128		vdd-s11-supply = <&vph_pwr>;
129		vdd-s12-supply = <&vph_pwr>;
130		vdd-s13-supply = <&vph_pwr>;
131		vdd-l1-l27-supply = <&vreg_s7a_1p025>;
132		vdd-l2-l8-l17-supply = <&vreg_s3a_1p35>;
133		vdd-l3-l11-supply = <&vreg_s7a_1p025>;
134		vdd-l4-l5-supply = <&vreg_s7a_1p025>;
135		vdd-l6-supply = <&vph_pwr>;
136		vdd-l7-l12-l14-l15-supply = <&vreg_s5a_2p04>;
137		vdd-l9-supply = <&vreg_bob>;
138		vdd-l10-l23-l25-supply = <&vreg_bob>;
139		vdd-l13-l19-l21-supply = <&vreg_bob>;
140		vdd-l16-l28-supply = <&vreg_bob>;
141		vdd-l18-l22-supply = <&vreg_bob>;
142		vdd-l20-l24-supply = <&vreg_bob>;
143		vdd-l26-supply = <&vreg_s3a_1p35>;
144		vin-lvs-1-2-supply = <&vreg_s4a_1p8>;
145
146		vreg_s2a_1p125: smps2 {
147			regulator-min-microvolt = <1100000>;
148			regulator-max-microvolt = <1100000>;
149		};
150
151		vreg_s3a_1p35: smps3 {
152			regulator-min-microvolt = <1352000>;
153			regulator-max-microvolt = <1352000>;
154		};
155
156		vreg_s5a_2p04: smps5 {
157			regulator-min-microvolt = <1904000>;
158			regulator-max-microvolt = <2040000>;
159		};
160
161		vreg_s7a_1p025: smps7 {
162			regulator-min-microvolt = <900000>;
163			regulator-max-microvolt = <1028000>;
164		};
165
166		vdd_qusb_hs0:
167		vdda_hp_pcie_core:
168		vdda_mipi_csi0_0p9:
169		vdda_mipi_csi1_0p9:
170		vdda_mipi_csi2_0p9:
171		vdda_mipi_dsi0_pll:
172		vdda_mipi_dsi1_pll:
173		vdda_qlink_lv:
174		vdda_qlink_lv_ck:
175		vdda_qrefs_0p875:
176		vdda_pcie_core:
177		vdda_pll_cc_ebi01:
178		vdda_pll_cc_ebi23:
179		vdda_sp_sensor:
180		vdda_ufs1_core:
181		vdda_ufs2_core:
182		vdda_usb1_ss_core:
183		vdda_usb2_ss_core:
184		vreg_l1a_0p875: ldo1 {
185			regulator-min-microvolt = <880000>;
186			regulator-max-microvolt = <880000>;
187			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
188		};
189
190		vddpx_10:
191		vreg_l2a_1p2: ldo2 {
192			regulator-min-microvolt = <1200000>;
193			regulator-max-microvolt = <1200000>;
194			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
195			regulator-always-on;
196		};
197
198		vreg_l3a_1p0: ldo3 {
199			regulator-min-microvolt = <1000000>;
200			regulator-max-microvolt = <1000000>;
201			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
202		};
203
204		vdd_wcss_cx:
205		vdd_wcss_mx:
206		vdda_wcss_pll:
207		vreg_l5a_0p8: ldo5 {
208			regulator-min-microvolt = <800000>;
209			regulator-max-microvolt = <800000>;
210			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
211		};
212
213		vddpx_13:
214		vreg_l6a_1p8: ldo6 {
215			regulator-min-microvolt = <1856000>;
216			regulator-max-microvolt = <1856000>;
217			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
218		};
219
220		vreg_l7a_1p8: ldo7 {
221			regulator-min-microvolt = <1800000>;
222			regulator-max-microvolt = <1800000>;
223			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
224		};
225
226		vreg_l8a_1p2: ldo8 {
227			regulator-min-microvolt = <1200000>;
228			regulator-max-microvolt = <1248000>;
229			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
230		};
231
232		vreg_l9a_1p8: ldo9 {
233			regulator-min-microvolt = <1704000>;
234			regulator-max-microvolt = <2928000>;
235			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
236		};
237
238		vreg_l10a_1p8: ldo10 {
239			regulator-min-microvolt = <1704000>;
240			regulator-max-microvolt = <2928000>;
241			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
242		};
243
244		vreg_l11a_1p0: ldo11 {
245			regulator-min-microvolt = <1000000>;
246			regulator-max-microvolt = <1048000>;
247			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
248		};
249
250		vdd_qfprom:
251		vdd_qfprom_sp:
252		vdda_apc1_cs_1p8:
253		vdda_gfx_cs_1p8:
254		vdda_qrefs_1p8:
255		vdda_qusb_hs0_1p8:
256		vddpx_11:
257		vreg_l12a_1p8: ldo12 {
258			regulator-min-microvolt = <1800000>;
259			regulator-max-microvolt = <1800000>;
260			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
261		};
262
263		vddpx_2:
264		vreg_l13a_2p95: ldo13 {
265			regulator-min-microvolt = <1800000>;
266			regulator-max-microvolt = <2960000>;
267			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
268		};
269
270		vreg_l14a_1p88: ldo14 {
271			regulator-min-microvolt = <1800000>;
272			regulator-max-microvolt = <1800000>;
273			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
274		};
275
276		vreg_l15a_1p8: ldo15 {
277			regulator-min-microvolt = <1800000>;
278			regulator-max-microvolt = <1800000>;
279			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
280		};
281
282		vreg_l16a_2p7: ldo16 {
283			regulator-min-microvolt = <2704000>;
284			regulator-max-microvolt = <2704000>;
285			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
286		};
287
288		vreg_l17a_1p3: ldo17 {
289			regulator-min-microvolt = <1304000>;
290			regulator-max-microvolt = <1304000>;
291			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
292		};
293
294		vreg_l18a_2p7: ldo18 {
295			regulator-min-microvolt = <2704000>;
296			regulator-max-microvolt = <2960000>;
297			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
298		};
299
300		vreg_l19a_3p0: ldo19 {
301			regulator-min-microvolt = <2856000>;
302			regulator-max-microvolt = <3104000>;
303			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
304		};
305
306		vreg_l20a_2p95: ldo20 {
307			regulator-min-microvolt = <2704000>;
308			regulator-max-microvolt = <2960000>;
309			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
310		};
311
312		vreg_l21a_2p95: ldo21 {
313			regulator-min-microvolt = <2704000>;
314			regulator-max-microvolt = <2960000>;
315			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
316		};
317
318		vreg_l22a_2p85: ldo22 {
319			regulator-min-microvolt = <2864000>;
320			regulator-max-microvolt = <3312000>;
321			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
322		};
323
324		vreg_l23a_3p3: ldo23 {
325			regulator-min-microvolt = <3000000>;
326			regulator-max-microvolt = <3312000>;
327			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
328		};
329
330		vdda_qusb_hs0_3p1:
331		vreg_l24a_3p075: ldo24 {
332			regulator-min-microvolt = <3088000>;
333			regulator-max-microvolt = <3088000>;
334			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
335		};
336
337		vreg_l25a_3p3: ldo25 {
338			regulator-min-microvolt = <3300000>;
339			regulator-max-microvolt = <3312000>;
340			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
341		};
342
343		vdda_hp_pcie_1p2:
344		vdda_hv_ebi0:
345		vdda_hv_ebi1:
346		vdda_hv_ebi2:
347		vdda_hv_ebi3:
348		vdda_mipi_csi_1p25:
349		vdda_mipi_dsi0_1p2:
350		vdda_mipi_dsi1_1p2:
351		vdda_pcie_1p2:
352		vdda_ufs1_1p2:
353		vdda_ufs2_1p2:
354		vdda_usb1_ss_1p2:
355		vdda_usb2_ss_1p2:
356		vreg_l26a_1p2: ldo26 {
357			regulator-min-microvolt = <1200000>;
358			regulator-max-microvolt = <1200000>;
359			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
360		};
361
362		vreg_l28a_3p0: ldo28 {
363			regulator-min-microvolt = <2856000>;
364			regulator-max-microvolt = <3008000>;
365			regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
366		};
367
368		vreg_lvs1a_1p8: lvs1 {
369			regulator-min-microvolt = <1800000>;
370			regulator-max-microvolt = <1800000>;
371		};
372
373		vreg_lvs2a_1p8: lvs2 {
374			regulator-min-microvolt = <1800000>;
375			regulator-max-microvolt = <1800000>;
376		};
377	};
378
379	regulators-1 {
380		compatible = "qcom,pmi8998-rpmh-regulators";
381		qcom,pmic-id = "b";
382
383		vdd-bob-supply = <&vph_pwr>;
384
385		vreg_bob: bob {
386			regulator-min-microvolt = <3312000>;
387			regulator-max-microvolt = <3600000>;
388			regulator-initial-mode = <RPMH_REGULATOR_MODE_AUTO>;
389			regulator-allow-bypass;
390		};
391	};
392
393	regulators-2 {
394		compatible = "qcom,pm8005-rpmh-regulators";
395		qcom,pmic-id = "c";
396
397		vdd-s1-supply = <&vph_pwr>;
398		vdd-s2-supply = <&vph_pwr>;
399		vdd-s3-supply = <&vph_pwr>;
400		vdd-s4-supply = <&vph_pwr>;
401
402		vreg_s3c_0p6: smps3 {
403			regulator-min-microvolt = <600000>;
404			regulator-max-microvolt = <600000>;
405		};
406	};
407};
408
409&cdsp_pas {
410	status = "okay";
411	firmware-name = "qcom/sdm845/axolotl/cdsp.mbn";
412};
413
414&dsi0 {
415	status = "okay";
416	vdda-supply = <&vdda_mipi_dsi0_1p2>;
417
418	panel@0 {
419		compatible = "visionox,rm69299-shift";
420		status = "okay";
421		reg = <0>;
422		vdda-supply = <&vreg_l14a_1p88>;
423		vdd3p3-supply = <&vreg_l28a_3p0>;
424
425		#address-cells = <1>;
426		#size-cells = <0>;
427
428		reset-gpios = <&tlmm 6 GPIO_ACTIVE_HIGH>;
429
430		pinctrl-names = "default", "sleep";
431		pinctrl-0 = <&sde_dsi_active &sde_te_active>;
432		pinctrl-1 = <&sde_dsi_suspend &sde_te_suspend>;
433
434		port {
435			panel_in_0: endpoint {
436				remote-endpoint = <&dsi0_out>;
437			};
438		};
439	};
440};
441
442&dsi0_out {
443	remote-endpoint = <&panel_in_0>;
444	data-lanes = <0 1 2 3>;
445};
446
447&dsi0_phy {
448	status = "okay";
449	vdds-supply = <&vdda_mipi_dsi0_pll>;
450};
451
452&gcc {
453	protected-clocks = <GCC_QSPI_CORE_CLK>,
454			   <GCC_QSPI_CORE_CLK_SRC>,
455			   <GCC_QSPI_CNOC_PERIPH_AHB_CLK>,
456			   <GCC_LPASS_Q6_AXI_CLK>,
457			   <GCC_LPASS_SWAY_CLK>;
458};
459
460&gmu {
461	status = "okay";
462};
463
464&gpu {
465	status = "okay";
466
467	zap-shader {
468		memory-region = <&gpu_mem>;
469		firmware-name = "qcom/sdm845/axolotl/a630_zap.mbn";
470	};
471};
472
473&i2c5 {
474	status = "okay";
475
476	touchscreen@38 {
477		compatible = "focaltech,fts8719";
478		reg = <0x38>;
479		wakeup-source;
480		interrupt-parent = <&tlmm>;
481		interrupts = <125 0x2>;
482		vdd-supply = <&vreg_l28a_3p0>;
483		vcc-i2c-supply = <&vreg_l14a_1p88>;
484
485		pinctrl-names = "default", "suspend";
486		pinctrl-0 = <&ts_int_active &ts_reset_active>;
487		pinctrl-1 = <&ts_int_suspend &ts_reset_suspend>;
488
489		reset-gpio = <&tlmm 99 GPIO_ACTIVE_HIGH>;
490		irq-gpio = <&tlmm 125 GPIO_TRANSITORY>;
491		touchscreen-size-x = <1080>;
492		touchscreen-size-y = <2160>;
493		focaltech,max-touch-number = <5>;
494	};
495};
496
497&ipa {
498	qcom,gsi-loader = "self";
499	memory-region = <&ipa_fw_mem>;
500	firmware-name = "qcom/sdm845/axolotl/ipa_fws.mbn";
501	status = "okay";
502};
503
504&mdss {
505	status = "okay";
506};
507
508&mss_pil {
509	status = "okay";
510	firmware-name = "qcom/sdm845/axolotl/mba.mbn", "qcom/sdm845/axolotl/modem.mbn";
511};
512
513&pm8998_gpios {
514	volume_up_gpio: pm8998-gpio6-state {
515		pinconf {
516			pins = "gpio6";
517			function = "normal";
518			input-enable;
519			bias-pull-up;
520			qcom,drive-strength = <0>;
521		};
522	};
523};
524
525&pm8998_resin {
526	linux,code = <KEY_VOLUMEDOWN>;
527	status = "okay";
528};
529
530&pmi8998_lpg {
531	status = "okay";
532
533	multi-led {
534		color = <LED_COLOR_ID_RGB>;
535		function = LED_FUNCTION_STATUS;
536
537		#address-cells = <1>;
538		#size-cells = <0>;
539
540		led@3 {
541			reg = <3>;
542			color = <LED_COLOR_ID_BLUE>;
543		};
544
545		led@4 {
546			reg = <4>;
547			color = <LED_COLOR_ID_GREEN>;
548		};
549
550		led@5 {
551			reg = <5>;
552			color = <LED_COLOR_ID_RED>;
553		};
554	};
555};
556
557&qup_uart9_rx {
558	drive-strength = <2>;
559	bias-pull-up;
560};
561
562&qup_uart9_tx {
563	drive-strength = <2>;
564	bias-disable;
565};
566
567&qupv3_id_0 {
568	status = "okay";
569};
570
571&qupv3_id_1 {
572	status = "okay";
573};
574
575&tlmm {
576	gpio-reserved-ranges = <0 4>, <81 4>;
577
578	sde_dsi_active: sde-dsi-active-state {
579		pins = "gpio6", "gpio11";
580		function = "gpio";
581		drive-strength = <8>;
582		bias-disable;
583	};
584
585	sde_dsi_suspend: sde-dsi-suspend-state {
586		pins = "gpio6", "gpio11";
587		function = "gpio";
588		drive-strength = <2>;
589		bias-pull-down;
590	};
591
592	sde_te_active: sde-te-active-state {
593		pins = "gpio10";
594		function = "mdp_vsync";
595		drive-strength = <2>;
596		bias-pull-down;
597	};
598
599	sde_te_suspend: sde-te-suspend-state {
600		pins = "gpio10";
601		function = "mdp_vsync";
602		drive-strength = <2>;
603		bias-pull-down;
604	};
605
606	ts_int_active: ts-int-active-state {
607		pins = "gpio125";
608		function = "gpio";
609		drive-strength = <8>;
610		bias-pull-up;
611		input-enable;
612	};
613
614	ts_int_suspend: ts-int-suspend-state {
615		pins = "gpio125";
616		function = "gpio";
617		drive-strength = <2>;
618		bias-pull-down;
619		input-enable;
620	};
621
622	ts_reset_active: ts-reset-active-state {
623		pins = "gpio99";
624		function = "gpio";
625		drive-strength = <8>;
626		bias-pull-up;
627	};
628
629	ts_reset_suspend: ts-reset-suspend-state {
630		pins = "gpio99";
631		function = "gpio";
632		drive-strength = <2>;
633		bias-pull-down;
634	};
635};
636
637&uart6 {
638	status = "okay";
639
640	pinctrl-0 = <&qup_uart6_4pin>;
641
642	bluetooth {
643		compatible = "qcom,wcn3990-bt";
644
645		/*
646		 * This path is relative to the qca/
647		 * subdir under lib/firmware.
648		 */
649		firmware-name = "axolotl/crnv21.bin";
650
651		vddio-supply = <&vreg_s4a_1p8>;
652		vddxo-supply = <&vreg_l7a_1p8>;
653		vddrf-supply = <&vreg_l17a_1p3>;
654		vddch0-supply = <&vreg_l25a_3p3>;
655		max-speed = <3200000>;
656	};
657};
658
659&uart9 {
660	status = "okay";
661};
662
663&ufs_mem_hc {
664	status = "okay";
665
666	reset-gpios = <&tlmm 150 GPIO_ACTIVE_LOW>;
667
668	vcc-supply = <&vreg_l20a_2p95>;
669	vcc-max-microamp = <600000>;
670};
671
672&ufs_mem_phy {
673	status = "okay";
674
675	vdda-phy-supply = <&vdda_ufs1_core>;
676	vdda-pll-supply = <&vdda_ufs1_1p2>;
677};
678
679&usb_1 {
680	status = "okay";
681};
682
683&usb_1_dwc3 {
684	dr_mode = "peripheral";
685};
686
687&usb_1_hsphy {
688	status = "okay";
689
690	vdd-supply = <&vreg_l1a_0p875>;
691	vdda-phy-dpdm-supply = <&vreg_l24a_3p075>;
692	vdda-pll-supply = <&vreg_l12a_1p8>;
693};
694
695&usb_1_qmpphy {
696	status = "okay";
697
698	vdda-phy-supply = <&vreg_l26a_1p2>;
699	vdda-pll-supply = <&vreg_l1a_0p875>;
700};
701
702&venus {
703	status = "okay";
704	firmware-name = "qcom/sdm845/axolotl/venus.mbn";
705};
706
707&wifi {
708	status = "okay";
709
710	vdd-0.8-cx-mx-supply = <&vreg_l5a_0p8>;
711	vdd-1.3-rfa-supply = <&vreg_l17a_1p3>;
712	vdd-1.8-xo-supply = <&vreg_l7a_1p8>;
713	vdd-3.3-ch0-supply = <&vreg_l25a_3p3>;
714	vdd-3.3-ch1-supply = <&vreg_l23a_3p3>;
715
716	qcom,snoc-host-cap-8bit-quirk;
717};
718