mt8173.dtsi 37 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382
  1. /*
  2. * Copyright (c) 2014 MediaTek Inc.
  3. * Author: Eddie Huang <eddie.huang@mediatek.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License version 2 as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. */
  13. #include <dt-bindings/clock/mt8173-clk.h>
  14. #include <dt-bindings/interrupt-controller/irq.h>
  15. #include <dt-bindings/interrupt-controller/arm-gic.h>
  16. #include <dt-bindings/memory/mt8173-larb-port.h>
  17. #include <dt-bindings/phy/phy.h>
  18. #include <dt-bindings/power/mt8173-power.h>
  19. #include <dt-bindings/reset/mt8173-resets.h>
  20. #include "mt8173-pinfunc.h"
  21. / {
  22. compatible = "mediatek,mt8173";
  23. interrupt-parent = <&sysirq>;
  24. #address-cells = <2>;
  25. #size-cells = <2>;
  26. aliases {
  27. ovl0 = &ovl0;
  28. ovl1 = &ovl1;
  29. rdma0 = &rdma0;
  30. rdma1 = &rdma1;
  31. rdma2 = &rdma2;
  32. wdma0 = &wdma0;
  33. wdma1 = &wdma1;
  34. color0 = &color0;
  35. color1 = &color1;
  36. split0 = &split0;
  37. split1 = &split1;
  38. dpi0 = &dpi0;
  39. dsi0 = &dsi0;
  40. dsi1 = &dsi1;
  41. mdp_rdma0 = &mdp_rdma0;
  42. mdp_rdma1 = &mdp_rdma1;
  43. mdp_rsz0 = &mdp_rsz0;
  44. mdp_rsz1 = &mdp_rsz1;
  45. mdp_rsz2 = &mdp_rsz2;
  46. mdp_wdma0 = &mdp_wdma0;
  47. mdp_wrot0 = &mdp_wrot0;
  48. mdp_wrot1 = &mdp_wrot1;
  49. };
  50. cluster0_opp: opp_table0 {
  51. compatible = "operating-points-v2";
  52. opp-shared;
  53. opp-507000000 {
  54. opp-hz = /bits/ 64 <507000000>;
  55. opp-microvolt = <859000>;
  56. };
  57. opp-702000000 {
  58. opp-hz = /bits/ 64 <702000000>;
  59. opp-microvolt = <908000>;
  60. };
  61. opp-1001000000 {
  62. opp-hz = /bits/ 64 <1001000000>;
  63. opp-microvolt = <983000>;
  64. };
  65. opp-1105000000 {
  66. opp-hz = /bits/ 64 <1105000000>;
  67. opp-microvolt = <1009000>;
  68. };
  69. opp-1209000000 {
  70. opp-hz = /bits/ 64 <1209000000>;
  71. opp-microvolt = <1034000>;
  72. };
  73. opp-1300000000 {
  74. opp-hz = /bits/ 64 <1300000000>;
  75. opp-microvolt = <1057000>;
  76. };
  77. opp-1508000000 {
  78. opp-hz = /bits/ 64 <1508000000>;
  79. opp-microvolt = <1109000>;
  80. };
  81. opp-1703000000 {
  82. opp-hz = /bits/ 64 <1703000000>;
  83. opp-microvolt = <1125000>;
  84. };
  85. };
  86. cluster1_opp: opp_table1 {
  87. compatible = "operating-points-v2";
  88. opp-shared;
  89. opp-507000000 {
  90. opp-hz = /bits/ 64 <507000000>;
  91. opp-microvolt = <828000>;
  92. };
  93. opp-702000000 {
  94. opp-hz = /bits/ 64 <702000000>;
  95. opp-microvolt = <867000>;
  96. };
  97. opp-1001000000 {
  98. opp-hz = /bits/ 64 <1001000000>;
  99. opp-microvolt = <927000>;
  100. };
  101. opp-1209000000 {
  102. opp-hz = /bits/ 64 <1209000000>;
  103. opp-microvolt = <968000>;
  104. };
  105. opp-1404000000 {
  106. opp-hz = /bits/ 64 <1404000000>;
  107. opp-microvolt = <1007000>;
  108. };
  109. opp-1612000000 {
  110. opp-hz = /bits/ 64 <1612000000>;
  111. opp-microvolt = <1049000>;
  112. };
  113. opp-1807000000 {
  114. opp-hz = /bits/ 64 <1807000000>;
  115. opp-microvolt = <1089000>;
  116. };
  117. opp-2106000000 {
  118. opp-hz = /bits/ 64 <2106000000>;
  119. opp-microvolt = <1125000>;
  120. };
  121. };
  122. cpus {
  123. #address-cells = <1>;
  124. #size-cells = <0>;
  125. cpu-map {
  126. cluster0 {
  127. core0 {
  128. cpu = <&cpu0>;
  129. };
  130. core1 {
  131. cpu = <&cpu1>;
  132. };
  133. };
  134. cluster1 {
  135. core0 {
  136. cpu = <&cpu2>;
  137. };
  138. core1 {
  139. cpu = <&cpu3>;
  140. };
  141. };
  142. };
  143. cpu0: cpu@0 {
  144. device_type = "cpu";
  145. compatible = "arm,cortex-a53";
  146. reg = <0x000>;
  147. enable-method = "psci";
  148. cpu-idle-states = <&CPU_SLEEP_0>;
  149. #cooling-cells = <2>;
  150. clocks = <&infracfg CLK_INFRA_CA53SEL>,
  151. <&apmixedsys CLK_APMIXED_MAINPLL>;
  152. clock-names = "cpu", "intermediate";
  153. operating-points-v2 = <&cluster0_opp>;
  154. };
  155. cpu1: cpu@1 {
  156. device_type = "cpu";
  157. compatible = "arm,cortex-a53";
  158. reg = <0x001>;
  159. enable-method = "psci";
  160. cpu-idle-states = <&CPU_SLEEP_0>;
  161. #cooling-cells = <2>;
  162. clocks = <&infracfg CLK_INFRA_CA53SEL>,
  163. <&apmixedsys CLK_APMIXED_MAINPLL>;
  164. clock-names = "cpu", "intermediate";
  165. operating-points-v2 = <&cluster0_opp>;
  166. };
  167. cpu2: cpu@100 {
  168. device_type = "cpu";
  169. compatible = "arm,cortex-a57";
  170. reg = <0x100>;
  171. enable-method = "psci";
  172. cpu-idle-states = <&CPU_SLEEP_0>;
  173. #cooling-cells = <2>;
  174. clocks = <&infracfg CLK_INFRA_CA57SEL>,
  175. <&apmixedsys CLK_APMIXED_MAINPLL>;
  176. clock-names = "cpu", "intermediate";
  177. operating-points-v2 = <&cluster1_opp>;
  178. };
  179. cpu3: cpu@101 {
  180. device_type = "cpu";
  181. compatible = "arm,cortex-a57";
  182. reg = <0x101>;
  183. enable-method = "psci";
  184. cpu-idle-states = <&CPU_SLEEP_0>;
  185. #cooling-cells = <2>;
  186. clocks = <&infracfg CLK_INFRA_CA57SEL>,
  187. <&apmixedsys CLK_APMIXED_MAINPLL>;
  188. clock-names = "cpu", "intermediate";
  189. operating-points-v2 = <&cluster1_opp>;
  190. };
  191. idle-states {
  192. entry-method = "psci";
  193. CPU_SLEEP_0: cpu-sleep-0 {
  194. compatible = "arm,idle-state";
  195. local-timer-stop;
  196. entry-latency-us = <639>;
  197. exit-latency-us = <680>;
  198. min-residency-us = <1088>;
  199. arm,psci-suspend-param = <0x0010000>;
  200. };
  201. };
  202. };
  203. psci {
  204. compatible = "arm,psci-1.0", "arm,psci-0.2", "arm,psci";
  205. method = "smc";
  206. cpu_suspend = <0x84000001>;
  207. cpu_off = <0x84000002>;
  208. cpu_on = <0x84000003>;
  209. };
  210. clk26m: oscillator0 {
  211. compatible = "fixed-clock";
  212. #clock-cells = <0>;
  213. clock-frequency = <26000000>;
  214. clock-output-names = "clk26m";
  215. };
  216. clk32k: oscillator1 {
  217. compatible = "fixed-clock";
  218. #clock-cells = <0>;
  219. clock-frequency = <32000>;
  220. clock-output-names = "clk32k";
  221. };
  222. cpum_ck: oscillator2 {
  223. compatible = "fixed-clock";
  224. #clock-cells = <0>;
  225. clock-frequency = <0>;
  226. clock-output-names = "cpum_ck";
  227. };
  228. thermal-zones {
  229. cpu_thermal: cpu_thermal {
  230. polling-delay-passive = <1000>; /* milliseconds */
  231. polling-delay = <1000>; /* milliseconds */
  232. thermal-sensors = <&thermal>;
  233. sustainable-power = <1500>; /* milliwatts */
  234. trips {
  235. threshold: trip-point0 {
  236. temperature = <68000>;
  237. hysteresis = <2000>;
  238. type = "passive";
  239. };
  240. target: trip-point1 {
  241. temperature = <85000>;
  242. hysteresis = <2000>;
  243. type = "passive";
  244. };
  245. cpu_crit: cpu_crit0 {
  246. temperature = <115000>;
  247. hysteresis = <2000>;
  248. type = "critical";
  249. };
  250. };
  251. cooling-maps {
  252. map0 {
  253. trip = <&target>;
  254. cooling-device = <&cpu0 0 0>;
  255. contribution = <3072>;
  256. };
  257. map1 {
  258. trip = <&target>;
  259. cooling-device = <&cpu2 0 0>;
  260. contribution = <1024>;
  261. };
  262. };
  263. };
  264. };
  265. reserved-memory {
  266. #address-cells = <2>;
  267. #size-cells = <2>;
  268. ranges;
  269. vpu_dma_reserved: vpu_dma_mem_region@b7000000 {
  270. compatible = "shared-dma-pool";
  271. reg = <0 0xb7000000 0 0x500000>;
  272. alignment = <0x1000>;
  273. no-map;
  274. };
  275. };
  276. timer {
  277. compatible = "arm,armv8-timer";
  278. interrupt-parent = <&gic>;
  279. interrupts = <GIC_PPI 13
  280. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
  281. <GIC_PPI 14
  282. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
  283. <GIC_PPI 11
  284. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
  285. <GIC_PPI 10
  286. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
  287. };
  288. soc {
  289. #address-cells = <2>;
  290. #size-cells = <2>;
  291. compatible = "simple-bus";
  292. ranges;
  293. topckgen: clock-controller@10000000 {
  294. compatible = "mediatek,mt8173-topckgen";
  295. reg = <0 0x10000000 0 0x1000>;
  296. #clock-cells = <1>;
  297. };
  298. infracfg: power-controller@10001000 {
  299. compatible = "mediatek,mt8173-infracfg", "syscon";
  300. reg = <0 0x10001000 0 0x1000>;
  301. #clock-cells = <1>;
  302. #reset-cells = <1>;
  303. };
  304. pericfg: power-controller@10003000 {
  305. compatible = "mediatek,mt8173-pericfg", "syscon";
  306. reg = <0 0x10003000 0 0x1000>;
  307. #clock-cells = <1>;
  308. #reset-cells = <1>;
  309. };
  310. syscfg_pctl_a: syscfg_pctl_a@10005000 {
  311. compatible = "mediatek,mt8173-pctl-a-syscfg", "syscon";
  312. reg = <0 0x10005000 0 0x1000>;
  313. };
  314. pio: pinctrl@1000b000 {
  315. compatible = "mediatek,mt8173-pinctrl";
  316. reg = <0 0x1000b000 0 0x1000>;
  317. mediatek,pctl-regmap = <&syscfg_pctl_a>;
  318. pins-are-numbered;
  319. gpio-controller;
  320. #gpio-cells = <2>;
  321. interrupt-controller;
  322. #interrupt-cells = <2>;
  323. interrupts = <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>,
  324. <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>,
  325. <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>;
  326. hdmi_pin: xxx {
  327. /*hdmi htplg pin*/
  328. pins1 {
  329. pinmux = <MT8173_PIN_21_HTPLG__FUNC_HTPLG>;
  330. input-enable;
  331. bias-pull-down;
  332. };
  333. };
  334. i2c0_pins_a: i2c0 {
  335. pins1 {
  336. pinmux = <MT8173_PIN_45_SDA0__FUNC_SDA0>,
  337. <MT8173_PIN_46_SCL0__FUNC_SCL0>;
  338. bias-disable;
  339. };
  340. };
  341. i2c1_pins_a: i2c1 {
  342. pins1 {
  343. pinmux = <MT8173_PIN_125_SDA1__FUNC_SDA1>,
  344. <MT8173_PIN_126_SCL1__FUNC_SCL1>;
  345. bias-disable;
  346. };
  347. };
  348. i2c2_pins_a: i2c2 {
  349. pins1 {
  350. pinmux = <MT8173_PIN_43_SDA2__FUNC_SDA2>,
  351. <MT8173_PIN_44_SCL2__FUNC_SCL2>;
  352. bias-disable;
  353. };
  354. };
  355. i2c3_pins_a: i2c3 {
  356. pins1 {
  357. pinmux = <MT8173_PIN_106_SDA3__FUNC_SDA3>,
  358. <MT8173_PIN_107_SCL3__FUNC_SCL3>;
  359. bias-disable;
  360. };
  361. };
  362. i2c4_pins_a: i2c4 {
  363. pins1 {
  364. pinmux = <MT8173_PIN_133_SDA4__FUNC_SDA4>,
  365. <MT8173_PIN_134_SCL4__FUNC_SCL4>;
  366. bias-disable;
  367. };
  368. };
  369. i2c6_pins_a: i2c6 {
  370. pins1 {
  371. pinmux = <MT8173_PIN_100_MSDC2_DAT0__FUNC_SDA5>,
  372. <MT8173_PIN_101_MSDC2_DAT1__FUNC_SCL5>;
  373. bias-disable;
  374. };
  375. };
  376. };
  377. scpsys: scpsys@10006000 {
  378. compatible = "mediatek,mt8173-scpsys";
  379. #power-domain-cells = <1>;
  380. reg = <0 0x10006000 0 0x1000>;
  381. clocks = <&clk26m>,
  382. <&topckgen CLK_TOP_MM_SEL>,
  383. <&topckgen CLK_TOP_VENC_SEL>,
  384. <&topckgen CLK_TOP_VENC_LT_SEL>;
  385. clock-names = "mfg", "mm", "venc", "venc_lt";
  386. infracfg = <&infracfg>;
  387. };
  388. watchdog: watchdog@10007000 {
  389. compatible = "mediatek,mt8173-wdt",
  390. "mediatek,mt6589-wdt";
  391. reg = <0 0x10007000 0 0x100>;
  392. };
  393. timer: timer@10008000 {
  394. compatible = "mediatek,mt8173-timer",
  395. "mediatek,mt6577-timer";
  396. reg = <0 0x10008000 0 0x1000>;
  397. interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_LOW>;
  398. clocks = <&infracfg CLK_INFRA_CLK_13M>,
  399. <&topckgen CLK_TOP_RTC_SEL>;
  400. };
  401. pwrap: pwrap@1000d000 {
  402. compatible = "mediatek,mt8173-pwrap";
  403. reg = <0 0x1000d000 0 0x1000>;
  404. reg-names = "pwrap";
  405. interrupts = <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>;
  406. resets = <&infracfg MT8173_INFRA_PMIC_WRAP_RST>;
  407. reset-names = "pwrap";
  408. clocks = <&infracfg CLK_INFRA_PMICSPI>, <&infracfg CLK_INFRA_PMICWRAP>;
  409. clock-names = "spi", "wrap";
  410. };
  411. cec: cec@10013000 {
  412. compatible = "mediatek,mt8173-cec";
  413. reg = <0 0x10013000 0 0xbc>;
  414. interrupts = <GIC_SPI 167 IRQ_TYPE_LEVEL_LOW>;
  415. clocks = <&infracfg CLK_INFRA_CEC>;
  416. status = "disabled";
  417. };
  418. vpu: vpu@10020000 {
  419. compatible = "mediatek,mt8173-vpu";
  420. reg = <0 0x10020000 0 0x30000>,
  421. <0 0x10050000 0 0x100>;
  422. reg-names = "tcm", "cfg_reg";
  423. interrupts = <GIC_SPI 166 IRQ_TYPE_LEVEL_HIGH>;
  424. clocks = <&topckgen CLK_TOP_SCP_SEL>;
  425. clock-names = "main";
  426. memory-region = <&vpu_dma_reserved>;
  427. };
  428. sysirq: intpol-controller@10200620 {
  429. compatible = "mediatek,mt8173-sysirq",
  430. "mediatek,mt6577-sysirq";
  431. interrupt-controller;
  432. #interrupt-cells = <3>;
  433. interrupt-parent = <&gic>;
  434. reg = <0 0x10200620 0 0x20>;
  435. };
  436. iommu: iommu@10205000 {
  437. compatible = "mediatek,mt8173-m4u";
  438. reg = <0 0x10205000 0 0x1000>;
  439. interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_LOW>;
  440. clocks = <&infracfg CLK_INFRA_M4U>;
  441. clock-names = "bclk";
  442. mediatek,larbs = <&larb0 &larb1 &larb2
  443. &larb3 &larb4 &larb5>;
  444. #iommu-cells = <1>;
  445. };
  446. efuse: efuse@10206000 {
  447. compatible = "mediatek,mt8173-efuse";
  448. reg = <0 0x10206000 0 0x1000>;
  449. #address-cells = <1>;
  450. #size-cells = <1>;
  451. thermal_calibration: calib@528 {
  452. reg = <0x528 0xc>;
  453. };
  454. };
  455. apmixedsys: clock-controller@10209000 {
  456. compatible = "mediatek,mt8173-apmixedsys";
  457. reg = <0 0x10209000 0 0x1000>;
  458. #clock-cells = <1>;
  459. };
  460. hdmi_phy: hdmi-phy@10209100 {
  461. compatible = "mediatek,mt8173-hdmi-phy";
  462. reg = <0 0x10209100 0 0x24>;
  463. clocks = <&apmixedsys CLK_APMIXED_HDMI_REF>;
  464. clock-names = "pll_ref";
  465. clock-output-names = "hdmitx_dig_cts";
  466. mediatek,ibias = <0xa>;
  467. mediatek,ibias_up = <0x1c>;
  468. #clock-cells = <0>;
  469. #phy-cells = <0>;
  470. status = "disabled";
  471. };
  472. mipi_tx0: mipi-dphy@10215000 {
  473. compatible = "mediatek,mt8173-mipi-tx";
  474. reg = <0 0x10215000 0 0x1000>;
  475. clocks = <&clk26m>;
  476. clock-output-names = "mipi_tx0_pll";
  477. #clock-cells = <0>;
  478. #phy-cells = <0>;
  479. status = "disabled";
  480. };
  481. mipi_tx1: mipi-dphy@10216000 {
  482. compatible = "mediatek,mt8173-mipi-tx";
  483. reg = <0 0x10216000 0 0x1000>;
  484. clocks = <&clk26m>;
  485. clock-output-names = "mipi_tx1_pll";
  486. #clock-cells = <0>;
  487. #phy-cells = <0>;
  488. status = "disabled";
  489. };
  490. gic: interrupt-controller@10221000 {
  491. compatible = "arm,gic-400";
  492. #interrupt-cells = <3>;
  493. interrupt-parent = <&gic>;
  494. interrupt-controller;
  495. reg = <0 0x10221000 0 0x1000>,
  496. <0 0x10222000 0 0x2000>,
  497. <0 0x10224000 0 0x2000>,
  498. <0 0x10226000 0 0x2000>;
  499. interrupts = <GIC_PPI 9
  500. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
  501. };
  502. auxadc: auxadc@11001000 {
  503. compatible = "mediatek,mt8173-auxadc";
  504. reg = <0 0x11001000 0 0x1000>;
  505. clocks = <&pericfg CLK_PERI_AUXADC>;
  506. clock-names = "main";
  507. #io-channel-cells = <1>;
  508. };
  509. uart0: serial@11002000 {
  510. compatible = "mediatek,mt8173-uart",
  511. "mediatek,mt6577-uart";
  512. reg = <0 0x11002000 0 0x400>;
  513. interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_LOW>;
  514. clocks = <&pericfg CLK_PERI_UART0_SEL>, <&pericfg CLK_PERI_UART0>;
  515. clock-names = "baud", "bus";
  516. status = "disabled";
  517. };
  518. uart1: serial@11003000 {
  519. compatible = "mediatek,mt8173-uart",
  520. "mediatek,mt6577-uart";
  521. reg = <0 0x11003000 0 0x400>;
  522. interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_LOW>;
  523. clocks = <&pericfg CLK_PERI_UART1_SEL>, <&pericfg CLK_PERI_UART1>;
  524. clock-names = "baud", "bus";
  525. status = "disabled";
  526. };
  527. uart2: serial@11004000 {
  528. compatible = "mediatek,mt8173-uart",
  529. "mediatek,mt6577-uart";
  530. reg = <0 0x11004000 0 0x400>;
  531. interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_LOW>;
  532. clocks = <&pericfg CLK_PERI_UART2_SEL>, <&pericfg CLK_PERI_UART2>;
  533. clock-names = "baud", "bus";
  534. status = "disabled";
  535. };
  536. uart3: serial@11005000 {
  537. compatible = "mediatek,mt8173-uart",
  538. "mediatek,mt6577-uart";
  539. reg = <0 0x11005000 0 0x400>;
  540. interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_LOW>;
  541. clocks = <&pericfg CLK_PERI_UART3_SEL>, <&pericfg CLK_PERI_UART3>;
  542. clock-names = "baud", "bus";
  543. status = "disabled";
  544. };
  545. i2c0: i2c@11007000 {
  546. compatible = "mediatek,mt8173-i2c";
  547. reg = <0 0x11007000 0 0x70>,
  548. <0 0x11000100 0 0x80>;
  549. interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_LOW>;
  550. clock-div = <16>;
  551. clocks = <&pericfg CLK_PERI_I2C0>,
  552. <&pericfg CLK_PERI_AP_DMA>;
  553. clock-names = "main", "dma";
  554. pinctrl-names = "default";
  555. pinctrl-0 = <&i2c0_pins_a>;
  556. #address-cells = <1>;
  557. #size-cells = <0>;
  558. status = "disabled";
  559. };
  560. i2c1: i2c@11008000 {
  561. compatible = "mediatek,mt8173-i2c";
  562. reg = <0 0x11008000 0 0x70>,
  563. <0 0x11000180 0 0x80>;
  564. interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_LOW>;
  565. clock-div = <16>;
  566. clocks = <&pericfg CLK_PERI_I2C1>,
  567. <&pericfg CLK_PERI_AP_DMA>;
  568. clock-names = "main", "dma";
  569. pinctrl-names = "default";
  570. pinctrl-0 = <&i2c1_pins_a>;
  571. #address-cells = <1>;
  572. #size-cells = <0>;
  573. status = "disabled";
  574. };
  575. i2c2: i2c@11009000 {
  576. compatible = "mediatek,mt8173-i2c";
  577. reg = <0 0x11009000 0 0x70>,
  578. <0 0x11000200 0 0x80>;
  579. interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_LOW>;
  580. clock-div = <16>;
  581. clocks = <&pericfg CLK_PERI_I2C2>,
  582. <&pericfg CLK_PERI_AP_DMA>;
  583. clock-names = "main", "dma";
  584. pinctrl-names = "default";
  585. pinctrl-0 = <&i2c2_pins_a>;
  586. #address-cells = <1>;
  587. #size-cells = <0>;
  588. status = "disabled";
  589. };
  590. spi: spi@1100a000 {
  591. compatible = "mediatek,mt8173-spi";
  592. #address-cells = <1>;
  593. #size-cells = <0>;
  594. reg = <0 0x1100a000 0 0x1000>;
  595. interrupts = <GIC_SPI 110 IRQ_TYPE_LEVEL_LOW>;
  596. clocks = <&topckgen CLK_TOP_SYSPLL3_D2>,
  597. <&topckgen CLK_TOP_SPI_SEL>,
  598. <&pericfg CLK_PERI_SPI0>;
  599. clock-names = "parent-clk", "sel-clk", "spi-clk";
  600. status = "disabled";
  601. };
  602. thermal: thermal@1100b000 {
  603. #thermal-sensor-cells = <0>;
  604. compatible = "mediatek,mt8173-thermal";
  605. reg = <0 0x1100b000 0 0x1000>;
  606. interrupts = <0 70 IRQ_TYPE_LEVEL_LOW>;
  607. clocks = <&pericfg CLK_PERI_THERM>, <&pericfg CLK_PERI_AUXADC>;
  608. clock-names = "therm", "auxadc";
  609. resets = <&pericfg MT8173_PERI_THERM_SW_RST>;
  610. mediatek,auxadc = <&auxadc>;
  611. mediatek,apmixedsys = <&apmixedsys>;
  612. nvmem-cells = <&thermal_calibration>;
  613. nvmem-cell-names = "calibration-data";
  614. };
  615. nor_flash: spi@1100d000 {
  616. compatible = "mediatek,mt8173-nor";
  617. reg = <0 0x1100d000 0 0xe0>;
  618. clocks = <&pericfg CLK_PERI_SPI>,
  619. <&topckgen CLK_TOP_SPINFI_IFR_SEL>;
  620. clock-names = "spi", "sf";
  621. #address-cells = <1>;
  622. #size-cells = <0>;
  623. status = "disabled";
  624. };
  625. i2c3: i2c@11010000 {
  626. compatible = "mediatek,mt8173-i2c";
  627. reg = <0 0x11010000 0 0x70>,
  628. <0 0x11000280 0 0x80>;
  629. interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_LOW>;
  630. clock-div = <16>;
  631. clocks = <&pericfg CLK_PERI_I2C3>,
  632. <&pericfg CLK_PERI_AP_DMA>;
  633. clock-names = "main", "dma";
  634. pinctrl-names = "default";
  635. pinctrl-0 = <&i2c3_pins_a>;
  636. #address-cells = <1>;
  637. #size-cells = <0>;
  638. status = "disabled";
  639. };
  640. i2c4: i2c@11011000 {
  641. compatible = "mediatek,mt8173-i2c";
  642. reg = <0 0x11011000 0 0x70>,
  643. <0 0x11000300 0 0x80>;
  644. interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_LOW>;
  645. clock-div = <16>;
  646. clocks = <&pericfg CLK_PERI_I2C4>,
  647. <&pericfg CLK_PERI_AP_DMA>;
  648. clock-names = "main", "dma";
  649. pinctrl-names = "default";
  650. pinctrl-0 = <&i2c4_pins_a>;
  651. #address-cells = <1>;
  652. #size-cells = <0>;
  653. status = "disabled";
  654. };
  655. hdmiddc0: i2c@11012000 {
  656. compatible = "mediatek,mt8173-hdmi-ddc";
  657. interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_LOW>;
  658. reg = <0 0x11012000 0 0x1C>;
  659. clocks = <&pericfg CLK_PERI_I2C5>;
  660. clock-names = "ddc-i2c";
  661. };
  662. i2c6: i2c@11013000 {
  663. compatible = "mediatek,mt8173-i2c";
  664. reg = <0 0x11013000 0 0x70>,
  665. <0 0x11000080 0 0x80>;
  666. interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_LOW>;
  667. clock-div = <16>;
  668. clocks = <&pericfg CLK_PERI_I2C6>,
  669. <&pericfg CLK_PERI_AP_DMA>;
  670. clock-names = "main", "dma";
  671. pinctrl-names = "default";
  672. pinctrl-0 = <&i2c6_pins_a>;
  673. #address-cells = <1>;
  674. #size-cells = <0>;
  675. status = "disabled";
  676. };
  677. afe: audio-controller@11220000 {
  678. compatible = "mediatek,mt8173-afe-pcm";
  679. reg = <0 0x11220000 0 0x1000>;
  680. interrupts = <GIC_SPI 134 IRQ_TYPE_EDGE_FALLING>;
  681. power-domains = <&scpsys MT8173_POWER_DOMAIN_AUDIO>;
  682. clocks = <&infracfg CLK_INFRA_AUDIO>,
  683. <&topckgen CLK_TOP_AUDIO_SEL>,
  684. <&topckgen CLK_TOP_AUD_INTBUS_SEL>,
  685. <&topckgen CLK_TOP_APLL1_DIV0>,
  686. <&topckgen CLK_TOP_APLL2_DIV0>,
  687. <&topckgen CLK_TOP_I2S0_M_SEL>,
  688. <&topckgen CLK_TOP_I2S1_M_SEL>,
  689. <&topckgen CLK_TOP_I2S2_M_SEL>,
  690. <&topckgen CLK_TOP_I2S3_M_SEL>,
  691. <&topckgen CLK_TOP_I2S3_B_SEL>;
  692. clock-names = "infra_sys_audio_clk",
  693. "top_pdn_audio",
  694. "top_pdn_aud_intbus",
  695. "bck0",
  696. "bck1",
  697. "i2s0_m",
  698. "i2s1_m",
  699. "i2s2_m",
  700. "i2s3_m",
  701. "i2s3_b";
  702. assigned-clocks = <&topckgen CLK_TOP_AUD_1_SEL>,
  703. <&topckgen CLK_TOP_AUD_2_SEL>;
  704. assigned-clock-parents = <&topckgen CLK_TOP_APLL1>,
  705. <&topckgen CLK_TOP_APLL2>;
  706. };
  707. mmc0: mmc@11230000 {
  708. compatible = "mediatek,mt8173-mmc";
  709. reg = <0 0x11230000 0 0x1000>;
  710. interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_LOW>;
  711. clocks = <&pericfg CLK_PERI_MSDC30_0>,
  712. <&topckgen CLK_TOP_MSDC50_0_H_SEL>;
  713. clock-names = "source", "hclk";
  714. status = "disabled";
  715. };
  716. mmc1: mmc@11240000 {
  717. compatible = "mediatek,mt8173-mmc";
  718. reg = <0 0x11240000 0 0x1000>;
  719. interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_LOW>;
  720. clocks = <&pericfg CLK_PERI_MSDC30_1>,
  721. <&topckgen CLK_TOP_AXI_SEL>;
  722. clock-names = "source", "hclk";
  723. status = "disabled";
  724. };
  725. mmc2: mmc@11250000 {
  726. compatible = "mediatek,mt8173-mmc";
  727. reg = <0 0x11250000 0 0x1000>;
  728. interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_LOW>;
  729. clocks = <&pericfg CLK_PERI_MSDC30_2>,
  730. <&topckgen CLK_TOP_AXI_SEL>;
  731. clock-names = "source", "hclk";
  732. status = "disabled";
  733. };
  734. mmc3: mmc@11260000 {
  735. compatible = "mediatek,mt8173-mmc";
  736. reg = <0 0x11260000 0 0x1000>;
  737. interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_LOW>;
  738. clocks = <&pericfg CLK_PERI_MSDC30_3>,
  739. <&topckgen CLK_TOP_MSDC50_2_H_SEL>;
  740. clock-names = "source", "hclk";
  741. status = "disabled";
  742. };
  743. ssusb: usb@11271000 {
  744. compatible = "mediatek,mt8173-mtu3";
  745. reg = <0 0x11271000 0 0x3000>,
  746. <0 0x11280700 0 0x0100>;
  747. reg-names = "mac", "ippc";
  748. interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_LOW>;
  749. phys = <&u2port0 PHY_TYPE_USB2>,
  750. <&u3port0 PHY_TYPE_USB3>,
  751. <&u2port1 PHY_TYPE_USB2>;
  752. power-domains = <&scpsys MT8173_POWER_DOMAIN_USB>;
  753. clocks = <&topckgen CLK_TOP_USB30_SEL>, <&clk26m>;
  754. clock-names = "sys_ck", "ref_ck";
  755. mediatek,syscon-wakeup = <&pericfg 0x400 1>;
  756. #address-cells = <2>;
  757. #size-cells = <2>;
  758. ranges;
  759. status = "disabled";
  760. usb_host: xhci@11270000 {
  761. compatible = "mediatek,mt8173-xhci";
  762. reg = <0 0x11270000 0 0x1000>;
  763. reg-names = "mac";
  764. interrupts = <GIC_SPI 115 IRQ_TYPE_LEVEL_LOW>;
  765. power-domains = <&scpsys MT8173_POWER_DOMAIN_USB>;
  766. clocks = <&topckgen CLK_TOP_USB30_SEL>, <&clk26m>;
  767. clock-names = "sys_ck", "ref_ck";
  768. status = "disabled";
  769. };
  770. };
  771. u3phy: usb-phy@11290000 {
  772. compatible = "mediatek,mt8173-u3phy";
  773. reg = <0 0x11290000 0 0x800>;
  774. #address-cells = <2>;
  775. #size-cells = <2>;
  776. ranges;
  777. status = "okay";
  778. u2port0: usb-phy@11290800 {
  779. reg = <0 0x11290800 0 0x100>;
  780. clocks = <&apmixedsys CLK_APMIXED_REF2USB_TX>;
  781. clock-names = "ref";
  782. #phy-cells = <1>;
  783. status = "okay";
  784. };
  785. u3port0: usb-phy@11290900 {
  786. reg = <0 0x11290900 0 0x700>;
  787. clocks = <&clk26m>;
  788. clock-names = "ref";
  789. #phy-cells = <1>;
  790. status = "okay";
  791. };
  792. u2port1: usb-phy@11291000 {
  793. reg = <0 0x11291000 0 0x100>;
  794. clocks = <&apmixedsys CLK_APMIXED_REF2USB_TX>;
  795. clock-names = "ref";
  796. #phy-cells = <1>;
  797. status = "okay";
  798. };
  799. };
  800. mmsys: clock-controller@14000000 {
  801. compatible = "mediatek,mt8173-mmsys", "syscon";
  802. reg = <0 0x14000000 0 0x1000>;
  803. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  804. assigned-clocks = <&topckgen CLK_TOP_MM_SEL>;
  805. assigned-clock-rates = <400000000>;
  806. #clock-cells = <1>;
  807. };
  808. mdp_rdma0: rdma@14001000 {
  809. compatible = "mediatek,mt8173-mdp-rdma",
  810. "mediatek,mt8173-mdp";
  811. reg = <0 0x14001000 0 0x1000>;
  812. clocks = <&mmsys CLK_MM_MDP_RDMA0>,
  813. <&mmsys CLK_MM_MUTEX_32K>;
  814. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  815. iommus = <&iommu M4U_PORT_MDP_RDMA0>;
  816. mediatek,larb = <&larb0>;
  817. mediatek,vpu = <&vpu>;
  818. };
  819. mdp_rdma1: rdma@14002000 {
  820. compatible = "mediatek,mt8173-mdp-rdma";
  821. reg = <0 0x14002000 0 0x1000>;
  822. clocks = <&mmsys CLK_MM_MDP_RDMA1>,
  823. <&mmsys CLK_MM_MUTEX_32K>;
  824. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  825. iommus = <&iommu M4U_PORT_MDP_RDMA1>;
  826. mediatek,larb = <&larb4>;
  827. };
  828. mdp_rsz0: rsz@14003000 {
  829. compatible = "mediatek,mt8173-mdp-rsz";
  830. reg = <0 0x14003000 0 0x1000>;
  831. clocks = <&mmsys CLK_MM_MDP_RSZ0>;
  832. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  833. };
  834. mdp_rsz1: rsz@14004000 {
  835. compatible = "mediatek,mt8173-mdp-rsz";
  836. reg = <0 0x14004000 0 0x1000>;
  837. clocks = <&mmsys CLK_MM_MDP_RSZ1>;
  838. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  839. };
  840. mdp_rsz2: rsz@14005000 {
  841. compatible = "mediatek,mt8173-mdp-rsz";
  842. reg = <0 0x14005000 0 0x1000>;
  843. clocks = <&mmsys CLK_MM_MDP_RSZ2>;
  844. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  845. };
  846. mdp_wdma0: wdma@14006000 {
  847. compatible = "mediatek,mt8173-mdp-wdma";
  848. reg = <0 0x14006000 0 0x1000>;
  849. clocks = <&mmsys CLK_MM_MDP_WDMA>;
  850. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  851. iommus = <&iommu M4U_PORT_MDP_WDMA>;
  852. mediatek,larb = <&larb0>;
  853. };
  854. mdp_wrot0: wrot@14007000 {
  855. compatible = "mediatek,mt8173-mdp-wrot";
  856. reg = <0 0x14007000 0 0x1000>;
  857. clocks = <&mmsys CLK_MM_MDP_WROT0>;
  858. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  859. iommus = <&iommu M4U_PORT_MDP_WROT0>;
  860. mediatek,larb = <&larb0>;
  861. };
  862. mdp_wrot1: wrot@14008000 {
  863. compatible = "mediatek,mt8173-mdp-wrot";
  864. reg = <0 0x14008000 0 0x1000>;
  865. clocks = <&mmsys CLK_MM_MDP_WROT1>;
  866. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  867. iommus = <&iommu M4U_PORT_MDP_WROT1>;
  868. mediatek,larb = <&larb4>;
  869. };
  870. ovl0: ovl@1400c000 {
  871. compatible = "mediatek,mt8173-disp-ovl";
  872. reg = <0 0x1400c000 0 0x1000>;
  873. interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_LOW>;
  874. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  875. clocks = <&mmsys CLK_MM_DISP_OVL0>;
  876. iommus = <&iommu M4U_PORT_DISP_OVL0>;
  877. mediatek,larb = <&larb0>;
  878. };
  879. ovl1: ovl@1400d000 {
  880. compatible = "mediatek,mt8173-disp-ovl";
  881. reg = <0 0x1400d000 0 0x1000>;
  882. interrupts = <GIC_SPI 181 IRQ_TYPE_LEVEL_LOW>;
  883. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  884. clocks = <&mmsys CLK_MM_DISP_OVL1>;
  885. iommus = <&iommu M4U_PORT_DISP_OVL1>;
  886. mediatek,larb = <&larb4>;
  887. };
  888. rdma0: rdma@1400e000 {
  889. compatible = "mediatek,mt8173-disp-rdma";
  890. reg = <0 0x1400e000 0 0x1000>;
  891. interrupts = <GIC_SPI 182 IRQ_TYPE_LEVEL_LOW>;
  892. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  893. clocks = <&mmsys CLK_MM_DISP_RDMA0>;
  894. iommus = <&iommu M4U_PORT_DISP_RDMA0>;
  895. mediatek,larb = <&larb0>;
  896. };
  897. rdma1: rdma@1400f000 {
  898. compatible = "mediatek,mt8173-disp-rdma";
  899. reg = <0 0x1400f000 0 0x1000>;
  900. interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_LOW>;
  901. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  902. clocks = <&mmsys CLK_MM_DISP_RDMA1>;
  903. iommus = <&iommu M4U_PORT_DISP_RDMA1>;
  904. mediatek,larb = <&larb4>;
  905. };
  906. rdma2: rdma@14010000 {
  907. compatible = "mediatek,mt8173-disp-rdma";
  908. reg = <0 0x14010000 0 0x1000>;
  909. interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_LOW>;
  910. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  911. clocks = <&mmsys CLK_MM_DISP_RDMA2>;
  912. iommus = <&iommu M4U_PORT_DISP_RDMA2>;
  913. mediatek,larb = <&larb4>;
  914. };
  915. wdma0: wdma@14011000 {
  916. compatible = "mediatek,mt8173-disp-wdma";
  917. reg = <0 0x14011000 0 0x1000>;
  918. interrupts = <GIC_SPI 185 IRQ_TYPE_LEVEL_LOW>;
  919. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  920. clocks = <&mmsys CLK_MM_DISP_WDMA0>;
  921. iommus = <&iommu M4U_PORT_DISP_WDMA0>;
  922. mediatek,larb = <&larb0>;
  923. };
  924. wdma1: wdma@14012000 {
  925. compatible = "mediatek,mt8173-disp-wdma";
  926. reg = <0 0x14012000 0 0x1000>;
  927. interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_LOW>;
  928. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  929. clocks = <&mmsys CLK_MM_DISP_WDMA1>;
  930. iommus = <&iommu M4U_PORT_DISP_WDMA1>;
  931. mediatek,larb = <&larb4>;
  932. };
  933. color0: color@14013000 {
  934. compatible = "mediatek,mt8173-disp-color";
  935. reg = <0 0x14013000 0 0x1000>;
  936. interrupts = <GIC_SPI 187 IRQ_TYPE_LEVEL_LOW>;
  937. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  938. clocks = <&mmsys CLK_MM_DISP_COLOR0>;
  939. };
  940. color1: color@14014000 {
  941. compatible = "mediatek,mt8173-disp-color";
  942. reg = <0 0x14014000 0 0x1000>;
  943. interrupts = <GIC_SPI 188 IRQ_TYPE_LEVEL_LOW>;
  944. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  945. clocks = <&mmsys CLK_MM_DISP_COLOR1>;
  946. };
  947. aal@14015000 {
  948. compatible = "mediatek,mt8173-disp-aal";
  949. reg = <0 0x14015000 0 0x1000>;
  950. interrupts = <GIC_SPI 189 IRQ_TYPE_LEVEL_LOW>;
  951. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  952. clocks = <&mmsys CLK_MM_DISP_AAL>;
  953. };
  954. gamma@14016000 {
  955. compatible = "mediatek,mt8173-disp-gamma";
  956. reg = <0 0x14016000 0 0x1000>;
  957. interrupts = <GIC_SPI 190 IRQ_TYPE_LEVEL_LOW>;
  958. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  959. clocks = <&mmsys CLK_MM_DISP_GAMMA>;
  960. };
  961. merge@14017000 {
  962. compatible = "mediatek,mt8173-disp-merge";
  963. reg = <0 0x14017000 0 0x1000>;
  964. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  965. clocks = <&mmsys CLK_MM_DISP_MERGE>;
  966. };
  967. split0: split@14018000 {
  968. compatible = "mediatek,mt8173-disp-split";
  969. reg = <0 0x14018000 0 0x1000>;
  970. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  971. clocks = <&mmsys CLK_MM_DISP_SPLIT0>;
  972. };
  973. split1: split@14019000 {
  974. compatible = "mediatek,mt8173-disp-split";
  975. reg = <0 0x14019000 0 0x1000>;
  976. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  977. clocks = <&mmsys CLK_MM_DISP_SPLIT1>;
  978. };
  979. ufoe@1401a000 {
  980. compatible = "mediatek,mt8173-disp-ufoe";
  981. reg = <0 0x1401a000 0 0x1000>;
  982. interrupts = <GIC_SPI 191 IRQ_TYPE_LEVEL_LOW>;
  983. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  984. clocks = <&mmsys CLK_MM_DISP_UFOE>;
  985. };
  986. dsi0: dsi@1401b000 {
  987. compatible = "mediatek,mt8173-dsi";
  988. reg = <0 0x1401b000 0 0x1000>;
  989. interrupts = <GIC_SPI 192 IRQ_TYPE_LEVEL_LOW>;
  990. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  991. clocks = <&mmsys CLK_MM_DSI0_ENGINE>,
  992. <&mmsys CLK_MM_DSI0_DIGITAL>,
  993. <&mipi_tx0>;
  994. clock-names = "engine", "digital", "hs";
  995. phys = <&mipi_tx0>;
  996. phy-names = "dphy";
  997. status = "disabled";
  998. };
  999. dsi1: dsi@1401c000 {
  1000. compatible = "mediatek,mt8173-dsi";
  1001. reg = <0 0x1401c000 0 0x1000>;
  1002. interrupts = <GIC_SPI 193 IRQ_TYPE_LEVEL_LOW>;
  1003. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  1004. clocks = <&mmsys CLK_MM_DSI1_ENGINE>,
  1005. <&mmsys CLK_MM_DSI1_DIGITAL>,
  1006. <&mipi_tx1>;
  1007. clock-names = "engine", "digital", "hs";
  1008. phys = <&mipi_tx1>;
  1009. phy-names = "dphy";
  1010. status = "disabled";
  1011. };
  1012. dpi0: dpi@1401d000 {
  1013. compatible = "mediatek,mt8173-dpi";
  1014. reg = <0 0x1401d000 0 0x1000>;
  1015. interrupts = <GIC_SPI 194 IRQ_TYPE_LEVEL_LOW>;
  1016. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  1017. clocks = <&mmsys CLK_MM_DPI_PIXEL>,
  1018. <&mmsys CLK_MM_DPI_ENGINE>,
  1019. <&apmixedsys CLK_APMIXED_TVDPLL>;
  1020. clock-names = "pixel", "engine", "pll";
  1021. status = "disabled";
  1022. port {
  1023. dpi0_out: endpoint {
  1024. remote-endpoint = <&hdmi0_in>;
  1025. };
  1026. };
  1027. };
  1028. pwm0: pwm@1401e000 {
  1029. compatible = "mediatek,mt8173-disp-pwm",
  1030. "mediatek,mt6595-disp-pwm";
  1031. reg = <0 0x1401e000 0 0x1000>;
  1032. #pwm-cells = <2>;
  1033. clocks = <&mmsys CLK_MM_DISP_PWM026M>,
  1034. <&mmsys CLK_MM_DISP_PWM0MM>;
  1035. clock-names = "main", "mm";
  1036. status = "disabled";
  1037. };
  1038. pwm1: pwm@1401f000 {
  1039. compatible = "mediatek,mt8173-disp-pwm",
  1040. "mediatek,mt6595-disp-pwm";
  1041. reg = <0 0x1401f000 0 0x1000>;
  1042. #pwm-cells = <2>;
  1043. clocks = <&mmsys CLK_MM_DISP_PWM126M>,
  1044. <&mmsys CLK_MM_DISP_PWM1MM>;
  1045. clock-names = "main", "mm";
  1046. status = "disabled";
  1047. };
  1048. mutex: mutex@14020000 {
  1049. compatible = "mediatek,mt8173-disp-mutex";
  1050. reg = <0 0x14020000 0 0x1000>;
  1051. interrupts = <GIC_SPI 169 IRQ_TYPE_LEVEL_LOW>;
  1052. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  1053. clocks = <&mmsys CLK_MM_MUTEX_32K>;
  1054. };
  1055. larb0: larb@14021000 {
  1056. compatible = "mediatek,mt8173-smi-larb";
  1057. reg = <0 0x14021000 0 0x1000>;
  1058. mediatek,smi = <&smi_common>;
  1059. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  1060. clocks = <&mmsys CLK_MM_SMI_LARB0>,
  1061. <&mmsys CLK_MM_SMI_LARB0>;
  1062. clock-names = "apb", "smi";
  1063. };
  1064. smi_common: smi@14022000 {
  1065. compatible = "mediatek,mt8173-smi-common";
  1066. reg = <0 0x14022000 0 0x1000>;
  1067. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  1068. clocks = <&mmsys CLK_MM_SMI_COMMON>,
  1069. <&mmsys CLK_MM_SMI_COMMON>;
  1070. clock-names = "apb", "smi";
  1071. };
  1072. od@14023000 {
  1073. compatible = "mediatek,mt8173-disp-od";
  1074. reg = <0 0x14023000 0 0x1000>;
  1075. clocks = <&mmsys CLK_MM_DISP_OD>;
  1076. };
  1077. hdmi0: hdmi@14025000 {
  1078. compatible = "mediatek,mt8173-hdmi";
  1079. reg = <0 0x14025000 0 0x400>;
  1080. interrupts = <GIC_SPI 206 IRQ_TYPE_LEVEL_LOW>;
  1081. clocks = <&mmsys CLK_MM_HDMI_PIXEL>,
  1082. <&mmsys CLK_MM_HDMI_PLLCK>,
  1083. <&mmsys CLK_MM_HDMI_AUDIO>,
  1084. <&mmsys CLK_MM_HDMI_SPDIF>;
  1085. clock-names = "pixel", "pll", "bclk", "spdif";
  1086. pinctrl-names = "default";
  1087. pinctrl-0 = <&hdmi_pin>;
  1088. phys = <&hdmi_phy>;
  1089. phy-names = "hdmi";
  1090. mediatek,syscon-hdmi = <&mmsys 0x900>;
  1091. assigned-clocks = <&topckgen CLK_TOP_HDMI_SEL>;
  1092. assigned-clock-parents = <&hdmi_phy>;
  1093. status = "disabled";
  1094. ports {
  1095. #address-cells = <1>;
  1096. #size-cells = <0>;
  1097. port@0 {
  1098. reg = <0>;
  1099. hdmi0_in: endpoint {
  1100. remote-endpoint = <&dpi0_out>;
  1101. };
  1102. };
  1103. };
  1104. };
  1105. larb4: larb@14027000 {
  1106. compatible = "mediatek,mt8173-smi-larb";
  1107. reg = <0 0x14027000 0 0x1000>;
  1108. mediatek,smi = <&smi_common>;
  1109. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  1110. clocks = <&mmsys CLK_MM_SMI_LARB4>,
  1111. <&mmsys CLK_MM_SMI_LARB4>;
  1112. clock-names = "apb", "smi";
  1113. };
  1114. imgsys: clock-controller@15000000 {
  1115. compatible = "mediatek,mt8173-imgsys", "syscon";
  1116. reg = <0 0x15000000 0 0x1000>;
  1117. #clock-cells = <1>;
  1118. };
  1119. larb2: larb@15001000 {
  1120. compatible = "mediatek,mt8173-smi-larb";
  1121. reg = <0 0x15001000 0 0x1000>;
  1122. mediatek,smi = <&smi_common>;
  1123. power-domains = <&scpsys MT8173_POWER_DOMAIN_ISP>;
  1124. clocks = <&imgsys CLK_IMG_LARB2_SMI>,
  1125. <&imgsys CLK_IMG_LARB2_SMI>;
  1126. clock-names = "apb", "smi";
  1127. };
  1128. vdecsys: clock-controller@16000000 {
  1129. compatible = "mediatek,mt8173-vdecsys", "syscon";
  1130. reg = <0 0x16000000 0 0x1000>;
  1131. #clock-cells = <1>;
  1132. };
  1133. vcodec_dec: vcodec@16000000 {
  1134. compatible = "mediatek,mt8173-vcodec-dec";
  1135. reg = <0 0x16000000 0 0x100>, /* VDEC_SYS */
  1136. <0 0x16020000 0 0x1000>, /* VDEC_MISC */
  1137. <0 0x16021000 0 0x800>, /* VDEC_LD */
  1138. <0 0x16021800 0 0x800>, /* VDEC_TOP */
  1139. <0 0x16022000 0 0x1000>, /* VDEC_CM */
  1140. <0 0x16023000 0 0x1000>, /* VDEC_AD */
  1141. <0 0x16024000 0 0x1000>, /* VDEC_AV */
  1142. <0 0x16025000 0 0x1000>, /* VDEC_PP */
  1143. <0 0x16026800 0 0x800>, /* VDEC_HWD */
  1144. <0 0x16027000 0 0x800>, /* VDEC_HWQ */
  1145. <0 0x16027800 0 0x800>, /* VDEC_HWB */
  1146. <0 0x16028400 0 0x400>; /* VDEC_HWG */
  1147. interrupts = <GIC_SPI 204 IRQ_TYPE_LEVEL_LOW>;
  1148. mediatek,larb = <&larb1>;
  1149. iommus = <&iommu M4U_PORT_HW_VDEC_MC_EXT>,
  1150. <&iommu M4U_PORT_HW_VDEC_PP_EXT>,
  1151. <&iommu M4U_PORT_HW_VDEC_AVC_MV_EXT>,
  1152. <&iommu M4U_PORT_HW_VDEC_PRED_RD_EXT>,
  1153. <&iommu M4U_PORT_HW_VDEC_PRED_WR_EXT>,
  1154. <&iommu M4U_PORT_HW_VDEC_UFO_EXT>,
  1155. <&iommu M4U_PORT_HW_VDEC_VLD_EXT>,
  1156. <&iommu M4U_PORT_HW_VDEC_VLD2_EXT>;
  1157. mediatek,vpu = <&vpu>;
  1158. power-domains = <&scpsys MT8173_POWER_DOMAIN_VDEC>;
  1159. clocks = <&apmixedsys CLK_APMIXED_VCODECPLL>,
  1160. <&topckgen CLK_TOP_UNIVPLL_D2>,
  1161. <&topckgen CLK_TOP_CCI400_SEL>,
  1162. <&topckgen CLK_TOP_VDEC_SEL>,
  1163. <&topckgen CLK_TOP_VCODECPLL>,
  1164. <&apmixedsys CLK_APMIXED_VENCPLL>,
  1165. <&topckgen CLK_TOP_VENC_LT_SEL>,
  1166. <&topckgen CLK_TOP_VCODECPLL_370P5>;
  1167. clock-names = "vcodecpll",
  1168. "univpll_d2",
  1169. "clk_cci400_sel",
  1170. "vdec_sel",
  1171. "vdecpll",
  1172. "vencpll",
  1173. "venc_lt_sel",
  1174. "vdec_bus_clk_src";
  1175. };
  1176. larb1: larb@16010000 {
  1177. compatible = "mediatek,mt8173-smi-larb";
  1178. reg = <0 0x16010000 0 0x1000>;
  1179. mediatek,smi = <&smi_common>;
  1180. power-domains = <&scpsys MT8173_POWER_DOMAIN_VDEC>;
  1181. clocks = <&vdecsys CLK_VDEC_CKEN>,
  1182. <&vdecsys CLK_VDEC_LARB_CKEN>;
  1183. clock-names = "apb", "smi";
  1184. };
  1185. vencsys: clock-controller@18000000 {
  1186. compatible = "mediatek,mt8173-vencsys", "syscon";
  1187. reg = <0 0x18000000 0 0x1000>;
  1188. #clock-cells = <1>;
  1189. };
  1190. larb3: larb@18001000 {
  1191. compatible = "mediatek,mt8173-smi-larb";
  1192. reg = <0 0x18001000 0 0x1000>;
  1193. mediatek,smi = <&smi_common>;
  1194. power-domains = <&scpsys MT8173_POWER_DOMAIN_VENC>;
  1195. clocks = <&vencsys CLK_VENC_CKE1>,
  1196. <&vencsys CLK_VENC_CKE0>;
  1197. clock-names = "apb", "smi";
  1198. };
  1199. vcodec_enc: vcodec@18002000 {
  1200. compatible = "mediatek,mt8173-vcodec-enc";
  1201. reg = <0 0x18002000 0 0x1000>, /* VENC_SYS */
  1202. <0 0x19002000 0 0x1000>; /* VENC_LT_SYS */
  1203. interrupts = <GIC_SPI 198 IRQ_TYPE_LEVEL_LOW>,
  1204. <GIC_SPI 202 IRQ_TYPE_LEVEL_LOW>;
  1205. mediatek,larb = <&larb3>,
  1206. <&larb5>;
  1207. iommus = <&iommu M4U_PORT_VENC_RCPU>,
  1208. <&iommu M4U_PORT_VENC_REC>,
  1209. <&iommu M4U_PORT_VENC_BSDMA>,
  1210. <&iommu M4U_PORT_VENC_SV_COMV>,
  1211. <&iommu M4U_PORT_VENC_RD_COMV>,
  1212. <&iommu M4U_PORT_VENC_CUR_LUMA>,
  1213. <&iommu M4U_PORT_VENC_CUR_CHROMA>,
  1214. <&iommu M4U_PORT_VENC_REF_LUMA>,
  1215. <&iommu M4U_PORT_VENC_REF_CHROMA>,
  1216. <&iommu M4U_PORT_VENC_NBM_RDMA>,
  1217. <&iommu M4U_PORT_VENC_NBM_WDMA>,
  1218. <&iommu M4U_PORT_VENC_RCPU_SET2>,
  1219. <&iommu M4U_PORT_VENC_REC_FRM_SET2>,
  1220. <&iommu M4U_PORT_VENC_BSDMA_SET2>,
  1221. <&iommu M4U_PORT_VENC_SV_COMA_SET2>,
  1222. <&iommu M4U_PORT_VENC_RD_COMA_SET2>,
  1223. <&iommu M4U_PORT_VENC_CUR_LUMA_SET2>,
  1224. <&iommu M4U_PORT_VENC_CUR_CHROMA_SET2>,
  1225. <&iommu M4U_PORT_VENC_REF_LUMA_SET2>,
  1226. <&iommu M4U_PORT_VENC_REC_CHROMA_SET2>;
  1227. mediatek,vpu = <&vpu>;
  1228. clocks = <&topckgen CLK_TOP_VENCPLL_D2>,
  1229. <&topckgen CLK_TOP_VENC_SEL>,
  1230. <&topckgen CLK_TOP_UNIVPLL1_D2>,
  1231. <&topckgen CLK_TOP_VENC_LT_SEL>;
  1232. clock-names = "venc_sel_src",
  1233. "venc_sel",
  1234. "venc_lt_sel_src",
  1235. "venc_lt_sel";
  1236. };
  1237. vencltsys: clock-controller@19000000 {
  1238. compatible = "mediatek,mt8173-vencltsys", "syscon";
  1239. reg = <0 0x19000000 0 0x1000>;
  1240. #clock-cells = <1>;
  1241. };
  1242. larb5: larb@19001000 {
  1243. compatible = "mediatek,mt8173-smi-larb";
  1244. reg = <0 0x19001000 0 0x1000>;
  1245. mediatek,smi = <&smi_common>;
  1246. power-domains = <&scpsys MT8173_POWER_DOMAIN_VENC_LT>;
  1247. clocks = <&vencltsys CLK_VENCLT_CKE1>,
  1248. <&vencltsys CLK_VENCLT_CKE0>;
  1249. clock-names = "apb", "smi";
  1250. };
  1251. };
  1252. };