rk3xxx.dtsi 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488
  1. // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
  2. /*
  3. * Copyright (c) 2013 MundoReader S.L.
  4. * Author: Heiko Stuebner <[email protected]>
  5. */
  6. #include <dt-bindings/interrupt-controller/irq.h>
  7. #include <dt-bindings/interrupt-controller/arm-gic.h>
  8. #include <dt-bindings/soc/rockchip,boot-mode.h>
  9. / {
  10. #address-cells = <1>;
  11. #size-cells = <1>;
  12. interrupt-parent = <&gic>;
  13. aliases {
  14. ethernet0 = &emac;
  15. i2c0 = &i2c0;
  16. i2c1 = &i2c1;
  17. i2c2 = &i2c2;
  18. i2c3 = &i2c3;
  19. i2c4 = &i2c4;
  20. serial0 = &uart0;
  21. serial1 = &uart1;
  22. serial2 = &uart2;
  23. serial3 = &uart3;
  24. spi0 = &spi0;
  25. spi1 = &spi1;
  26. };
  27. xin24m: oscillator {
  28. compatible = "fixed-clock";
  29. clock-frequency = <24000000>;
  30. #clock-cells = <0>;
  31. clock-output-names = "xin24m";
  32. };
  33. gpu: gpu@10090000 {
  34. compatible = "arm,mali-400";
  35. reg = <0x10090000 0x10000>;
  36. clocks = <&cru ACLK_GPU>, <&cru ACLK_GPU>;
  37. clock-names = "bus", "core";
  38. assigned-clocks = <&cru ACLK_GPU>;
  39. assigned-clock-rates = <100000000>;
  40. resets = <&cru SRST_GPU>;
  41. status = "disabled";
  42. };
  43. vpu: video-codec@10104000 {
  44. compatible = "rockchip,rk3066-vpu";
  45. reg = <0x10104000 0x800>;
  46. interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>,
  47. <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
  48. interrupt-names = "vepu", "vdpu";
  49. clocks = <&cru ACLK_VDPU>, <&cru HCLK_VDPU>,
  50. <&cru ACLK_VEPU>, <&cru HCLK_VEPU>;
  51. clock-names = "aclk_vdpu", "hclk_vdpu",
  52. "aclk_vepu", "hclk_vepu";
  53. };
  54. L2: cache-controller@10138000 {
  55. compatible = "arm,pl310-cache";
  56. reg = <0x10138000 0x1000>;
  57. cache-unified;
  58. cache-level = <2>;
  59. };
  60. scu@1013c000 {
  61. compatible = "arm,cortex-a9-scu";
  62. reg = <0x1013c000 0x100>;
  63. };
  64. global_timer: global-timer@1013c200 {
  65. compatible = "arm,cortex-a9-global-timer";
  66. reg = <0x1013c200 0x20>;
  67. interrupts = <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_EDGE_RISING)>;
  68. clocks = <&cru CORE_PERI>;
  69. status = "disabled";
  70. /* The clock source and the sched_clock provided by the arm_global_timer
  71. * on Rockchip rk3066a/rk3188 are quite unstable because their rates
  72. * depend on the CPU frequency.
  73. * Keep the arm_global_timer disabled in order to have the
  74. * DW_APB_TIMER (rk3066a) or ROCKCHIP_TIMER (rk3188) selected by default.
  75. */
  76. };
  77. local_timer: local-timer@1013c600 {
  78. compatible = "arm,cortex-a9-twd-timer";
  79. reg = <0x1013c600 0x20>;
  80. interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_EDGE_RISING)>;
  81. clocks = <&cru CORE_PERI>;
  82. };
  83. gic: interrupt-controller@1013d000 {
  84. compatible = "arm,cortex-a9-gic";
  85. interrupt-controller;
  86. #interrupt-cells = <3>;
  87. reg = <0x1013d000 0x1000>,
  88. <0x1013c100 0x0100>;
  89. };
  90. uart0: serial@10124000 {
  91. compatible = "snps,dw-apb-uart";
  92. reg = <0x10124000 0x400>;
  93. interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
  94. reg-shift = <2>;
  95. reg-io-width = <1>;
  96. clock-names = "baudclk", "apb_pclk";
  97. clocks = <&cru SCLK_UART0>, <&cru PCLK_UART0>;
  98. status = "disabled";
  99. };
  100. uart1: serial@10126000 {
  101. compatible = "snps,dw-apb-uart";
  102. reg = <0x10126000 0x400>;
  103. interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
  104. reg-shift = <2>;
  105. reg-io-width = <1>;
  106. clock-names = "baudclk", "apb_pclk";
  107. clocks = <&cru SCLK_UART1>, <&cru PCLK_UART1>;
  108. status = "disabled";
  109. };
  110. qos_gpu: qos@1012d000 {
  111. compatible = "rockchip,rk3066-qos", "syscon";
  112. reg = <0x1012d000 0x20>;
  113. };
  114. qos_vpu: qos@1012e000 {
  115. compatible = "rockchip,rk3066-qos", "syscon";
  116. reg = <0x1012e000 0x20>;
  117. };
  118. qos_lcdc0: qos@1012f000 {
  119. compatible = "rockchip,rk3066-qos", "syscon";
  120. reg = <0x1012f000 0x20>;
  121. };
  122. qos_cif0: qos@1012f080 {
  123. compatible = "rockchip,rk3066-qos", "syscon";
  124. reg = <0x1012f080 0x20>;
  125. };
  126. qos_ipp: qos@1012f100 {
  127. compatible = "rockchip,rk3066-qos", "syscon";
  128. reg = <0x1012f100 0x20>;
  129. };
  130. qos_lcdc1: qos@1012f180 {
  131. compatible = "rockchip,rk3066-qos", "syscon";
  132. reg = <0x1012f180 0x20>;
  133. };
  134. qos_cif1: qos@1012f200 {
  135. compatible = "rockchip,rk3066-qos", "syscon";
  136. reg = <0x1012f200 0x20>;
  137. };
  138. qos_rga: qos@1012f280 {
  139. compatible = "rockchip,rk3066-qos", "syscon";
  140. reg = <0x1012f280 0x20>;
  141. };
  142. usb_otg: usb@10180000 {
  143. compatible = "rockchip,rk3066-usb", "snps,dwc2";
  144. reg = <0x10180000 0x40000>;
  145. interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
  146. clocks = <&cru HCLK_OTG0>;
  147. clock-names = "otg";
  148. dr_mode = "otg";
  149. g-np-tx-fifo-size = <16>;
  150. g-rx-fifo-size = <275>;
  151. g-tx-fifo-size = <256 128 128 64 64 32>;
  152. phys = <&usbphy0>;
  153. phy-names = "usb2-phy";
  154. status = "disabled";
  155. };
  156. usb_host: usb@101c0000 {
  157. compatible = "snps,dwc2";
  158. reg = <0x101c0000 0x40000>;
  159. interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
  160. clocks = <&cru HCLK_OTG1>;
  161. clock-names = "otg";
  162. dr_mode = "host";
  163. phys = <&usbphy1>;
  164. phy-names = "usb2-phy";
  165. status = "disabled";
  166. };
  167. emac: ethernet@10204000 {
  168. compatible = "snps,arc-emac";
  169. reg = <0x10204000 0x3c>;
  170. interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
  171. rockchip,grf = <&grf>;
  172. clocks = <&cru HCLK_EMAC>, <&cru SCLK_MAC>;
  173. clock-names = "hclk", "macref";
  174. max-speed = <100>;
  175. phy-mode = "rmii";
  176. status = "disabled";
  177. };
  178. mmc0: mmc@10214000 {
  179. compatible = "rockchip,rk2928-dw-mshc";
  180. reg = <0x10214000 0x1000>;
  181. interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
  182. clocks = <&cru HCLK_SDMMC>, <&cru SCLK_SDMMC>;
  183. clock-names = "biu", "ciu";
  184. dmas = <&dmac2 1>;
  185. dma-names = "rx-tx";
  186. fifo-depth = <256>;
  187. resets = <&cru SRST_SDMMC>;
  188. reset-names = "reset";
  189. status = "disabled";
  190. };
  191. mmc1: mmc@10218000 {
  192. compatible = "rockchip,rk2928-dw-mshc";
  193. reg = <0x10218000 0x1000>;
  194. interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
  195. clocks = <&cru HCLK_SDIO>, <&cru SCLK_SDIO>;
  196. clock-names = "biu", "ciu";
  197. dmas = <&dmac2 3>;
  198. dma-names = "rx-tx";
  199. fifo-depth = <256>;
  200. resets = <&cru SRST_SDIO>;
  201. reset-names = "reset";
  202. status = "disabled";
  203. };
  204. emmc: mmc@1021c000 {
  205. compatible = "rockchip,rk2928-dw-mshc";
  206. reg = <0x1021c000 0x1000>;
  207. interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
  208. clocks = <&cru HCLK_EMMC>, <&cru SCLK_EMMC>;
  209. clock-names = "biu", "ciu";
  210. dmas = <&dmac2 4>;
  211. dma-names = "rx-tx";
  212. fifo-depth = <256>;
  213. resets = <&cru SRST_EMMC>;
  214. reset-names = "reset";
  215. status = "disabled";
  216. };
  217. nfc: nand-controller@10500000 {
  218. compatible = "rockchip,rk2928-nfc";
  219. reg = <0x10500000 0x4000>;
  220. interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
  221. clocks = <&cru HCLK_NANDC0>;
  222. clock-names = "ahb";
  223. status = "disabled";
  224. };
  225. pmu: pmu@20004000 {
  226. compatible = "rockchip,rk3066-pmu", "syscon", "simple-mfd";
  227. reg = <0x20004000 0x100>;
  228. reboot-mode {
  229. compatible = "syscon-reboot-mode";
  230. offset = <0x40>;
  231. mode-normal = <BOOT_NORMAL>;
  232. mode-recovery = <BOOT_RECOVERY>;
  233. mode-bootloader = <BOOT_FASTBOOT>;
  234. mode-loader = <BOOT_BL_DOWNLOAD>;
  235. };
  236. };
  237. grf: grf@20008000 {
  238. compatible = "syscon", "simple-mfd";
  239. reg = <0x20008000 0x200>;
  240. };
  241. dmac1_s: dma-controller@20018000 {
  242. compatible = "arm,pl330", "arm,primecell";
  243. reg = <0x20018000 0x4000>;
  244. interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
  245. <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
  246. #dma-cells = <1>;
  247. arm,pl330-broken-no-flushp;
  248. arm,pl330-periph-burst;
  249. clocks = <&cru ACLK_DMA1>;
  250. clock-names = "apb_pclk";
  251. };
  252. dmac1_ns: dma-controller@2001c000 {
  253. compatible = "arm,pl330", "arm,primecell";
  254. reg = <0x2001c000 0x4000>;
  255. interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
  256. <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
  257. #dma-cells = <1>;
  258. arm,pl330-broken-no-flushp;
  259. arm,pl330-periph-burst;
  260. clocks = <&cru ACLK_DMA1>;
  261. clock-names = "apb_pclk";
  262. status = "disabled";
  263. };
  264. i2c0: i2c@2002d000 {
  265. compatible = "rockchip,rk3066-i2c";
  266. reg = <0x2002d000 0x1000>;
  267. interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
  268. #address-cells = <1>;
  269. #size-cells = <0>;
  270. rockchip,grf = <&grf>;
  271. clock-names = "i2c";
  272. clocks = <&cru PCLK_I2C0>;
  273. status = "disabled";
  274. };
  275. i2c1: i2c@2002f000 {
  276. compatible = "rockchip,rk3066-i2c";
  277. reg = <0x2002f000 0x1000>;
  278. interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
  279. #address-cells = <1>;
  280. #size-cells = <0>;
  281. rockchip,grf = <&grf>;
  282. clocks = <&cru PCLK_I2C1>;
  283. clock-names = "i2c";
  284. status = "disabled";
  285. };
  286. pwm0: pwm@20030000 {
  287. compatible = "rockchip,rk2928-pwm";
  288. reg = <0x20030000 0x10>;
  289. #pwm-cells = <2>;
  290. clocks = <&cru PCLK_PWM01>;
  291. status = "disabled";
  292. };
  293. pwm1: pwm@20030010 {
  294. compatible = "rockchip,rk2928-pwm";
  295. reg = <0x20030010 0x10>;
  296. #pwm-cells = <2>;
  297. clocks = <&cru PCLK_PWM01>;
  298. status = "disabled";
  299. };
  300. wdt: watchdog@2004c000 {
  301. compatible = "snps,dw-wdt";
  302. reg = <0x2004c000 0x100>;
  303. clocks = <&cru PCLK_WDT>;
  304. interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
  305. status = "disabled";
  306. };
  307. pwm2: pwm@20050020 {
  308. compatible = "rockchip,rk2928-pwm";
  309. reg = <0x20050020 0x10>;
  310. #pwm-cells = <2>;
  311. clocks = <&cru PCLK_PWM23>;
  312. status = "disabled";
  313. };
  314. pwm3: pwm@20050030 {
  315. compatible = "rockchip,rk2928-pwm";
  316. reg = <0x20050030 0x10>;
  317. #pwm-cells = <2>;
  318. clocks = <&cru PCLK_PWM23>;
  319. status = "disabled";
  320. };
  321. i2c2: i2c@20056000 {
  322. compatible = "rockchip,rk3066-i2c";
  323. reg = <0x20056000 0x1000>;
  324. interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
  325. #address-cells = <1>;
  326. #size-cells = <0>;
  327. rockchip,grf = <&grf>;
  328. clocks = <&cru PCLK_I2C2>;
  329. clock-names = "i2c";
  330. status = "disabled";
  331. };
  332. i2c3: i2c@2005a000 {
  333. compatible = "rockchip,rk3066-i2c";
  334. reg = <0x2005a000 0x1000>;
  335. interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
  336. #address-cells = <1>;
  337. #size-cells = <0>;
  338. rockchip,grf = <&grf>;
  339. clocks = <&cru PCLK_I2C3>;
  340. clock-names = "i2c";
  341. status = "disabled";
  342. };
  343. i2c4: i2c@2005e000 {
  344. compatible = "rockchip,rk3066-i2c";
  345. reg = <0x2005e000 0x1000>;
  346. interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
  347. #address-cells = <1>;
  348. #size-cells = <0>;
  349. rockchip,grf = <&grf>;
  350. clocks = <&cru PCLK_I2C4>;
  351. clock-names = "i2c";
  352. status = "disabled";
  353. };
  354. uart2: serial@20064000 {
  355. compatible = "snps,dw-apb-uart";
  356. reg = <0x20064000 0x400>;
  357. interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
  358. reg-shift = <2>;
  359. reg-io-width = <1>;
  360. clock-names = "baudclk", "apb_pclk";
  361. clocks = <&cru SCLK_UART2>, <&cru PCLK_UART2>;
  362. status = "disabled";
  363. };
  364. uart3: serial@20068000 {
  365. compatible = "snps,dw-apb-uart";
  366. reg = <0x20068000 0x400>;
  367. interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
  368. reg-shift = <2>;
  369. reg-io-width = <1>;
  370. clock-names = "baudclk", "apb_pclk";
  371. clocks = <&cru SCLK_UART3>, <&cru PCLK_UART3>;
  372. status = "disabled";
  373. };
  374. saradc: saradc@2006c000 {
  375. compatible = "rockchip,saradc";
  376. reg = <0x2006c000 0x100>;
  377. interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
  378. #io-channel-cells = <1>;
  379. clocks = <&cru SCLK_SARADC>, <&cru PCLK_SARADC>;
  380. clock-names = "saradc", "apb_pclk";
  381. resets = <&cru SRST_SARADC>;
  382. reset-names = "saradc-apb";
  383. status = "disabled";
  384. };
  385. spi0: spi@20070000 {
  386. compatible = "rockchip,rk3066-spi";
  387. clocks = <&cru SCLK_SPI0>, <&cru PCLK_SPI0>;
  388. clock-names = "spiclk", "apb_pclk";
  389. interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
  390. reg = <0x20070000 0x1000>;
  391. #address-cells = <1>;
  392. #size-cells = <0>;
  393. dmas = <&dmac2 10>, <&dmac2 11>;
  394. dma-names = "tx", "rx";
  395. status = "disabled";
  396. };
  397. spi1: spi@20074000 {
  398. compatible = "rockchip,rk3066-spi";
  399. clocks = <&cru SCLK_SPI1>, <&cru PCLK_SPI1>;
  400. clock-names = "spiclk", "apb_pclk";
  401. interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
  402. reg = <0x20074000 0x1000>;
  403. #address-cells = <1>;
  404. #size-cells = <0>;
  405. dmas = <&dmac2 12>, <&dmac2 13>;
  406. dma-names = "tx", "rx";
  407. status = "disabled";
  408. };
  409. dmac2: dma-controller@20078000 {
  410. compatible = "arm,pl330", "arm,primecell";
  411. reg = <0x20078000 0x4000>;
  412. interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>,
  413. <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
  414. #dma-cells = <1>;
  415. arm,pl330-broken-no-flushp;
  416. arm,pl330-periph-burst;
  417. clocks = <&cru ACLK_DMA2>;
  418. clock-names = "apb_pclk";
  419. };
  420. };