exynos5800-peach-pi.dts 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855
  1. /*
  2. * Google Peach Pi Rev 10+ board device tree source
  3. *
  4. * Copyright (c) 2014 Google, Inc
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. */
  10. /dts-v1/;
  11. #include <dt-bindings/input/input.h>
  12. #include <dt-bindings/gpio/gpio.h>
  13. #include <dt-bindings/interrupt-controller/irq.h>
  14. #include "exynos5800.dtsi"
  15. / {
  16. model = "Google Peach Pi Rev 10+";
  17. compatible = "google,pi-rev16",
  18. "google,pi-rev15", "google,pi-rev14",
  19. "google,pi-rev13", "google,pi-rev12",
  20. "google,pi-rev11", "google,pi-rev10",
  21. "google,pi", "google,peach", "samsung,exynos5800",
  22. "samsung,exynos5";
  23. aliases {
  24. /* Assign 20 so we don't get confused w/ builtin ones */
  25. i2c20 = "/spi@12d40000/cros-ec@0/i2c-tunnel";
  26. };
  27. backlight: backlight {
  28. compatible = "pwm-backlight";
  29. pwms = <&pwm 0 1000000 0>;
  30. brightness-levels = <0 100 500 1000 1500 2000 2500 2800>;
  31. default-brightness-level = <7>;
  32. enable-gpios = <&gpx2 2 GPIO_ACTIVE_HIGH>;
  33. power-supply = <&tps65090_fet1>;
  34. pinctrl-0 = <&pwm0_out>;
  35. pinctrl-names = "default";
  36. };
  37. fixed-rate-clocks {
  38. oscclk {
  39. compatible = "samsung,exynos5420-oscclk";
  40. clock-frequency = <24000000>;
  41. };
  42. };
  43. gpio-keys {
  44. compatible = "gpio-keys";
  45. pinctrl-names = "default";
  46. pinctrl-0 = <&power_key_irq>;
  47. power {
  48. label = "Power";
  49. gpios = <&gpx1 2 GPIO_ACTIVE_LOW>;
  50. linux,code = <KEY_POWER>;
  51. gpio-key,wakeup;
  52. };
  53. };
  54. memory {
  55. reg = <0x20000000 0x80000000>;
  56. };
  57. sound {
  58. compatible = "google,snow-audio-max98091";
  59. samsung,model = "Peach-Pi-I2S-MAX98091";
  60. samsung,i2s-controller = <&i2s0>;
  61. samsung,audio-codec = <&max98091>;
  62. };
  63. usb300_vbus_reg: regulator-usb300 {
  64. compatible = "regulator-fixed";
  65. regulator-name = "P5.0V_USB3CON0";
  66. regulator-min-microvolt = <5000000>;
  67. regulator-max-microvolt = <5000000>;
  68. gpio = <&gph0 0 0>;
  69. pinctrl-names = "default";
  70. pinctrl-0 = <&usb300_vbus_en>;
  71. enable-active-high;
  72. };
  73. usb301_vbus_reg: regulator-usb301 {
  74. compatible = "regulator-fixed";
  75. regulator-name = "P5.0V_USB3CON1";
  76. regulator-min-microvolt = <5000000>;
  77. regulator-max-microvolt = <5000000>;
  78. gpio = <&gph0 1 0>;
  79. pinctrl-names = "default";
  80. pinctrl-0 = <&usb301_vbus_en>;
  81. enable-active-high;
  82. };
  83. vbat: fixed-regulator {
  84. compatible = "regulator-fixed";
  85. regulator-name = "vbat-supply";
  86. regulator-boot-on;
  87. regulator-always-on;
  88. };
  89. panel: panel {
  90. compatible = "auo,b133htn01";
  91. power-supply = <&tps65090_fet6>;
  92. backlight = <&backlight>;
  93. };
  94. };
  95. &adc {
  96. status = "okay";
  97. vdd-supply = <&ldo9_reg>;
  98. };
  99. &dp {
  100. status = "okay";
  101. pinctrl-names = "default";
  102. pinctrl-0 = <&dp_hpd_gpio>;
  103. samsung,color-space = <0>;
  104. samsung,dynamic-range = <0>;
  105. samsung,ycbcr-coeff = <0>;
  106. samsung,color-depth = <1>;
  107. samsung,link-rate = <0x0a>;
  108. samsung,lane-count = <2>;
  109. samsung,hpd-gpio = <&gpx2 6 0>;
  110. panel = <&panel>;
  111. };
  112. &fimd {
  113. status = "okay";
  114. samsung,invert-vclk;
  115. };
  116. &hdmi {
  117. status = "okay";
  118. hpd-gpio = <&gpx3 7 GPIO_ACTIVE_HIGH>;
  119. pinctrl-names = "default";
  120. pinctrl-0 = <&hdmi_hpd_irq>;
  121. ddc = <&i2c_2>;
  122. hdmi-en-supply = <&tps65090_fet7>;
  123. vdd-supply = <&ldo8_reg>;
  124. vdd_osc-supply = <&ldo10_reg>;
  125. vdd_pll-supply = <&ldo8_reg>;
  126. };
  127. &hsi2c_4 {
  128. status = "okay";
  129. clock-frequency = <400000>;
  130. max77802-pmic@9 {
  131. compatible = "maxim,max77802";
  132. interrupt-parent = <&gpx3>;
  133. interrupts = <1 IRQ_TYPE_NONE>;
  134. pinctrl-names = "default";
  135. pinctrl-0 = <&max77802_irq>, <&pmic_selb>,
  136. <&pmic_dvs_1>, <&pmic_dvs_2>, <&pmic_dvs_3>;
  137. wakeup-source;
  138. reg = <0x9>;
  139. #clock-cells = <1>;
  140. inb1-supply = <&tps65090_dcdc2>;
  141. inb2-supply = <&tps65090_dcdc1>;
  142. inb3-supply = <&tps65090_dcdc2>;
  143. inb4-supply = <&tps65090_dcdc2>;
  144. inb5-supply = <&tps65090_dcdc1>;
  145. inb6-supply = <&tps65090_dcdc2>;
  146. inb7-supply = <&tps65090_dcdc1>;
  147. inb8-supply = <&tps65090_dcdc1>;
  148. inb9-supply = <&tps65090_dcdc1>;
  149. inb10-supply = <&tps65090_dcdc1>;
  150. inl1-supply = <&buck5_reg>;
  151. inl2-supply = <&buck7_reg>;
  152. inl3-supply = <&buck9_reg>;
  153. inl4-supply = <&buck9_reg>;
  154. inl5-supply = <&buck9_reg>;
  155. inl6-supply = <&tps65090_dcdc2>;
  156. inl7-supply = <&buck9_reg>;
  157. inl9-supply = <&tps65090_dcdc2>;
  158. inl10-supply = <&buck7_reg>;
  159. regulators {
  160. buck1_reg: BUCK1 {
  161. regulator-name = "vdd_mif";
  162. regulator-min-microvolt = <800000>;
  163. regulator-max-microvolt = <1300000>;
  164. regulator-always-on;
  165. regulator-boot-on;
  166. regulator-ramp-delay = <12500>;
  167. };
  168. buck2_reg: BUCK2 {
  169. regulator-name = "vdd_arm";
  170. regulator-min-microvolt = <800000>;
  171. regulator-max-microvolt = <1500000>;
  172. regulator-always-on;
  173. regulator-boot-on;
  174. regulator-ramp-delay = <12500>;
  175. };
  176. buck3_reg: BUCK3 {
  177. regulator-name = "vdd_int";
  178. regulator-min-microvolt = <800000>;
  179. regulator-max-microvolt = <1400000>;
  180. regulator-always-on;
  181. regulator-boot-on;
  182. regulator-ramp-delay = <12500>;
  183. };
  184. buck4_reg: BUCK4 {
  185. regulator-name = "vdd_g3d";
  186. regulator-min-microvolt = <700000>;
  187. regulator-max-microvolt = <1400000>;
  188. regulator-always-on;
  189. regulator-boot-on;
  190. regulator-ramp-delay = <12500>;
  191. };
  192. buck5_reg: BUCK5 {
  193. regulator-name = "vdd_1v2";
  194. regulator-min-microvolt = <1200000>;
  195. regulator-max-microvolt = <1200000>;
  196. regulator-always-on;
  197. regulator-boot-on;
  198. };
  199. buck6_reg: BUCK6 {
  200. regulator-name = "vdd_kfc";
  201. regulator-min-microvolt = <800000>;
  202. regulator-max-microvolt = <1500000>;
  203. regulator-always-on;
  204. regulator-boot-on;
  205. regulator-ramp-delay = <12500>;
  206. };
  207. buck7_reg: BUCK7 {
  208. regulator-name = "vdd_1v35";
  209. regulator-min-microvolt = <1350000>;
  210. regulator-max-microvolt = <1350000>;
  211. regulator-always-on;
  212. regulator-boot-on;
  213. };
  214. buck8_reg: BUCK8 {
  215. regulator-name = "vdd_emmc";
  216. regulator-min-microvolt = <2850000>;
  217. regulator-max-microvolt = <2850000>;
  218. regulator-always-on;
  219. regulator-boot-on;
  220. };
  221. buck9_reg: BUCK9 {
  222. regulator-name = "vdd_2v";
  223. regulator-min-microvolt = <2000000>;
  224. regulator-max-microvolt = <2000000>;
  225. regulator-always-on;
  226. regulator-boot-on;
  227. };
  228. buck10_reg: BUCK10 {
  229. regulator-name = "vdd_1v8";
  230. regulator-min-microvolt = <1800000>;
  231. regulator-max-microvolt = <1800000>;
  232. regulator-always-on;
  233. regulator-boot-on;
  234. };
  235. ldo1_reg: LDO1 {
  236. regulator-name = "vdd_1v0";
  237. regulator-min-microvolt = <1000000>;
  238. regulator-max-microvolt = <1000000>;
  239. regulator-always-on;
  240. };
  241. ldo2_reg: LDO2 {
  242. regulator-name = "vdd_1v2_2";
  243. regulator-min-microvolt = <1200000>;
  244. regulator-max-microvolt = <1200000>;
  245. };
  246. ldo3_reg: LDO3 {
  247. regulator-name = "vdd_1v8_3";
  248. regulator-min-microvolt = <1800000>;
  249. regulator-max-microvolt = <1800000>;
  250. regulator-always-on;
  251. };
  252. vqmmc_sdcard: ldo4_reg: LDO4 {
  253. regulator-name = "vdd_sd";
  254. regulator-min-microvolt = <1800000>;
  255. regulator-max-microvolt = <2800000>;
  256. regulator-always-on;
  257. };
  258. ldo5_reg: LDO5 {
  259. regulator-name = "vdd_1v8_5";
  260. regulator-min-microvolt = <1800000>;
  261. regulator-max-microvolt = <1800000>;
  262. regulator-always-on;
  263. };
  264. ldo6_reg: LDO6 {
  265. regulator-name = "vdd_1v8_6";
  266. regulator-min-microvolt = <1800000>;
  267. regulator-max-microvolt = <1800000>;
  268. regulator-always-on;
  269. };
  270. ldo7_reg: LDO7 {
  271. regulator-name = "vdd_1v8_7";
  272. regulator-min-microvolt = <1800000>;
  273. regulator-max-microvolt = <1800000>;
  274. };
  275. ldo8_reg: LDO8 {
  276. regulator-name = "vdd_ldo8";
  277. regulator-min-microvolt = <1000000>;
  278. regulator-max-microvolt = <1000000>;
  279. regulator-always-on;
  280. };
  281. ldo9_reg: LDO9 {
  282. regulator-name = "vdd_ldo9";
  283. regulator-min-microvolt = <1800000>;
  284. regulator-max-microvolt = <1800000>;
  285. regulator-always-on;
  286. };
  287. ldo10_reg: LDO10 {
  288. regulator-name = "vdd_ldo10";
  289. regulator-min-microvolt = <1800000>;
  290. regulator-max-microvolt = <1800000>;
  291. regulator-always-on;
  292. };
  293. ldo11_reg: LDO11 {
  294. regulator-name = "vdd_ldo11";
  295. regulator-min-microvolt = <1800000>;
  296. regulator-max-microvolt = <1800000>;
  297. regulator-always-on;
  298. };
  299. ldo12_reg: LDO12 {
  300. regulator-name = "vdd_ldo12";
  301. regulator-min-microvolt = <3000000>;
  302. regulator-max-microvolt = <3000000>;
  303. regulator-always-on;
  304. };
  305. ldo13_reg: LDO13 {
  306. regulator-name = "vdd_ldo13";
  307. regulator-min-microvolt = <1800000>;
  308. regulator-max-microvolt = <1800000>;
  309. regulator-always-on;
  310. };
  311. ldo14_reg: LDO14 {
  312. regulator-name = "vdd_ldo14";
  313. regulator-min-microvolt = <1800000>;
  314. regulator-max-microvolt = <1800000>;
  315. regulator-always-on;
  316. };
  317. ldo15_reg: LDO15 {
  318. regulator-name = "vdd_ldo15";
  319. regulator-min-microvolt = <1000000>;
  320. regulator-max-microvolt = <1000000>;
  321. regulator-always-on;
  322. };
  323. ldo17_reg: LDO17 {
  324. regulator-name = "vdd_g3ds";
  325. regulator-min-microvolt = <900000>;
  326. regulator-max-microvolt = <1400000>;
  327. regulator-always-on;
  328. };
  329. ldo18_reg: LDO18 {
  330. regulator-name = "ldo_18";
  331. regulator-min-microvolt = <1800000>;
  332. regulator-max-microvolt = <1800000>;
  333. };
  334. ldo19_reg: LDO19 {
  335. regulator-name = "ldo_19";
  336. regulator-min-microvolt = <1800000>;
  337. regulator-max-microvolt = <1800000>;
  338. };
  339. ldo20_reg: LDO20 {
  340. regulator-name = "ldo_20";
  341. regulator-min-microvolt = <1800000>;
  342. regulator-max-microvolt = <1800000>;
  343. regulator-always-on;
  344. };
  345. ldo21_reg: LDO21 {
  346. regulator-name = "ldo_21";
  347. regulator-min-microvolt = <2800000>;
  348. regulator-max-microvolt = <2800000>;
  349. };
  350. ldo23_reg: LDO23 {
  351. regulator-name = "ldo_23";
  352. regulator-min-microvolt = <3300000>;
  353. regulator-max-microvolt = <3300000>;
  354. };
  355. ldo24_reg: LDO24 {
  356. regulator-name = "ldo_24";
  357. regulator-min-microvolt = <2800000>;
  358. regulator-max-microvolt = <2800000>;
  359. };
  360. ldo25_reg: LDO25 {
  361. regulator-name = "ldo_25";
  362. regulator-min-microvolt = <3300000>;
  363. regulator-max-microvolt = <3300000>;
  364. };
  365. ldo26_reg: LDO26 {
  366. regulator-name = "ldo_26";
  367. regulator-min-microvolt = <1200000>;
  368. regulator-max-microvolt = <1200000>;
  369. };
  370. ldo27_reg: LDO27 {
  371. regulator-name = "ldo_27";
  372. regulator-min-microvolt = <1200000>;
  373. regulator-max-microvolt = <1200000>;
  374. };
  375. ldo28_reg: LDO28 {
  376. regulator-name = "ldo_28";
  377. regulator-min-microvolt = <1800000>;
  378. regulator-max-microvolt = <1800000>;
  379. };
  380. ldo29_reg: LDO29 {
  381. regulator-name = "ldo_29";
  382. regulator-min-microvolt = <1800000>;
  383. regulator-max-microvolt = <1800000>;
  384. };
  385. ldo30_reg: LDO30 {
  386. regulator-name = "vdd_mifs";
  387. regulator-min-microvolt = <1000000>;
  388. regulator-max-microvolt = <1000000>;
  389. regulator-always-on;
  390. };
  391. ldo32_reg: LDO32 {
  392. regulator-name = "ldo_32";
  393. regulator-min-microvolt = <3000000>;
  394. regulator-max-microvolt = <3000000>;
  395. };
  396. ldo33_reg: LDO33 {
  397. regulator-name = "ldo_33";
  398. regulator-min-microvolt = <2800000>;
  399. regulator-max-microvolt = <2800000>;
  400. };
  401. ldo34_reg: LDO34 {
  402. regulator-name = "ldo_34";
  403. regulator-min-microvolt = <3000000>;
  404. regulator-max-microvolt = <3000000>;
  405. };
  406. ldo35_reg: LDO35 {
  407. regulator-name = "ldo_35";
  408. regulator-min-microvolt = <1200000>;
  409. regulator-max-microvolt = <1200000>;
  410. };
  411. };
  412. };
  413. };
  414. &hsi2c_7 {
  415. status = "okay";
  416. clock-frequency = <400000>;
  417. max98091: codec@10 {
  418. compatible = "maxim,max98091";
  419. reg = <0x10>;
  420. interrupts = <2 0>;
  421. interrupt-parent = <&gpx0>;
  422. pinctrl-names = "default";
  423. pinctrl-0 = <&max98091_irq>;
  424. };
  425. light-sensor@44 {
  426. compatible = "isil,isl29018";
  427. reg = <0x44>;
  428. vcc-supply = <&tps65090_fet5>;
  429. };
  430. };
  431. &hsi2c_8 {
  432. status = "okay";
  433. clock-frequency = <333000>;
  434. /* Atmel mXT540S */
  435. trackpad@4b {
  436. compatible = "atmel,maxtouch";
  437. reg = <0x4b>;
  438. interrupt-parent = <&gpx1>;
  439. interrupts = <1 IRQ_TYPE_EDGE_FALLING>;
  440. wakeup-source;
  441. pinctrl-names = "default";
  442. pinctrl-0 = <&trackpad_irq>;
  443. linux,gpio-keymap = <KEY_RESERVED
  444. KEY_RESERVED
  445. KEY_RESERVED /* GPIO 0 */
  446. KEY_RESERVED /* GPIO 1 */
  447. BTN_LEFT /* GPIO 2 */
  448. KEY_RESERVED>; /* GPIO 3 */
  449. };
  450. };
  451. &hsi2c_9 {
  452. status = "okay";
  453. clock-frequency = <400000>;
  454. tpm@20 {
  455. compatible = "infineon,slb9645tt";
  456. reg = <0x20>;
  457. /* Unused irq; but still need to configure the pins */
  458. pinctrl-names = "default";
  459. pinctrl-0 = <&tpm_irq>;
  460. };
  461. };
  462. &i2c_2 {
  463. status = "okay";
  464. samsung,i2c-sda-delay = <100>;
  465. samsung,i2c-max-bus-freq = <66000>;
  466. samsung,i2c-slave-addr = <0x50>;
  467. };
  468. &i2s0 {
  469. status = "okay";
  470. };
  471. &mmc_0 {
  472. status = "okay";
  473. num-slots = <1>;
  474. broken-cd;
  475. caps2-mmc-hs200-1_8v;
  476. cap-mmc-highspeed;
  477. non-removable;
  478. card-detect-delay = <200>;
  479. clock-frequency = <400000000>;
  480. samsung,dw-mshc-ciu-div = <3>;
  481. samsung,dw-mshc-sdr-timing = <0 4>;
  482. samsung,dw-mshc-ddr-timing = <0 2>;
  483. pinctrl-names = "default";
  484. pinctrl-0 = <&sd0_clk &sd0_cmd &sd0_bus4 &sd0_bus8>;
  485. bus-width = <8>;
  486. };
  487. &mmc_2 {
  488. status = "okay";
  489. num-slots = <1>;
  490. cap-sd-highspeed;
  491. card-detect-delay = <200>;
  492. clock-frequency = <400000000>;
  493. samsung,dw-mshc-ciu-div = <3>;
  494. samsung,dw-mshc-sdr-timing = <2 3>;
  495. samsung,dw-mshc-ddr-timing = <1 2>;
  496. pinctrl-names = "default";
  497. pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_cd &sd2_bus4>;
  498. bus-width = <4>;
  499. };
  500. &pinctrl_0 {
  501. pinctrl-names = "default";
  502. pinctrl-0 = <&mask_tpm_reset>;
  503. max98091_irq: max98091-irq {
  504. samsung,pins = "gpx0-2";
  505. samsung,pin-function = <0>;
  506. samsung,pin-pud = <0>;
  507. samsung,pin-drv = <0>;
  508. };
  509. /* We need GPX0_6 to be low at sleep time; just keep it low always */
  510. mask_tpm_reset: mask-tpm-reset {
  511. samsung,pins = "gpx0-6";
  512. samsung,pin-function = <1>;
  513. samsung,pin-pud = <0>;
  514. samsung,pin-drv = <0>;
  515. samsung,pin-val = <0>;
  516. };
  517. tpm_irq: tpm-irq {
  518. samsung,pins = "gpx1-0";
  519. samsung,pin-function = <0>;
  520. samsung,pin-pud = <0>;
  521. samsung,pin-drv = <0>;
  522. };
  523. trackpad_irq: trackpad-irq {
  524. samsung,pins = "gpx1-1";
  525. samsung,pin-function = <0xf>;
  526. samsung,pin-pud = <0>;
  527. samsung,pin-drv = <0>;
  528. };
  529. power_key_irq: power-key-irq {
  530. samsung,pins = "gpx1-2";
  531. samsung,pin-function = <0>;
  532. samsung,pin-pud = <0>;
  533. samsung,pin-drv = <0>;
  534. };
  535. ec_irq: ec-irq {
  536. samsung,pins = "gpx1-5";
  537. samsung,pin-function = <0>;
  538. samsung,pin-pud = <0>;
  539. samsung,pin-drv = <0>;
  540. };
  541. tps65090_irq: tps65090-irq {
  542. samsung,pins = "gpx2-5";
  543. samsung,pin-function = <0>;
  544. samsung,pin-pud = <0>;
  545. samsung,pin-drv = <0>;
  546. };
  547. dp_hpd_gpio: dp_hpd_gpio {
  548. samsung,pins = "gpx2-6";
  549. samsung,pin-function = <0>;
  550. samsung,pin-pud = <3>;
  551. samsung,pin-drv = <0>;
  552. };
  553. max77802_irq: max77802-irq {
  554. samsung,pins = "gpx3-1";
  555. samsung,pin-function = <0>;
  556. samsung,pin-pud = <0>;
  557. samsung,pin-drv = <0>;
  558. };
  559. hdmi_hpd_irq: hdmi-hpd-irq {
  560. samsung,pins = "gpx3-7";
  561. samsung,pin-function = <0>;
  562. samsung,pin-pud = <1>;
  563. samsung,pin-drv = <0>;
  564. };
  565. pmic_dvs_1: pmic-dvs-1 {
  566. samsung,pins = "gpy7-6";
  567. samsung,pin-function = <1>;
  568. samsung,pin-pud = <0>;
  569. samsung,pin-drv = <0>;
  570. };
  571. };
  572. &pinctrl_2 {
  573. pmic_dvs_2: pmic-dvs-2 {
  574. samsung,pins = "gpj4-2";
  575. samsung,pin-function = <1>;
  576. samsung,pin-pud = <0>;
  577. samsung,pin-drv = <0>;
  578. };
  579. pmic_dvs_3: pmic-dvs-3 {
  580. samsung,pins = "gpj4-3";
  581. samsung,pin-function = <1>;
  582. samsung,pin-pud = <0>;
  583. samsung,pin-drv = <0>;
  584. };
  585. };
  586. &pinctrl_3 {
  587. /* Drive SPI lines at x2 for better integrity */
  588. spi2-bus {
  589. samsung,pin-drv = <2>;
  590. };
  591. /* Drive SPI chip select at x2 for better integrity */
  592. ec_spi_cs: ec-spi-cs {
  593. samsung,pins = "gpb1-2";
  594. samsung,pin-function = <1>;
  595. samsung,pin-pud = <0>;
  596. samsung,pin-drv = <2>;
  597. };
  598. usb300_vbus_en: usb300-vbus-en {
  599. samsung,pins = "gph0-0";
  600. samsung,pin-function = <1>;
  601. samsung,pin-pud = <0>;
  602. samsung,pin-drv = <0>;
  603. };
  604. usb301_vbus_en: usb301-vbus-en {
  605. samsung,pins = "gph0-1";
  606. samsung,pin-function = <1>;
  607. samsung,pin-pud = <0>;
  608. samsung,pin-drv = <0>;
  609. };
  610. pmic_selb: pmic-selb {
  611. samsung,pins = "gph0-2", "gph0-3", "gph0-4", "gph0-5",
  612. "gph0-6";
  613. samsung,pin-function = <1>;
  614. samsung,pin-pud = <0>;
  615. samsung,pin-drv = <0>;
  616. };
  617. };
  618. &rtc {
  619. status = "okay";
  620. };
  621. &spi_2 {
  622. status = "okay";
  623. num-cs = <1>;
  624. samsung,spi-src-clk = <0>;
  625. cs-gpios = <&gpb1 2 0>;
  626. cros_ec: cros-ec@0 {
  627. compatible = "google,cros-ec-spi";
  628. interrupt-parent = <&gpx1>;
  629. interrupts = <5 0>;
  630. pinctrl-names = "default";
  631. pinctrl-0 = <&ec_spi_cs &ec_irq>;
  632. reg = <0>;
  633. spi-max-frequency = <3125000>;
  634. controller-data {
  635. samsung,spi-feedback-delay = <1>;
  636. };
  637. i2c-tunnel {
  638. compatible = "google,cros-ec-i2c-tunnel";
  639. #address-cells = <1>;
  640. #size-cells = <0>;
  641. google,remote-bus = <0>;
  642. battery: sbs-battery@b {
  643. compatible = "sbs,sbs-battery";
  644. reg = <0xb>;
  645. sbs,poll-retry-count = <1>;
  646. sbs,i2c-retry-count = <2>;
  647. };
  648. power-regulator@48 {
  649. compatible = "ti,tps65090";
  650. reg = <0x48>;
  651. /*
  652. * Config irq to disable internal pulls
  653. * even though we run in polling mode.
  654. */
  655. pinctrl-names = "default";
  656. pinctrl-0 = <&tps65090_irq>;
  657. vsys1-supply = <&vbat>;
  658. vsys2-supply = <&vbat>;
  659. vsys3-supply = <&vbat>;
  660. infet1-supply = <&vbat>;
  661. infet2-supply = <&tps65090_dcdc1>;
  662. infet3-supply = <&tps65090_dcdc2>;
  663. infet4-supply = <&tps65090_dcdc2>;
  664. infet5-supply = <&tps65090_dcdc2>;
  665. infet6-supply = <&tps65090_dcdc2>;
  666. infet7-supply = <&tps65090_dcdc1>;
  667. vsys-l1-supply = <&vbat>;
  668. vsys-l2-supply = <&vbat>;
  669. regulators {
  670. tps65090_dcdc1: dcdc1 {
  671. ti,enable-ext-control;
  672. };
  673. tps65090_dcdc2: dcdc2 {
  674. ti,enable-ext-control;
  675. };
  676. tps65090_dcdc3: dcdc3 {
  677. ti,enable-ext-control;
  678. };
  679. tps65090_fet1: fet1 {
  680. regulator-name = "vcd_led";
  681. };
  682. tps65090_fet2: fet2 {
  683. regulator-name = "video_mid";
  684. regulator-always-on;
  685. };
  686. tps65090_fet3: fet3 {
  687. regulator-name = "wwan_r";
  688. regulator-always-on;
  689. };
  690. tps65090_fet4: fet4 {
  691. regulator-name = "sdcard";
  692. regulator-always-on;
  693. };
  694. tps65090_fet5: fet5 {
  695. regulator-name = "camout";
  696. };
  697. tps65090_fet6: fet6 {
  698. regulator-name = "lcd_vdd";
  699. };
  700. tps65090_fet7: fet7 {
  701. regulator-name = "video_mid_1a";
  702. regulator-always-on;
  703. };
  704. tps65090_ldo1: ldo1 {
  705. };
  706. tps65090_ldo2: ldo2 {
  707. };
  708. };
  709. charger {
  710. compatible = "ti,tps65090-charger";
  711. };
  712. };
  713. };
  714. };
  715. };
  716. &uart_3 {
  717. status = "okay";
  718. };
  719. &usbdrd_dwc3_0 {
  720. dr_mode = "host";
  721. };
  722. &usbdrd_dwc3_1 {
  723. dr_mode = "host";
  724. };
  725. &usbdrd_phy0 {
  726. vbus-supply = <&usb300_vbus_reg>;
  727. };
  728. &usbdrd_phy1 {
  729. vbus-supply = <&usb301_vbus_reg>;
  730. };
  731. /*
  732. * Use longest HW watchdog in SoC (32 seconds) since the hardware
  733. * watchdog provides no debugging information (compared to soft/hard
  734. * lockup detectors) and so should be last resort.
  735. */
  736. &watchdog {
  737. timeout-sec = <32>;
  738. };
  739. #include "cros-ec-keyboard.dtsi"
  740. #include "cros-adc-thermistors.dtsi"