arm64: dts: qcom: sdm845: Rename gic-its node to msi-controller
[linux/fpc-iii.git] / arch / arm64 / boot / dts / rockchip / rk3399-gru-chromebook.dtsi
blob7cd6d470c1cbdb657e5c54b015ac012e07c2d085
1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2 /*
3  * Google Gru-Chromebook shared properties
4  *
5  * Copyright 2018 Google, Inc
6  */
8 #include "rk3399-gru.dtsi"
10 / {
11         pp900_ap: pp900-ap {
12                 compatible = "regulator-fixed";
13                 regulator-name = "pp900_ap";
15                 /* EC turns on w/ pp900_ap_en; always on for AP */
16                 regulator-always-on;
17                 regulator-boot-on;
18                 regulator-min-microvolt = <900000>;
19                 regulator-max-microvolt = <900000>;
21                 vin-supply = <&ppvar_sys>;
22         };
24         /* EC turns on w/ pp900_usb_en */
25         pp900_usb: pp900-ap {
26         };
28         /* EC turns on w/ pp900_pcie_en */
29         pp900_pcie: pp900-ap {
30         };
32         pp3000: pp3000 {
33                 compatible = "regulator-fixed";
34                 regulator-name = "pp3000";
35                 pinctrl-names = "default";
36                 pinctrl-0 = <&pp3000_en>;
38                 enable-active-high;
39                 gpio = <&gpio0 12 GPIO_ACTIVE_HIGH>;
41                 regulator-always-on;
42                 regulator-boot-on;
43                 regulator-min-microvolt = <3000000>;
44                 regulator-max-microvolt = <3000000>;
46                 vin-supply = <&ppvar_sys>;
47         };
49         ppvar_centerlogic_pwm: ppvar-centerlogic-pwm {
50                 compatible = "pwm-regulator";
51                 regulator-name = "ppvar_centerlogic_pwm";
53                 pwms = <&pwm3 0 3337 0>;
54                 pwm-supply = <&ppvar_sys>;
55                 pwm-dutycycle-range = <100 0>;
56                 pwm-dutycycle-unit = <100>;
58                 /* EC turns on w/ ppvar_centerlogic_en; always on for AP */
59                 regulator-always-on;
60                 regulator-boot-on;
61                 regulator-min-microvolt = <799434>;
62                 regulator-max-microvolt = <1049925>;
63         };
65         ppvar_centerlogic: ppvar-centerlogic {
66                 compatible = "vctrl-regulator";
67                 regulator-name = "ppvar_centerlogic";
69                 regulator-min-microvolt = <799434>;
70                 regulator-max-microvolt = <1049925>;
72                 ctrl-supply = <&ppvar_centerlogic_pwm>;
73                 ctrl-voltage-range = <799434 1049925>;
75                 regulator-settling-time-up-us = <378>;
76                 min-slew-down-rate = <225>;
77                 ovp-threshold-percent = <16>;
78         };
80         /* Schematics call this PPVAR even though it's fixed */
81         ppvar_logic: ppvar-logic {
82                 compatible = "regulator-fixed";
83                 regulator-name = "ppvar_logic";
85                 /* EC turns on w/ ppvar_logic_en; always on for AP */
86                 regulator-always-on;
87                 regulator-boot-on;
88                 regulator-min-microvolt = <900000>;
89                 regulator-max-microvolt = <900000>;
91                 vin-supply = <&ppvar_sys>;
92         };
94         pp1800_audio: pp1800-audio {
95                 compatible = "regulator-fixed";
96                 regulator-name = "pp1800_audio";
97                 pinctrl-names = "default";
98                 pinctrl-0 = <&pp1800_audio_en>;
100                 enable-active-high;
101                 gpio = <&gpio0 2 GPIO_ACTIVE_HIGH>;
103                 regulator-always-on;
104                 regulator-boot-on;
106                 vin-supply = <&pp1800>;
107         };
109         /* gpio is shared with pp3300_wifi_bt */
110         pp1800_pcie: pp1800-pcie {
111                 compatible = "regulator-fixed";
112                 regulator-name = "pp1800_pcie";
113                 pinctrl-names = "default";
114                 pinctrl-0 = <&wlan_module_pd_l>;
116                 enable-active-high;
117                 gpio = <&gpio0 4 GPIO_ACTIVE_HIGH>;
119                 /*
120                  * Need to wait 1ms + ramp-up time before we can power on WiFi.
121                  * This has been approximated as 8ms total.
122                  */
123                 regulator-enable-ramp-delay = <8000>;
125                 vin-supply = <&pp1800>;
126         };
128         /* Always on; plain and simple */
129         pp3000_ap: pp3000_emmc: pp3000 {
130         };
132         pp1500_ap_io: pp1500-ap-io {
133                 compatible = "regulator-fixed";
134                 regulator-name = "pp1500_ap_io";
135                 pinctrl-names = "default";
136                 pinctrl-0 = <&pp1500_en>;
138                 enable-active-high;
139                 gpio = <&gpio0 10 GPIO_ACTIVE_HIGH>;
141                 regulator-always-on;
142                 regulator-boot-on;
143                 regulator-min-microvolt = <1500000>;
144                 regulator-max-microvolt = <1500000>;
146                 vin-supply = <&pp1800>;
147         };
149         pp3300_disp: pp3300-disp {
150                 compatible = "regulator-fixed";
151                 regulator-name = "pp3300_disp";
152                 pinctrl-names = "default";
153                 pinctrl-0 = <&pp3300_disp_en>;
155                 enable-active-high;
156                 gpio = <&gpio4 27 GPIO_ACTIVE_HIGH>;
158                 startup-delay-us = <2000>;
159                 vin-supply = <&pp3300>;
160         };
162         /* EC turns on w/ pp3300_usb_en_l */
163         pp3300_usb: pp3300 {
164         };
166         /* gpio is shared with pp1800_pcie and pinctrl is set there */
167         pp3300_wifi_bt: pp3300-wifi-bt {
168                 compatible = "regulator-fixed";
169                 regulator-name = "pp3300_wifi_bt";
171                 enable-active-high;
172                 gpio = <&gpio0 4 GPIO_ACTIVE_HIGH>;
174                 vin-supply = <&pp3300>;
175         };
177         /*
178          * This is a bit of a hack. The WiFi module should be reset at least
179          * 1ms after its regulators have ramped up (max rampup time is ~7ms).
180          * With some stretching of the imagination, we can call the 1.8V
181          * regulator a supply.
182          */
183         wlan_pd_n: wlan-pd-n {
184                 compatible = "regulator-fixed";
185                 regulator-name = "wlan_pd_n";
186                 pinctrl-names = "default";
187                 pinctrl-0 = <&wlan_module_reset_l>;
189                 enable-active-high;
190                 gpio = <&gpio1 11 GPIO_ACTIVE_HIGH>;
192                 vin-supply = <&pp1800_pcie>;
193         };
195         backlight: backlight {
196                 compatible = "pwm-backlight";
197                 enable-gpios = <&gpio1 17 GPIO_ACTIVE_HIGH>;
198                 power-supply = <&pp3300_disp>;
199                 pinctrl-names = "default";
200                 pinctrl-0 = <&bl_en>;
201                 pwm-delay-us = <10000>;
202         };
204         gpio_keys: gpio-keys {
205                 compatible = "gpio-keys";
206                 pinctrl-names = "default";
207                 pinctrl-0 = <&bt_host_wake_l>;
209                 wake_on_bt: wake-on-bt {
210                         label = "Wake-on-Bluetooth";
211                         gpios = <&gpio0 3 GPIO_ACTIVE_LOW>;
212                         linux,code = <KEY_WAKEUP>;
213                         wakeup-source;
214                 };
215         };
218 &ppvar_bigcpu {
219         min-slew-down-rate = <225>;
220         ovp-threshold-percent = <16>;
223 &ppvar_litcpu {
224         min-slew-down-rate = <225>;
225         ovp-threshold-percent = <16>;
228 &ppvar_gpu {
229         min-slew-down-rate = <225>;
230         ovp-threshold-percent = <16>;
233 &cdn_dp {
234         extcon = <&usbc_extcon0>, <&usbc_extcon1>;
237 &edp {
238         status = "okay";
240         ports {
241                 edp_out: port@1 {
242                         reg = <1>;
243                         #address-cells = <1>;
244                         #size-cells = <0>;
246                         edp_out_panel: endpoint@0 {
247                                 reg = <0>;
248                                 remote-endpoint = <&panel_in_edp>;
249                         };
250                 };
251         };
254 ap_i2c_mic: &i2c1 {
255         status = "okay";
257         clock-frequency = <400000>;
259         /* These are relatively safe rise/fall times */
260         i2c-scl-falling-time-ns = <50>;
261         i2c-scl-rising-time-ns = <300>;
263         headsetcodec: rt5514@57 {
264                 compatible = "realtek,rt5514";
265                 reg = <0x57>;
266                 realtek,dmic-init-delay-ms = <20>;
267         };
270 ap_i2c_tp: &i2c5 {
271         status = "okay";
273         clock-frequency = <400000>;
275         /* These are relatively safe rise/fall times */
276         i2c-scl-falling-time-ns = <50>;
277         i2c-scl-rising-time-ns = <300>;
279         /*
280          * Note strange pullup enable.  Apparently this avoids leakage but
281          * still allows us to get nice 4.7K pullups for high speed i2c
282          * transfers.  Basically we want the pullup on whenever the ap is
283          * alive, so the "en" pin just gets set to output high.
284          */
285         pinctrl-0 = <&i2c5_xfer &ap_i2c_tp_pu_en>;
288 &cros_ec {
289         cros_ec_pwm: ec-pwm {
290                 compatible = "google,cros-ec-pwm";
291                 #pwm-cells = <1>;
292         };
294         usbc_extcon1: extcon@1 {
295                 compatible = "google,extcon-usbc-cros-ec";
296                 google,usb-port-id = <1>;
298                 #extcon-cells = <0>;
299         };
302 &sound {
303         rockchip,codec = <&max98357a &headsetcodec
304                           &codec &wacky_spi_audio &cdn_dp>;
307 &spi2 {
308         wacky_spi_audio: spi2@0 {
309                 compatible = "realtek,rt5514";
310                 reg = <0>;
311                 interrupt-parent = <&gpio1>;
312                 interrupts = <13 IRQ_TYPE_LEVEL_HIGH>;
313                 pinctrl-names = "default";
314                 pinctrl-0 = <&mic_int>;
315                 /* May run faster once verified. */
316                 spi-max-frequency = <10000000>;
317                 wakeup-source;
318         };
321 &pci_rootport {
322         mvl_wifi: wifi@0,0 {
323                 compatible = "pci1b4b,2b42";
324                 reg = <0x83010000 0x0 0x00000000 0x0 0x00100000
325                        0x83010000 0x0 0x00100000 0x0 0x00100000>;
326                 interrupt-parent = <&gpio0>;
327                 interrupts = <8 IRQ_TYPE_LEVEL_LOW>;
328                 pinctrl-names = "default";
329                 pinctrl-0 = <&wlan_host_wake_l>;
330                 wakeup-source;
331         };
334 &tcphy1 {
335         status = "okay";
336         extcon = <&usbc_extcon1>;
339 &u2phy1 {
340         status = "okay";
343 &usb_host0_ehci {
344         status = "okay";
347 &usb_host1_ehci {
348         status = "okay";
351 &usb_host1_ohci {
352         status = "okay";
355 &usbdrd3_1 {
356         status = "okay";
357         extcon = <&usbc_extcon1>;
360 &usbdrd_dwc3_1 {
361         status = "okay";
362         dr_mode = "host";
365 &pinctrl {
366         discrete-regulators {
367                 pp1500_en: pp1500-en {
368                         rockchip,pins = <0 RK_PB2 RK_FUNC_GPIO
369                                          &pcfg_pull_none>;
370                 };
372                 pp1800_audio_en: pp1800-audio-en {
373                         rockchip,pins = <0 RK_PA2 RK_FUNC_GPIO
374                                          &pcfg_pull_down>;
375                 };
377                 pp3000_en: pp3000-en {
378                         rockchip,pins = <0 RK_PB4 RK_FUNC_GPIO
379                                          &pcfg_pull_none>;
380                 };
382                 pp3300_disp_en: pp3300-disp-en {
383                         rockchip,pins = <4 RK_PD3 RK_FUNC_GPIO
384                                          &pcfg_pull_none>;
385                 };
387                 wlan_module_pd_l: wlan-module-pd-l {
388                         rockchip,pins = <0 RK_PA4 RK_FUNC_GPIO
389                                          &pcfg_pull_down>;
390                 };
391         };
394 &wifi {
395         wifi_perst_l: wifi-perst-l {
396                 rockchip,pins = <2 RK_PD3 RK_FUNC_GPIO &pcfg_pull_none>;
397         };
399         wlan_host_wake_l: wlan-host-wake-l {
400                 rockchip,pins = <0 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>;
401         };