Merge tag 'linux-kselftest-kunit-5.15-rc1' of git://git.kernel.org/pub/scm/linux...
[linux-2.6-microblaze.git] / arch / arm64 / boot / dts / qcom / sdm630-sony-xperia-nile.dtsi
1 // SPDX-License-Identifier: BSD-3-Clause
2 /*
3  * Copyright (c) 2020, Konrad Dybcio <konrad.dybcio@somainline.org>
4  * Copyright (c) 2020, AngeloGioacchino Del Regno
5  *                     <angelogioacchino.delregno@somainline.org>
6  */
7
8 #include "pm660.dtsi"
9 #include "pm660l.dtsi"
10 #include <dt-bindings/gpio/gpio.h>
11 #include <dt-bindings/input/input.h>
12 #include <dt-bindings/input/gpio-keys.h>
13
14 / {
15         /* required for bootloader to select correct board */
16         qcom,msm-id = <318 0>;
17         qcom,board-id = <8 1>;
18         qcom,pmic-id = <0x1001b 0x101011a 0x00 0x00 0x1001b 0x201011a 0x00 0x00>;
19
20         /* This part enables graphical output via bootloader-enabled display */
21         chosen {
22                 bootargs = "earlycon=tty0 console=tty0";
23
24                 #address-cells = <2>;
25                 #size-cells = <2>;
26                 ranges;
27
28                 stdout-path = "framebuffer0";
29
30                 framebuffer0: framebuffer@9d400000 {
31                         compatible = "simple-framebuffer";
32                         reg = <0 0x9d400000 0 (1920 * 1080 * 4)>;
33                         width = <1080>;
34                         height = <1920>;
35                         stride = <(1080 * 4)>;
36                         format = "a8r8g8b8";
37                         status= "okay";
38                 };
39         };
40
41         board_vbat: vbat-regulator {
42                 compatible = "regulator-fixed";
43                 regulator-name = "VBAT";
44
45                 regulator-min-microvolt = <4000000>;
46                 regulator-max-microvolt = <4000000>;
47                 regulator-always-on;
48                 regulator-boot-on;
49         };
50
51         vph_pwr: vph-pwr-regulator {
52                 compatible = "regulator-fixed";
53                 regulator-name = "vph_pwr";
54
55                 regulator-always-on;
56                 regulator-boot-on;
57         };
58
59         cam_vdig_imx300_219_vreg: cam_vdig_imx300_219_vreg {
60                 compatible = "regulator-fixed";
61                 regulator-name = "cam_vdig_imx300_219_vreg";
62                 startup-delay-us = <0>;
63                 enable-active-high;
64                 gpio = <&tlmm 52 GPIO_ACTIVE_HIGH>;
65                 pinctrl-names = "default";
66                 pinctrl-0 = <&cam_vdig_default>;
67         };
68
69         cam_vana_front_vreg: cam_vana_front_vreg {
70                 compatible = "regulator-fixed";
71                 regulator-name = "cam_vana_front_vreg";
72                 startup-delay-us = <0>;
73                 enable-active-high;
74                 gpio = <&tlmm 51 GPIO_ACTIVE_HIGH>;
75                 pinctrl-names = "default";
76                 pinctrl-0 = <&imx219_vana_default>;
77         };
78
79         cam_vana_rear_vreg: cam_vana_rear_vreg {
80                 compatible = "regulator-fixed";
81                 regulator-name = "cam_vana_rear_vreg";
82                 startup-delay-us = <0>;
83                 enable-active-high;
84                 gpio = <&tlmm 50 GPIO_ACTIVE_HIGH>;
85                 regulator-always-on;
86                 pinctrl-names = "default";
87                 pinctrl-0 = <&imx300_vana_default>;
88         };
89
90         gpio_keys {
91                 status = "okay";
92                 compatible = "gpio-keys";
93                 input-name = "gpio-keys";
94                 #address-cells = <1>;
95                 #size-cells = <0>;
96
97                 camera_focus {
98                         label = "Camera Focus";
99                         gpios = <&tlmm 64 GPIO_ACTIVE_LOW>;
100                         linux,input-type = <1>;
101                         linux,code = <KEY_CAMERA_FOCUS>;
102                         debounce-interval = <15>;
103                 };
104
105                 camera_snapshot {
106                         label = "Camera Snapshot";
107                         gpios = <&tlmm 113 GPIO_ACTIVE_LOW>;
108                         linux,input-type = <1>;
109                         linux,code = <KEY_CAMERA>;
110                         debounce-interval = <15>;
111                 };
112
113                 vol_down {
114                         label = "Volume Down";
115                         gpios = <&pm660l_gpios 7 GPIO_ACTIVE_LOW>;
116                         linux,input-type = <1>;
117                         linux,code = <KEY_VOLUMEDOWN>;
118                         gpio-key,wakeup;
119                         debounce-interval = <15>;
120                 };
121         };
122
123         reserved-memory {
124                 #address-cells = <2>;
125                 #size-cells = <2>;
126                 ranges;
127
128                 ramoops@ffc00000 {
129                         compatible = "ramoops";
130                         reg = <0x0 0xffc00000 0x0 0x100000>;
131                         record-size = <0x10000>;
132                         console-size = <0x60000>;
133                         ftrace-size = <0x10000>;
134                         pmsg-size = <0x20000>;
135                         ecc-size = <16>;
136                         status = "okay";
137                 };
138
139                 debug_region@ffb00000 {
140                         reg = <0x00 0xffb00000 0x00 0x100000>;
141                         no-map;
142                 };
143
144                 removed_region@85800000 {
145                         reg = <0x00 0x85800000 0x00 0x3700000>;
146                         no-map;
147                 };
148         };
149
150         /*
151          * Until we hook up type-c detection, we
152          * have to stick with this. But it works.
153          */
154         extcon_usb: extcon-usb {
155                 compatible = "linux,extcon-usb-gpio";
156                 id-gpio = <&tlmm 58 GPIO_ACTIVE_HIGH>;
157         };
158 };
159
160 &adsp_pil {
161         firmware-name = "adsp.mdt";
162 };
163
164 &blsp_i2c1 {
165         status = "okay";
166
167         touchscreen: synaptics-rmi4-i2c@70 {
168                 compatible = "syna,rmi4-i2c";
169                 reg = <0x70>;
170                 #address-cells = <1>;
171                 #size-cells = <0>;
172                 interrupts-extended = <&tlmm 45 0x2008>;
173
174                 pinctrl-names = "default";
175                 pinctrl-0 = <&ts_int_active &ts_lcd_id_active>;
176
177                 syna,reset-delay-ms = <200>;
178                 syna,startup-delay-ms = <220>;
179
180                 rmi4-f01@1 {
181                         reg = <0x01>;
182                         syna,nosleep-mode = <1>;
183                 };
184
185                 rmi4-f11@11 {
186                         reg = <0x11>;
187                         syna,sensor-type = <1>;
188                 };
189         };
190 };
191
192 &blsp_i2c2 {
193         status = "okay";
194
195         /* SMB1351 charger */
196 };
197
198 /* I2C3, 4, 5, 7 and 8 are disabled on this board. */
199
200 &blsp_i2c6 {
201         status = "okay";
202
203         /* NXP NFC */
204 };
205
206 &blsp1_uart2 {
207         status = "okay";
208
209         /* MSM serial console */
210 };
211
212 &blsp2_uart1 {
213         status = "okay";
214
215         /* HCI Bluetooth */
216 };
217
218 &pon {
219         volup {
220                 compatible = "qcom,pm8941-resin";
221                 interrupts = <0x0 0x8 1 IRQ_TYPE_EDGE_BOTH>;
222                 debounce = <15625>;
223                 bias-pull-up;
224                 linux,code = <KEY_VOLUMEUP>;
225         };
226 };
227
228 &qusb2phy {
229         status = "okay";
230
231         vdd-supply = <&vreg_l1b_0p925>;
232         vdda-pll-supply = <&vreg_l10a_1p8>;
233         vdda-phy-dpdm-supply = <&vreg_l7b_3p125>;
234 };
235
236 &rpm_requests {
237         pm660l-regulators {
238                 compatible = "qcom,rpm-pm660l-regulators";
239
240                 vdd_s1-supply = <&vph_pwr>;
241                 vdd_s2-supply = <&vph_pwr>;
242                 vdd_s3_s4-supply = <&vph_pwr>;
243                 vdd_s5-supply = <&vph_pwr>;
244                 vdd_s6-supply = <&vph_pwr>;
245
246                 vdd_l1_l9_l10-supply = <&vreg_s2b_1p05>;
247                 vdd_l2-supply = <&vreg_bob>;
248                 vdd_l3_l5_l7_l8-supply = <&vreg_bob>;
249                 vdd_l4_l6-supply = <&vreg_bob>;
250                 vdd_bob-supply = <&vph_pwr>;
251
252                 vreg_s1b_1p125: s1 {
253                         regulator-min-microvolt = <1125000>;
254                         regulator-max-microvolt = <1125000>;
255                         regulator-enable-ramp-delay = <200>;
256                         regulator-ramp-delay = <0>;
257                 };
258
259                 vreg_s2b_1p05: s2 {
260                         regulator-min-microvolt = <1050000>;
261                         regulator-max-microvolt = <1050000>;
262                         regulator-enable-ramp-delay = <200>;
263                         regulator-ramp-delay = <0>;
264                 };
265
266                 /*
267                  * At least on Nile's configuration, S3B/S4B (VDD_CX) and
268                  * S5B (VDD_MX) are managed only through RPM Power Domains.
269                  * Trying to set a voltage on the main supply will create
270                  * havoc and freeze the SoC.
271                  * In any case, reference voltages for these regulators are:
272                  * S3B/S4B: 0.870V
273                  * S5B: 0.915V
274                  */
275
276                 /* LDOs */
277                 vreg_l1b_0p925: l1 {
278                         regulator-min-microvolt = <920000>;
279                         regulator-max-microvolt = <928000>;
280                         regulator-enable-ramp-delay = <250>;
281                         regulator-ramp-delay = <0>;
282                         regulator-allow-set-load;
283                 };
284
285                 vreg_l2b_2p95: l2 {
286                         /*
287                          * This regulator supports 1.648 - 3.104V on this board
288                          * but we set a max voltage of anything less than 2.7V
289                          * to satisfy a condition in sdhci.c that will disable
290                          * 3.3V SDHCI signaling, which happens to be not really
291                          * supported on the Xperia Nile/Ganges platform.
292                          */
293                         regulator-min-microvolt = <1648000>;
294                         regulator-max-microvolt = <2696000>;
295                         regulator-enable-ramp-delay = <250>;
296                         regulator-ramp-delay = <0>;
297                         regulator-allow-set-load;
298                 };
299
300                 vreg_l3b_3p0: l3 {
301                         regulator-min-microvolt = <2800000>;
302                         regulator-max-microvolt = <2800000>;
303                         regulator-enable-ramp-delay = <250>;
304                         regulator-ramp-delay = <0>;
305                         regulator-min-microamp = <200>;
306                         regulator-max-microamp = <600000>;
307                         regulator-system-load = <100000>;
308                         regulator-allow-set-load;
309                 };
310
311                 vreg_l4b_29p5: l4 {
312                         regulator-min-microvolt = <2944000>;
313                         regulator-max-microvolt = <2952000>;
314                         regulator-enable-ramp-delay = <250>;
315                         regulator-ramp-delay = <0>;
316
317                         regulator-min-microamp = <200>;
318                         regulator-max-microamp = <600000>;
319                         regulator-system-load = <570000>;
320                         regulator-allow-set-load;
321                 };
322
323                 /*
324                  * Downstream specifies a range of 1721-3600mV,
325                  * but the only assigned consumers are SDHCI2 VMMC
326                  * and Coresight QPDI that both request pinned 2.95V.
327                  * Tighten the range to 1.8-3.328 (closest to 3.3) to
328                  * make the mmc driver happy.
329                  */
330                 vreg_l5b_29p5: l5 {
331                         regulator-min-microvolt = <1800000>;
332                         regulator-max-microvolt = <3328000>;
333                         regulator-enable-ramp-delay = <250>;
334                         regulator-ramp-delay = <0>;
335                         regulator-allow-set-load;
336                         regulator-system-load = <800000>;
337                 };
338
339                 vreg_l6b_3p3: l6 {
340                         regulator-min-microvolt = <1704000>;
341                         regulator-max-microvolt = <3312000>;
342                         regulator-enable-ramp-delay = <250>;
343                         regulator-ramp-delay = <0>;
344                 };
345
346                 vreg_l7b_3p125: l7 {
347                         regulator-min-microvolt = <2704000>;
348                         regulator-max-microvolt = <3128000>;
349                         regulator-enable-ramp-delay = <250>;
350                         regulator-ramp-delay = <0>;
351                 };
352
353                 vreg_l8b_3p3: l8 {
354                         regulator-min-microvolt = <2800000>;
355                         regulator-max-microvolt = <3400000>;
356                         regulator-enable-ramp-delay = <250>;
357                         regulator-ramp-delay = <0>;
358                 };
359
360                 /* L9B (870mV) is currently unused */
361                 /* L10B (915mV) is currently unused */
362
363                 vreg_bob: bob {
364                         regulator-min-microvolt = <3304000>;
365                         regulator-max-microvolt = <3624000>;
366                         regulator-enable-ramp-delay = <500>;
367                         regulator-ramp-delay = <0>;
368                 };
369         };
370
371         pm660-regulators {
372                 compatible = "qcom,rpm-pm660-regulators";
373
374                 vdd_s1-supply = <&vph_pwr>;
375                 vdd_s2-supply = <&vph_pwr>;
376                 vdd_s3-supply = <&vph_pwr>;
377                 vdd_s4-supply = <&vph_pwr>;
378                 vdd_s5-supply = <&vph_pwr>;
379                 vdd_s6-supply = <&vph_pwr>;
380
381                 vdd_l1_l6_l7-supply = <&vreg_s5a_1p35>;
382                 vdd_l2_l3-supply = <&vreg_s2b_1p05>;
383                 vdd_l5-supply = <&vreg_s2b_1p05>;
384                 vdd_l8_l9_l10_l11_l12_l13_l14-supply = <&vreg_s4a_2p04>;
385                 vdd_l15_l16_l17_l18_l19-supply = <&vreg_bob>;
386
387                 /*
388                  * S1A (FTAPC0), S2A (FTAPC1), S3A (HFAPC1) are managed
389                  * by the Core Power Reduction hardened (CPRh) and the
390                  * Operating State Manager (OSM) HW automatically.
391                  */
392
393                 vreg_s4a_2p04: s4 {
394                         regulator-min-microvolt = <2040000>;
395                         regulator-max-microvolt = <2040000>;
396                         regulator-enable-ramp-delay = <200>;
397                         regulator-ramp-delay = <0>;
398                         regulator-always-on;
399                 };
400
401                 vreg_s5a_1p35: s5 {
402                         regulator-min-microvolt = <1224000>;
403                         regulator-max-microvolt = <1350000>;
404                         regulator-enable-ramp-delay = <200>;
405                         regulator-ramp-delay = <0>;
406                 };
407
408                 vreg_s6a_0p87: s6 {
409                         regulator-min-microvolt = <504000>;
410                         regulator-max-microvolt = <992000>;
411                         regulator-enable-ramp-delay = <150>;
412                         regulator-ramp-delay = <0>;
413                 };
414
415                 /* LDOs */
416                 vreg_l1a_1p225: l1 {
417                         regulator-min-microvolt = <1226000>;
418                         regulator-max-microvolt = <1250000>;
419                         regulator-enable-ramp-delay = <250>;
420                         regulator-ramp-delay = <0>;
421                         regulator-allow-set-load;
422                 };
423
424                 vreg_l2a_1p0: l2 {
425                         regulator-min-microvolt = <944000>;
426                         regulator-max-microvolt = <1008000>;
427                         regulator-enable-ramp-delay = <250>;
428                         regulator-ramp-delay = <0>;
429                 };
430
431                 vreg_l3a_1p0: l3 {
432                         regulator-min-microvolt = <944000>;
433                         regulator-max-microvolt = <1008000>;
434                         regulator-enable-ramp-delay = <250>;
435                         regulator-ramp-delay = <0>;
436                 };
437
438                 vreg_l5a_0p848: l5 {
439                         regulator-min-microvolt = <800000>;
440                         regulator-max-microvolt = <952000>;
441                         regulator-enable-ramp-delay = <250>;
442                         regulator-ramp-delay = <0>;
443                 };
444
445                 vreg_l6a_1p3: l6 {
446                         regulator-min-microvolt = <1304000>;
447                         regulator-max-microvolt = <1368000>;
448                         regulator-allow-set-load;
449                         regulator-enable-ramp-delay = <250>;
450                         regulator-ramp-delay = <0>;
451                 };
452
453                 vreg_l7a_1p2: l7 {
454                         regulator-min-microvolt = <1200000>;
455                         regulator-max-microvolt = <1200000>;
456                         regulator-enable-ramp-delay = <250>;
457                         regulator-ramp-delay = <0>;
458                 };
459
460                 vreg_l8a_1p8: l8 {
461                         regulator-min-microvolt = <1800000>;
462                         regulator-max-microvolt = <1800000>;
463                         regulator-enable-ramp-delay = <250>;
464                         regulator-ramp-delay = <0>;
465                         regulator-system-load = <325000>;
466                         regulator-allow-set-load;
467                 };
468
469                 vreg_l9a_1p8: l9 {
470                         regulator-min-microvolt = <1804000>;
471                         regulator-max-microvolt = <1896000>;
472                         regulator-enable-ramp-delay = <250>;
473                         regulator-ramp-delay = <0>;
474                         regulator-allow-set-load;
475                 };
476
477                 vreg_l10a_1p8: l10 {
478                         regulator-min-microvolt = <1800000>;
479                         regulator-max-microvolt = <1944000>;
480                         regulator-enable-ramp-delay = <250>;
481                         regulator-ramp-delay = <0>;
482                         regulator-allow-set-load;
483                 };
484
485                 vreg_l11a_1p8: l11 {
486                         regulator-min-microvolt = <1784000>;
487                         regulator-max-microvolt = <1944000>;
488                         regulator-enable-ramp-delay = <250>;
489                         regulator-ramp-delay = <0>;
490                 };
491
492                 vreg_l12a_1p8: l12 {
493                         regulator-min-microvolt = <1800000>;
494                         regulator-max-microvolt = <1944000>;
495                         regulator-enable-ramp-delay = <250>;
496                         regulator-ramp-delay = <0>;
497                 };
498
499                 /* This gives power to the LPDDR4: never turn it off! */
500                 vreg_l13a_1p8: l13 {
501                         regulator-min-microvolt = <1800000>;
502                         regulator-max-microvolt = <1944000>;
503                         regulator-enable-ramp-delay = <250>;
504                         regulator-ramp-delay = <0>;
505                         regulator-boot-on;
506                         regulator-always-on;
507                 };
508
509                 vreg_l14a_1p8: l14 {
510                         regulator-min-microvolt = <1710000>;
511                         regulator-max-microvolt = <1904000>;
512                         regulator-enable-ramp-delay = <250>;
513                         regulator-ramp-delay = <0>;
514                 };
515
516                 vreg_l15a_1p8: l15 {
517                         regulator-min-microvolt = <1648000>;
518                         regulator-max-microvolt = <2952000>;
519                         regulator-enable-ramp-delay = <250>;
520                         regulator-ramp-delay = <0>;
521                 };
522
523                 /* L16A (2.70V) is unused */
524
525                 vreg_l17a_1p8: l17 {
526                         regulator-min-microvolt = <1648000>;
527                         regulator-max-microvolt = <2952000>;
528                         regulator-enable-ramp-delay = <250>;
529                         regulator-ramp-delay = <0>;
530                 };
531
532                 vreg_l18a_1v8: l18 {
533                         regulator-min-microvolt = <1800000>;
534                         regulator-max-microvolt = <1800000>;
535                         regulator-enable-ramp-delay = <250>;
536                         regulator-ramp-delay = <10>;
537                         regulator-min-microamp = <200>;
538                         regulator-max-microamp = <50000>;
539                         regulator-system-load = <10000>;
540                         regulator-allow-set-load;
541                 };
542
543                 vreg_l19a_3p3: l19 {
544                         regulator-min-microvolt = <3312000>;
545                         regulator-max-microvolt = <3400000>;
546                         regulator-enable-ramp-delay = <250>;
547                         regulator-ramp-delay = <0>;
548                         regulator-allow-set-load;
549                 };
550         };
551 };
552
553 &sdhc_1 {
554         status = "okay";
555         supports-cqe;
556
557         /* SoMC Nile platform's eMMC doesn't support HS200 mode */
558         mmc-ddr-1_8v;
559         mmc-hs400-1_8v;
560         mmc-hs400-enhanced-strobe;
561
562         vmmc-supply = <&vreg_l4b_29p5>;
563         vqmmc-supply = <&vreg_l8a_1p8>;
564 };
565
566 &sdhc_2 {
567         status = "okay";
568
569         vmmc-supply = <&vreg_l5b_29p5>;
570         vqmmc-supply = <&vreg_l2b_2p95>;
571 };
572
573 &tlmm {
574         gpio-reserved-ranges = <8 4>;
575
576         ts_int_active: ts-int-active {
577                 pins = "gpio45";
578                 drive-strength = <8>;
579                 bias-pull-up;
580         };
581
582         ts_lcd_id_active: ts-lcd-id-active {
583                 pins = "gpio56";
584                 drive-strength = <8>;
585                 bias-disable;
586         };
587
588         imx300_vana_default: imx300-vana-default {
589                 pins = "gpio50";
590                 function = "gpio";
591                 bias-disable;
592                 drive-strength = <2>;
593         };
594
595         imx219_vana_default: imx219-vana-default {
596                 pins = "gpio51";
597                 function = "gpio";
598                 bias-disable;
599                 drive-strength = <2>;
600         };
601
602         cam_vdig_default: cam-vdig-default {
603                 pins = "gpio52";
604                 function = "gpio";
605                 bias-disable;
606                 drive-strength = <2>;
607         };
608 };
609
610 &usb3 {
611         status = "okay";
612 };
613
614 &usb3_dwc3 {
615         dr_mode = "peripheral";
616         extcon = <&extcon_usb>;
617 };