1// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2/* 3 * Google Gru-Kevin Rev 6+ board device tree source 4 * 5 * Copyright 2016-2017 Google, Inc 6 */ 7 8/dts-v1/; 9#include "rk3399-gru-chromebook.dtsi" 10#include <dt-bindings/input/linux-event-codes.h> 11 12/* 13 * Kevin-specific things 14 * 15 * Things in this section should use names from Kevin schematic since no 16 * equivalent exists in Gru schematic. If referring to signals that exist 17 * in Gru we use the Gru names, though. Confusing enough for you? 18 */ 19/ { 20 model = "Google Kevin"; 21 compatible = "google,kevin-rev15", "google,kevin-rev14", 22 "google,kevin-rev13", "google,kevin-rev12", 23 "google,kevin-rev11", "google,kevin-rev10", 24 "google,kevin-rev9", "google,kevin-rev8", 25 "google,kevin-rev7", "google,kevin-rev6", 26 "google,kevin", "google,gru", "rockchip,rk3399"; 27 28 /* Power tree */ 29 30 p3_3v_dig: p3-3v-dig { 31 compatible = "regulator-fixed"; 32 regulator-name = "p3.3v_dig"; 33 pinctrl-names = "default"; 34 pinctrl-0 = <&cpu3_pen_pwr_en>; 35 36 enable-active-high; 37 gpio = <&gpio4 30 GPIO_ACTIVE_HIGH>; 38 vin-supply = <&pp3300>; 39 }; 40 41 edp_panel: edp-panel { 42 compatible = "sharp,lq123p1jx31", "simple-panel"; 43 backlight = <&backlight>; 44 power-supply = <&pp3300_disp>; 45 46 panel-timing { 47 clock-frequency = <266666667>; 48 hactive = <2400>; 49 hfront-porch = <48>; 50 hback-porch = <84>; 51 hsync-len = <32>; 52 hsync-active = <0>; 53 vactive = <1600>; 54 vfront-porch = <3>; 55 vback-porch = <120>; 56 vsync-len = <10>; 57 vsync-active = <0>; 58 }; 59 60 port { 61 panel_in_edp: endpoint { 62 remote-endpoint = <&edp_out_panel>; 63 }; 64 }; 65 }; 66 67 thermistor_ppvar_bigcpu: thermistor-ppvar-bigcpu { 68 compatible = "murata,ncp15wb473"; 69 pullup-uv = <1800000>; 70 pullup-ohm = <25500>; 71 pulldown-ohm = <0>; 72 io-channels = <&saradc 2>; 73 #thermal-sensor-cells = <0>; 74 }; 75 76 thermistor_ppvar_litcpu: thermistor-ppvar-litcpu { 77 compatible = "murata,ncp15wb473"; 78 pullup-uv = <1800000>; 79 pullup-ohm = <25500>; 80 pulldown-ohm = <0>; 81 io-channels = <&saradc 3>; 82 #thermal-sensor-cells = <0>; 83 }; 84}; 85 86&backlight { 87 pwms = <&cros_ec_pwm 1>; 88}; 89 90&gpio_keys { 91 pinctrl-names = "default"; 92 pinctrl-0 = <&bt_host_wake_l>, <&cpu1_pen_eject>; 93 94 pen-insert { 95 label = "Pen Insert"; 96 /* Insert = low, eject = high */ 97 gpios = <&gpio0 13 GPIO_ACTIVE_LOW>; 98 linux,code = <SW_PEN_INSERTED>; 99 linux,input-type = <EV_SW>; 100 wakeup-source; 101 }; 102}; 103 104&thermal_zones { 105 bigcpu_reg_thermal: bigcpu-reg-thermal { 106 polling-delay-passive = <100>; /* milliseconds */ 107 polling-delay = <1000>; /* milliseconds */ 108 thermal-sensors = <&thermistor_ppvar_bigcpu 0>; 109 sustainable-power = <4000>; 110 111 ppvar_bigcpu_trips: trips { 112 ppvar_bigcpu_on: ppvar-bigcpu-on { 113 temperature = <40000>; /* millicelsius */ 114 hysteresis = <2000>; /* millicelsius */ 115 type = "passive"; 116 }; 117 118 ppvar_bigcpu_alert: ppvar-bigcpu-alert { 119 temperature = <50000>; /* millicelsius */ 120 hysteresis = <2000>; /* millicelsius */ 121 type = "passive"; 122 }; 123 124 ppvar_bigcpu_crit: ppvar-bigcpu-crit { 125 temperature = <90000>; /* millicelsius */ 126 hysteresis = <0>; /* millicelsius */ 127 type = "critical"; 128 }; 129 }; 130 131 cooling-maps { 132 map0 { 133 trip = <&ppvar_bigcpu_alert>; 134 cooling-device = 135 <&cpu_l0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 136 <&cpu_l1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 137 <&cpu_l2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 138 <&cpu_l3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; 139 contribution = <4096>; 140 }; 141 map1 { 142 trip = <&ppvar_bigcpu_alert>; 143 cooling-device = 144 <&cpu_b0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 145 <&cpu_b1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; 146 contribution = <1024>; 147 }; 148 }; 149 }; 150 151 litcpu_reg_thermal: litcpu-reg-thermal { 152 polling-delay-passive = <100>; /* milliseconds */ 153 polling-delay = <1000>; /* milliseconds */ 154 thermal-sensors = <&thermistor_ppvar_litcpu 0>; 155 sustainable-power = <4000>; 156 157 ppvar_litcpu_trips: trips { 158 ppvar_litcpu_on: ppvar-litcpu-on { 159 temperature = <40000>; /* millicelsius */ 160 hysteresis = <2000>; /* millicelsius */ 161 type = "passive"; 162 }; 163 164 ppvar_litcpu_alert: ppvar-litcpu-alert { 165 temperature = <50000>; /* millicelsius */ 166 hysteresis = <2000>; /* millicelsius */ 167 type = "passive"; 168 }; 169 170 ppvar_litcpu_crit: ppvar-litcpu-crit { 171 temperature = <90000>; /* millicelsius */ 172 hysteresis = <0>; /* millicelsius */ 173 type = "critical"; 174 }; 175 }; 176 }; 177}; 178 179ap_i2c_tpm: &i2c0 { 180 status = "okay"; 181 182 clock-frequency = <400000>; 183 184 /* These are relatively safe rise/fall times. */ 185 i2c-scl-falling-time-ns = <50>; 186 i2c-scl-rising-time-ns = <300>; 187 188 tpm: tpm@20 { 189 compatible = "infineon,slb9645tt"; 190 reg = <0x20>; 191 powered-while-suspended; 192 }; 193}; 194 195ap_i2c_dig: &i2c2 { 196 status = "okay"; 197 198 clock-frequency = <400000>; 199 200 /* These are relatively safe rise/fall times. */ 201 i2c-scl-falling-time-ns = <50>; 202 i2c-scl-rising-time-ns = <300>; 203 204 digitizer: digitizer@9 { 205 /* wacom,w9013 */ 206 compatible = "hid-over-i2c"; 207 reg = <0x9>; 208 pinctrl-names = "default"; 209 pinctrl-0 = <&cpu1_dig_irq_l &cpu1_dig_pdct_l>; 210 211 vdd-supply = <&p3_3v_dig>; 212 post-power-on-delay-ms = <100>; 213 214 interrupt-parent = <&gpio2>; 215 interrupts = <4 IRQ_TYPE_LEVEL_LOW>; 216 217 hid-descr-addr = <0x1>; 218 }; 219}; 220 221/* Adjustments to things in the gru baseboard */ 222 223&ap_i2c_tp { 224 trackpad@4a { 225 compatible = "atmel,maxtouch"; 226 reg = <0x4a>; 227 pinctrl-names = "default"; 228 pinctrl-0 = <&trackpad_int_l>; 229 interrupt-parent = <&gpio1>; 230 interrupts = <4 IRQ_TYPE_LEVEL_LOW>; 231 linux,gpio-keymap = <KEY_RESERVED 232 KEY_RESERVED 233 KEY_RESERVED 234 BTN_LEFT>; 235 wakeup-source; 236 }; 237}; 238 239&ap_i2c_ts { 240 touchscreen@4b { 241 compatible = "atmel,maxtouch"; 242 reg = <0x4b>; 243 pinctrl-names = "default"; 244 pinctrl-0 = <&touch_int_l>; 245 interrupt-parent = <&gpio3>; 246 interrupts = <13 IRQ_TYPE_LEVEL_LOW>; 247 }; 248}; 249 250&ppvar_bigcpu_pwm { 251 regulator-min-microvolt = <798674>; 252 regulator-max-microvolt = <1302172>; 253}; 254 255&ppvar_bigcpu { 256 regulator-min-microvolt = <798674>; 257 regulator-max-microvolt = <1302172>; 258 ctrl-voltage-range = <798674 1302172>; 259}; 260 261&ppvar_litcpu_pwm { 262 regulator-min-microvolt = <799065>; 263 regulator-max-microvolt = <1303738>; 264}; 265 266&ppvar_litcpu { 267 regulator-min-microvolt = <799065>; 268 regulator-max-microvolt = <1303738>; 269 ctrl-voltage-range = <799065 1303738>; 270}; 271 272&ppvar_gpu_pwm { 273 regulator-min-microvolt = <785782>; 274 regulator-max-microvolt = <1217729>; 275}; 276 277&ppvar_gpu { 278 regulator-min-microvolt = <785782>; 279 regulator-max-microvolt = <1217729>; 280 ctrl-voltage-range = <785782 1217729>; 281}; 282 283&ppvar_centerlogic_pwm { 284 regulator-min-microvolt = <800069>; 285 regulator-max-microvolt = <1049692>; 286}; 287 288&ppvar_centerlogic { 289 regulator-min-microvolt = <800069>; 290 regulator-max-microvolt = <1049692>; 291 ctrl-voltage-range = <800069 1049692>; 292}; 293 294&saradc { 295 status = "okay"; 296 vref-supply = <&pp1800_ap_io>; 297}; 298 299&mvl_wifi { 300 marvell,wakeup-pin = <14>; /* GPIO_14 on Marvell */ 301}; 302 303&pinctrl { 304 digitizer { 305 /* Has external pullup */ 306 cpu1_dig_irq_l: cpu1-dig-irq-l { 307 rockchip,pins = <2 RK_PA4 RK_FUNC_GPIO &pcfg_pull_none>; 308 }; 309 310 /* Has external pullup */ 311 cpu1_dig_pdct_l: cpu1-dig-pdct-l { 312 rockchip,pins = <2 RK_PA5 RK_FUNC_GPIO &pcfg_pull_none>; 313 }; 314 }; 315 316 discrete-regulators { 317 cpu3_pen_pwr_en: cpu3-pen-pwr-en { 318 rockchip,pins = <4 RK_PD6 RK_FUNC_GPIO &pcfg_pull_none>; 319 }; 320 }; 321 322 pen { 323 cpu1_pen_eject: cpu1-pen-eject { 324 rockchip,pins = <0 RK_PB5 RK_FUNC_GPIO &pcfg_pull_up>; 325 }; 326 }; 327}; 328