msm8996-xiaomi-gemini.dts 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475
  1. // SPDX-License-Identifier: BSD-3-Clause
  2. /*
  3. * Copyright (c) 2021, Raffaele Tranquillini <[email protected]>
  4. */
  5. /dts-v1/;
  6. #include "msm8996-xiaomi-common.dtsi"
  7. #include <dt-bindings/sound/qcom,q6afe.h>
  8. #include <dt-bindings/sound/qcom,q6asm.h>
  9. #include <dt-bindings/sound/qcom,wcd9335.h>
  10. #include <dt-bindings/input/ti-drv260x.h>
  11. / {
  12. model = "Xiaomi Mi 5";
  13. compatible = "xiaomi,gemini", "qcom,msm8996";
  14. chassis-type = "handset";
  15. qcom,msm-id = <246 0x30001>;
  16. qcom,pmic-id = <0x20009 0x2000a 0x00 0x00>;
  17. qcom,board-id = <31 0>;
  18. clocks {
  19. divclk2_haptics: divclk2 {
  20. compatible = "fixed-clock";
  21. #clock-cells = <0>;
  22. clock-frequency = <32768>;
  23. clock-output-names = "divclk2";
  24. pinctrl-names = "default";
  25. pinctrl-0 = <&divclk2_pin_a>;
  26. };
  27. };
  28. };
  29. &adsp_pil {
  30. firmware-name = "qcom/msm8996/gemini/adsp.mbn";
  31. };
  32. &blsp2_i2c3 {
  33. haptics: drv2604@5a {
  34. compatible = "ti,drv2604";
  35. reg = <0x5a>;
  36. enable-gpio = <&tlmm 93 0x00>;
  37. mode = <DRV260X_LRA_MODE>;
  38. library-sel = <DRV260X_LIB_LRA>;
  39. pinctrl-names = "default","sleep";
  40. pinctrl-0 = <&vibrator_default>;
  41. pinctrl-1 = <&vibrator_sleep>;
  42. };
  43. lp5562@30 {
  44. compatible = "ti,lp5562";
  45. reg = <0x30>;
  46. #address-cells = <1>;
  47. #size-cells = <0>;
  48. enable-gpio = <&pm8994_gpios 7 1>;
  49. clock-mode = /bits/8 <2>;
  50. label = "button-backlight";
  51. led@0 {
  52. reg = <0>;
  53. chan-name = "button-backlight";
  54. led-cur = /bits/ 8 <0x32>;
  55. max-cur = /bits/ 8 <0xC8>;
  56. };
  57. led@1 {
  58. reg = <0>;
  59. chan-name = "button-backlight1";
  60. led-cur = /bits/ 8 <0x32>;
  61. max-cur = /bits/ 8 <0xC8>;
  62. };
  63. };
  64. };
  65. &blsp2_i2c6 {
  66. synaptics@20 {
  67. compatible = "syna,rmi4-i2c";
  68. reg = <0x20>;
  69. #address-cells = <1>;
  70. #size-cells = <0>;
  71. interrupt-parent = <&tlmm>;
  72. interrupts = <125 IRQ_TYPE_LEVEL_LOW>;
  73. vio-supply = <&vreg_l6a_1p8>;
  74. vdd-supply = <&vdd_3v2_tp>;
  75. reset-gpios = <&tlmm 89 GPIO_ACTIVE_LOW>;
  76. pinctrl-names = "default", "sleep";
  77. pinctrl-0 = <&touchscreen_default>;
  78. pinctrl-1 = <&touchscreen_sleep>;
  79. };
  80. };
  81. &dsi0 {
  82. status = "okay";
  83. vdd-supply = <&vreg_l2a_1p25>;
  84. vdda-supply = <&vreg_l19a_3p3>;
  85. vddio-supply = <&vreg_l14a_1p8>;
  86. pinctrl-names = "default", "sleep";
  87. pinctrl-0 = <&mdss_dsi_default &mdss_te_default>;
  88. pinctrl-1 = <&mdss_dsi_sleep &mdss_te_sleep>;
  89. panel: panel@0 {
  90. compatible = "jdi,fhd-r63452";
  91. reg = <0>;
  92. reset-gpios = <&tlmm 8 GPIO_ACTIVE_LOW>;
  93. backlight = <&pmi8994_wled>;
  94. port {
  95. panel_in: endpoint {
  96. remote-endpoint = <&dsi0_out>;
  97. };
  98. };
  99. };
  100. };
  101. &dsi0_out {
  102. remote-endpoint = <&panel_in>;
  103. };
  104. &gpu {
  105. zap-shader {
  106. firmware-name = "qcom/msm8996/gemini/a530_zap.mbn";
  107. };
  108. };
  109. &pmi8994_wled {
  110. status = "okay";
  111. };
  112. &mss_pil {
  113. firmware-name = "qcom/msm8996/gemini/mba.mbn",
  114. "qcom/msm8996/gemini/modem.mbn";
  115. };
  116. &q6asmdai {
  117. dai@0 {
  118. reg = <0>;
  119. };
  120. dai@1 {
  121. reg = <1>;
  122. };
  123. dai@2 {
  124. reg = <2>;
  125. };
  126. };
  127. &slpi_pil {
  128. firmware-name = "qcom/msm8996/gemini/slpi.mbn";
  129. };
  130. &sound {
  131. compatible = "qcom,apq8096-sndcard";
  132. model = "gemini";
  133. audio-routing = "RX_BIAS", "MCLK",
  134. "MM_DL1", "MultiMedia1 Playback",
  135. "MM_DL2", "MultiMedia2 Playback",
  136. "MultiMedia3 Capture", "MM_UL3";
  137. mm1-dai-link {
  138. link-name = "MultiMedia1";
  139. cpu {
  140. sound-dai = <&q6asmdai MSM_FRONTEND_DAI_MULTIMEDIA1>;
  141. };
  142. };
  143. mm2-dai-link {
  144. link-name = "MultiMedia2";
  145. cpu {
  146. sound-dai = <&q6asmdai MSM_FRONTEND_DAI_MULTIMEDIA2>;
  147. };
  148. };
  149. mm3-dai-link {
  150. link-name = "MultiMedia3";
  151. cpu {
  152. sound-dai = <&q6asmdai MSM_FRONTEND_DAI_MULTIMEDIA3>;
  153. };
  154. };
  155. slim-dai-link {
  156. link-name = "SLIM Playback";
  157. cpu {
  158. sound-dai = <&q6afedai SLIMBUS_6_RX>;
  159. };
  160. platform {
  161. sound-dai = <&q6routing>;
  162. };
  163. codec {
  164. sound-dai = <&wcd9335 AIF4_PB>;
  165. };
  166. };
  167. slimcap-dai-link {
  168. link-name = "SLIM Capture";
  169. cpu {
  170. sound-dai = <&q6afedai SLIMBUS_0_TX>;
  171. };
  172. platform {
  173. sound-dai = <&q6routing>;
  174. };
  175. codec {
  176. sound-dai = <&wcd9335 AIF1_CAP>;
  177. };
  178. };
  179. };
  180. &venus {
  181. firmware-name = "qcom/msm8996/gemini/venus.mbn";
  182. };
  183. &rpm_requests {
  184. pm8994-regulators {
  185. vreg_l17a_2p8: l17 {
  186. regulator-name = "vreg_l17a_2p8";
  187. regulator-min-microvolt = <2500000>;
  188. regulator-max-microvolt = <2500000>;
  189. };
  190. vreg_l29a_2p7: l29 {
  191. regulator-name = "vreg_l29a_2p7";
  192. regulator-min-microvolt = <2800000>;
  193. regulator-max-microvolt = <2800000>;
  194. };
  195. };
  196. };
  197. &pm8994_gpios {
  198. gpio-line-names =
  199. "NC", /* GPIO_1 */
  200. "VOL_UP_N", /* GPIO_2 */
  201. "SPKR_ID", /* GPIO_3 */
  202. "PWM_HAPTICS", /* GPIO_4 */
  203. "INFARED_DRV", /* GPIO_5 */
  204. "NC", /* GPIO_6 */
  205. "KEYPAD_LED_EN", /* GPIO_7 */
  206. "WL_EN", /* GPIO_8 */
  207. "3P3_ENABLE", /* GPIO_9 */
  208. "FP_ID", /* GPIO_10 */
  209. "NC", /* GPIO_11 */
  210. "NC", /* GPIO_12 */
  211. "NC", /* GPIO_13 */
  212. "NC", /* GPIO_14 */
  213. "DIVCLK1_CDC", /* GPIO_15 */
  214. "DIVCLK2_HAPTICS", /* GPIO_16 */
  215. "NC", /* GPIO_17 */
  216. "32KHz_CLK_IN", /* GPIO_18 */
  217. "BT_EN", /* GPIO_19 */
  218. "PMIC_SLB", /* GPIO_20 */
  219. "UIM_BATT_ALARM", /* GPIO_21 */
  220. "NC"; /* GPIO_22 */
  221. divclk2_pin_a: divclk2-state {
  222. pins = "gpio16";
  223. function = PMIC_GPIO_FUNC_FUNC2;
  224. bias-disable;
  225. power-source = <PM8994_GPIO_S4>;
  226. };
  227. };
  228. &pm8994_mpps {
  229. gpio-line-names =
  230. "NC", /* MPP_1 */
  231. "CCI_TIMER1", /* MPP_2 */
  232. "PMIC_SLB", /* MPP_3 */
  233. "EXT_FET_WLED_PWR_EN_N",/* MPP_4 */
  234. "NC", /* MPP_5 */
  235. "NC", /* MPP_6 */
  236. "NC", /* MPP_7 */
  237. "NC"; /* MPP_8 */
  238. };
  239. &pmi8994_gpios {
  240. gpio-line-names =
  241. "NC", /* GPIO_1 */
  242. "SPKR_PA_RST", /* GPIO_2 */
  243. "NC", /* GPIO_3 */
  244. "NC", /* GPIO_4 */
  245. "NC", /* GPIO_5 */
  246. "NC", /* GPIO_6 */
  247. "NC", /* GPIO_7 */
  248. "NC", /* GPIO_8 */
  249. "NC", /* GPIO_9 */
  250. "NC"; /* GPIO_10 */
  251. };
  252. &tlmm {
  253. gpio-line-names =
  254. "ESE_SPI_MOSI", /* GPIO_0 */
  255. "ESE_SPI_MISO", /* GPIO_1 */
  256. "ERR_INT_N", /* GPIO_2 */
  257. "ESE_SPI_CLK", /* GPIO_3 */
  258. "MSM_UART_TX", /* GPIO_4 */
  259. "MSM_UART_RX", /* GPIO_5 */
  260. "NFC_I2C_SDA", /* GPIO_6 */
  261. "NFC_I2C_SCL", /* GPIO_7 */
  262. "LCD0_RESET_N", /* GPIO_8 */
  263. "NFC_IRQ", /* GPIO_9 */
  264. "LCD_TE", /* GPIO_10 */
  265. "LCD_ID_DET1", /* GPIO_11 */
  266. "NFC_DISABLE", /* GPIO_12 */
  267. "CAM_MCLK0", /* GPIO_13 */
  268. "NC", /* GPIO_14 */
  269. "CAM_MCLK2", /* GPIO_15 */
  270. "ESE_PWR_REQ", /* GPIO_16 */
  271. "CCI_I2C_SDA0", /* GPIO_17 */
  272. "CCI_I2C_SCL0", /* GPIO_18 */
  273. "CCI_I2C_SDA1", /* GPIO_19 */
  274. "CCI_I2C_SCL1", /* GPIO_20 */
  275. "NFC_DWL_REQ", /* GPIO_21 */
  276. "CCI_TIMER1", /* GPIO_22 */
  277. "WEBCAM1_RESET_N", /* GPIO_23 */
  278. "ESE_IRQ", /* GPIO_24 */
  279. "NC", /* GPIO_25 */
  280. "WEBCAM1_STANDBY", /* GPIO_26 */
  281. "NC", /* GPIO_27 */
  282. "NC", /* GPIO_28 */
  283. "NC", /* GPIO_29 */
  284. "CAM1_RST_N", /* GPIO_30 */
  285. "NC", /* GPIO_31 */
  286. "NC", /* GPIO_32 */
  287. "NC", /* GPIO_33 */
  288. "FP_DOME_SW", /* GPIO_34 */
  289. "PCI_E0_RST_N", /* GPIO_35 */
  290. "PCI_E0_CLKREQ_N", /* GPIO_36 */
  291. "PCI_E0_WAKE", /* GPIO_37 */
  292. "FM_INT_N", /* GPIO_38 */
  293. "FM_RESET_N", /* GPIO_39 */
  294. "NC", /* GPIO_40 */
  295. "QCA_UART_TXD", /* GPIO_41 */
  296. "QCA_UART_RXD", /* GPIO_42 */
  297. "QCA_UART_CTS", /* GPIO_43 */
  298. "QCA_UART_RTS", /* GPIO_44 */
  299. "MAWC_UART_TX", /* GPIO_45 */
  300. "MAWC_UART_RX", /* GPIO_46 */
  301. "NC", /* GPIO_47 */
  302. "NC", /* GPIO_48 */
  303. "AUDIO_SWITCH_EN", /* GPIO_49 */
  304. "FP_SPI_RST", /* GPIO_50 */
  305. "TYPEC_I2C_SDA", /* GPIO_51 */
  306. "TYPEC_I2C_SCL", /* GPIO_52 */
  307. "CODEC_INT2_N", /* GPIO_53 */
  308. "CODEC_INT1_N", /* GPIO_54 */
  309. "APPS_I2C7_SDA", /* GPIO_55 */
  310. "APPS_I2C7_SCL", /* GPIO_56 */
  311. "FORCE_USB_BOOT", /* GPIO_57 */
  312. "SPKR_I2S_BCK", /* GPIO_58 */
  313. "SPKR_I2S_WS", /* GPIO_59 */
  314. "SPKR_I2S_DOUT", /* GPIO_60 */
  315. "SPKR_I2S_DIN", /* GPIO_61 */
  316. "ESE_RSTN", /* GPIO_62 */
  317. "TYPEC_INT", /* GPIO_63 */
  318. "CODEC_RESET_N", /* GPIO_64 */
  319. "PCM_CLK", /* GPIO_65 */
  320. "PCM_SYNC", /* GPIO_66 */
  321. "PCM_DIN", /* GPIO_67 */
  322. "PCM_DOUT", /* GPIO_68 */
  323. "HIFI_CLK", /* GPIO_69 */
  324. "SLIMBUS_CLK", /* GPIO_70 */
  325. "SLIMBUS_DATA0", /* GPIO_71 */
  326. "SLIMBUS_DATA1", /* GPIO_72 */
  327. "LDO_5V_IN_EN", /* GPIO_73 */
  328. "NC", /* GPIO_74 */
  329. "FM_I2S_CLK", /* GPIO_75 */
  330. "FM_I2S_SYNC", /* GPIO_76 */
  331. "FM_I2S_DATA", /* GPIO_77 */
  332. "FM_STATUS", /* GPIO_78 */
  333. "NC", /* GPIO_79 */
  334. "SENSOR_RESET_N", /* GPIO_80 */
  335. "FP_SPI_MOSI", /* GPIO_81 */
  336. "FP_SPI_MISO", /* GPIO_82 */
  337. "FP_SPI_CS_N", /* GPIO_83 */
  338. "FP_SPI_CLK", /* GPIO_84 */
  339. "NC", /* GPIO_85 */
  340. "CAM_VDD_1P05_EN", /* GPIO_86 */
  341. "MSM_TS_I2C_SDA", /* GPIO_87 */
  342. "MSM_TS_I2C_SCL", /* GPIO_88 */
  343. "TS_RESOUT_N", /* GPIO_89 */
  344. "ESE_SPI_CS_N", /* GPIO_90 */
  345. "NC", /* GPIO_91 */
  346. "NC", /* GPIO_92 */
  347. "HAPTICS_EN", /* GPIO_93 */
  348. "NC", /* GPIO_94 */
  349. "NC", /* GPIO_95 */
  350. "NC", /* GPIO_96 */
  351. "NC", /* GPIO_97 */
  352. "GRFC_1", /* GPIO_98 */
  353. "NC", /* GPIO_99 */
  354. "GRFC_3", /* GPIO_100 */
  355. "GRFC_4", /* GPIO_101 */
  356. "NC", /* GPIO_102 */
  357. "NC", /* GPIO_103 */
  358. "GRFC_7", /* GPIO_104 */
  359. "UIM2_DATA", /* GPIO_105 */
  360. "UIM2_CLK", /* GPIO_106 */
  361. "UIM2_RESET", /* GPIO_107 */
  362. "UIM2_PRESENT", /* GPIO_108 */
  363. "UIM1_DATA", /* GPIO_109 */
  364. "UIM1_CLK", /* GPIO_110 */
  365. "UIM1_RESET", /* GPIO_111 */
  366. "UIM1_PRESENT", /* GPIO_112 */
  367. "UIM_BATT_ALARM", /* GPIO_113 */
  368. "GRFC_8", /* GPIO_114 */
  369. "GRFC_9", /* GPIO_115 */
  370. "TX_GTR_THRES", /* GPIO_116 */
  371. "ACCEL_INT", /* GPIO_117 */
  372. "GYRO_INT", /* GPIO_118 */
  373. "COMPASS_INT", /* GPIO_119 */
  374. "PROXIMITY_INT_N", /* GPIO_120 */
  375. "FP_IRQ", /* GPIO_121 */
  376. "NC", /* GPIO_122 */
  377. "HALL_INTR2", /* GPIO_123 */
  378. "HALL_INTR1", /* GPIO_124 */
  379. "TS_INT_N", /* GPIO_125 */
  380. "NC", /* GPIO_126 */
  381. "GRFC_11", /* GPIO_127 */
  382. "NC", /* GPIO_128 */
  383. "EXT_GPS_LNA_EN", /* GPIO_129 */
  384. "NC", /* GPIO_130 */
  385. "NC", /* GPIO_131 */
  386. "NC", /* GPIO_132 */
  387. "GRFC_14", /* GPIO_133 */
  388. "GSM_TX2_PHASE_D", /* GPIO_134 */
  389. "NC", /* GPIO_135 */
  390. "NC", /* GPIO_136 */
  391. "RFFE3_DATA", /* GPIO_137 */
  392. "RFFE3_CLK", /* GPIO_138 */
  393. "NC", /* GPIO_139 */
  394. "NC", /* GPIO_140 */
  395. "RFFE5_DATA", /* GPIO_141 */
  396. "RFFE5_CLK", /* GPIO_142 */
  397. "NC", /* GPIO_143 */
  398. "COEX_UART_TX", /* GPIO_144 */
  399. "COEX_UART_RX", /* GPIO_145 */
  400. "RFFE2_DATA", /* GPIO_146 */
  401. "RFFE2_CLK", /* GPIO_147 */
  402. "RFFE1_DATA", /* GPIO_148 */
  403. "RFFE1_CLK"; /* GPIO_149 */
  404. touchscreen_default: touchscreen_default {
  405. pins = "gpio89", "gpio125";
  406. function = "gpio";
  407. drive-strength = <10>;
  408. bias-pull-up;
  409. };
  410. touchscreen_sleep: touchscreen_sleep {
  411. pins = "gpio89", "gpio125";
  412. function = "gpio";
  413. drive-strength = <2>;
  414. bias-disable;
  415. };
  416. vibrator_default: vibrator_default {
  417. pins = "gpio93";
  418. function = "gpio";
  419. drive-strength = <8>;
  420. bias-pull-up;
  421. };
  422. vibrator_sleep: vibrator_sleep {
  423. pins = "gpio93";
  424. function = "gpio";
  425. drive-strength = <2>;
  426. bias-disable;
  427. };
  428. };