exynos5250.dtsi 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644
  1. /*
  2. * SAMSUNG EXYNOS5250 SoC device tree source
  3. *
  4. * Copyright (c) 2012 Samsung Electronics Co., Ltd.
  5. * http://www.samsung.com
  6. *
  7. * SAMSUNG EXYNOS5250 SoC device nodes are listed in this file.
  8. * EXYNOS5250 based board files can include this file and provide
  9. * values for board specfic bindings.
  10. *
  11. * Note: This file does not include device nodes for all the controllers in
  12. * EXYNOS5250 SoC. As device tree coverage for EXYNOS5250 increases,
  13. * additional nodes can be added to this file.
  14. *
  15. * This program is free software; you can redistribute it and/or modify
  16. * it under the terms of the GNU General Public License version 2 as
  17. * published by the Free Software Foundation.
  18. */
  19. #include "exynos5.dtsi"
  20. #include "exynos5250-pinctrl.dtsi"
  21. #include <dt-bindings/clk/exynos-audss-clk.h>
  22. / {
  23. compatible = "samsung,exynos5250";
  24. aliases {
  25. spi0 = &spi_0;
  26. spi1 = &spi_1;
  27. spi2 = &spi_2;
  28. gsc0 = &gsc_0;
  29. gsc1 = &gsc_1;
  30. gsc2 = &gsc_2;
  31. gsc3 = &gsc_3;
  32. mshc0 = &dwmmc_0;
  33. mshc1 = &dwmmc_1;
  34. mshc2 = &dwmmc_2;
  35. mshc3 = &dwmmc_3;
  36. i2c0 = &i2c_0;
  37. i2c1 = &i2c_1;
  38. i2c2 = &i2c_2;
  39. i2c3 = &i2c_3;
  40. i2c4 = &i2c_4;
  41. i2c5 = &i2c_5;
  42. i2c6 = &i2c_6;
  43. i2c7 = &i2c_7;
  44. i2c8 = &i2c_8;
  45. pinctrl0 = &pinctrl_0;
  46. pinctrl1 = &pinctrl_1;
  47. pinctrl2 = &pinctrl_2;
  48. pinctrl3 = &pinctrl_3;
  49. };
  50. cpus {
  51. #address-cells = <1>;
  52. #size-cells = <0>;
  53. cpu@0 {
  54. device_type = "cpu";
  55. compatible = "arm,cortex-a15";
  56. reg = <0>;
  57. };
  58. cpu@1 {
  59. device_type = "cpu";
  60. compatible = "arm,cortex-a15";
  61. reg = <1>;
  62. };
  63. };
  64. pd_gsc: gsc-power-domain@0x10044000 {
  65. compatible = "samsung,exynos4210-pd";
  66. reg = <0x10044000 0x20>;
  67. };
  68. pd_mfc: mfc-power-domain@0x10044040 {
  69. compatible = "samsung,exynos4210-pd";
  70. reg = <0x10044040 0x20>;
  71. };
  72. clock: clock-controller@0x10010000 {
  73. compatible = "samsung,exynos5250-clock";
  74. reg = <0x10010000 0x30000>;
  75. #clock-cells = <1>;
  76. };
  77. clock_audss: audss-clock-controller@3810000 {
  78. compatible = "samsung,exynos5250-audss-clock";
  79. reg = <0x03810000 0x0C>;
  80. #clock-cells = <1>;
  81. };
  82. timer {
  83. compatible = "arm,armv7-timer";
  84. interrupts = <1 13 0xf08>,
  85. <1 14 0xf08>,
  86. <1 11 0xf08>,
  87. <1 10 0xf08>;
  88. };
  89. mct@101C0000 {
  90. compatible = "samsung,exynos4210-mct";
  91. reg = <0x101C0000 0x800>;
  92. interrupt-controller;
  93. #interrups-cells = <2>;
  94. interrupt-parent = <&mct_map>;
  95. interrupts = <0 0>, <1 0>, <2 0>, <3 0>,
  96. <4 0>, <5 0>;
  97. clocks = <&clock 1>, <&clock 335>;
  98. clock-names = "fin_pll", "mct";
  99. mct_map: mct-map {
  100. #interrupt-cells = <2>;
  101. #address-cells = <0>;
  102. #size-cells = <0>;
  103. interrupt-map = <0x0 0 &combiner 23 3>,
  104. <0x1 0 &combiner 23 4>,
  105. <0x2 0 &combiner 25 2>,
  106. <0x3 0 &combiner 25 3>,
  107. <0x4 0 &gic 0 120 0>,
  108. <0x5 0 &gic 0 121 0>;
  109. };
  110. };
  111. pmu {
  112. compatible = "arm,cortex-a15-pmu";
  113. interrupt-parent = <&combiner>;
  114. interrupts = <1 2>, <22 4>;
  115. };
  116. pinctrl_0: pinctrl@11400000 {
  117. compatible = "samsung,exynos5250-pinctrl";
  118. reg = <0x11400000 0x1000>;
  119. interrupts = <0 46 0>;
  120. wakup_eint: wakeup-interrupt-controller {
  121. compatible = "samsung,exynos4210-wakeup-eint";
  122. interrupt-parent = <&gic>;
  123. interrupts = <0 32 0>;
  124. };
  125. };
  126. pinctrl_1: pinctrl@13400000 {
  127. compatible = "samsung,exynos5250-pinctrl";
  128. reg = <0x13400000 0x1000>;
  129. interrupts = <0 45 0>;
  130. };
  131. pinctrl_2: pinctrl@10d10000 {
  132. compatible = "samsung,exynos5250-pinctrl";
  133. reg = <0x10d10000 0x1000>;
  134. interrupts = <0 50 0>;
  135. };
  136. pinctrl_3: pinctrl@03860000 {
  137. compatible = "samsung,exynos5250-pinctrl";
  138. reg = <0x03860000 0x1000>;
  139. interrupts = <0 47 0>;
  140. };
  141. watchdog {
  142. clocks = <&clock 336>;
  143. clock-names = "watchdog";
  144. };
  145. g2d@10850000 {
  146. compatible = "samsung,exynos5250-g2d";
  147. reg = <0x10850000 0x1000>;
  148. interrupts = <0 91 0>;
  149. clocks = <&clock 345>;
  150. clock-names = "fimg2d";
  151. };
  152. codec@11000000 {
  153. compatible = "samsung,mfc-v6";
  154. reg = <0x11000000 0x10000>;
  155. interrupts = <0 96 0>;
  156. samsung,power-domain = <&pd_mfc>;
  157. clocks = <&clock 266>;
  158. clock-names = "mfc";
  159. };
  160. rtc {
  161. clocks = <&clock 337>;
  162. clock-names = "rtc";
  163. };
  164. tmu@10060000 {
  165. compatible = "samsung,exynos5250-tmu";
  166. reg = <0x10060000 0x100>;
  167. interrupts = <0 65 0>;
  168. clocks = <&clock 338>;
  169. clock-names = "tmu_apbif";
  170. };
  171. serial@12C00000 {
  172. clocks = <&clock 289>, <&clock 146>;
  173. clock-names = "uart", "clk_uart_baud0";
  174. };
  175. serial@12C10000 {
  176. clocks = <&clock 290>, <&clock 147>;
  177. clock-names = "uart", "clk_uart_baud0";
  178. };
  179. serial@12C20000 {
  180. clocks = <&clock 291>, <&clock 148>;
  181. clock-names = "uart", "clk_uart_baud0";
  182. };
  183. serial@12C30000 {
  184. clocks = <&clock 292>, <&clock 149>;
  185. clock-names = "uart", "clk_uart_baud0";
  186. };
  187. sata@122F0000 {
  188. compatible = "samsung,exynos5-sata-ahci";
  189. reg = <0x122F0000 0x1ff>;
  190. interrupts = <0 115 0>;
  191. clocks = <&clock 277>, <&clock 143>;
  192. clock-names = "sata", "sclk_sata";
  193. };
  194. sata-phy@12170000 {
  195. compatible = "samsung,exynos5-sata-phy";
  196. reg = <0x12170000 0x1ff>;
  197. };
  198. i2c_0: i2c@12C60000 {
  199. compatible = "samsung,s3c2440-i2c";
  200. reg = <0x12C60000 0x100>;
  201. interrupts = <0 56 0>;
  202. #address-cells = <1>;
  203. #size-cells = <0>;
  204. clocks = <&clock 294>;
  205. clock-names = "i2c";
  206. pinctrl-names = "default";
  207. pinctrl-0 = <&i2c0_bus>;
  208. };
  209. i2c_1: i2c@12C70000 {
  210. compatible = "samsung,s3c2440-i2c";
  211. reg = <0x12C70000 0x100>;
  212. interrupts = <0 57 0>;
  213. #address-cells = <1>;
  214. #size-cells = <0>;
  215. clocks = <&clock 295>;
  216. clock-names = "i2c";
  217. pinctrl-names = "default";
  218. pinctrl-0 = <&i2c1_bus>;
  219. };
  220. i2c_2: i2c@12C80000 {
  221. compatible = "samsung,s3c2440-i2c";
  222. reg = <0x12C80000 0x100>;
  223. interrupts = <0 58 0>;
  224. #address-cells = <1>;
  225. #size-cells = <0>;
  226. clocks = <&clock 296>;
  227. clock-names = "i2c";
  228. pinctrl-names = "default";
  229. pinctrl-0 = <&i2c2_bus>;
  230. };
  231. i2c_3: i2c@12C90000 {
  232. compatible = "samsung,s3c2440-i2c";
  233. reg = <0x12C90000 0x100>;
  234. interrupts = <0 59 0>;
  235. #address-cells = <1>;
  236. #size-cells = <0>;
  237. clocks = <&clock 297>;
  238. clock-names = "i2c";
  239. pinctrl-names = "default";
  240. pinctrl-0 = <&i2c3_bus>;
  241. };
  242. i2c_4: i2c@12CA0000 {
  243. compatible = "samsung,s3c2440-i2c";
  244. reg = <0x12CA0000 0x100>;
  245. interrupts = <0 60 0>;
  246. #address-cells = <1>;
  247. #size-cells = <0>;
  248. clocks = <&clock 298>;
  249. clock-names = "i2c";
  250. pinctrl-names = "default";
  251. pinctrl-0 = <&i2c4_bus>;
  252. };
  253. i2c_5: i2c@12CB0000 {
  254. compatible = "samsung,s3c2440-i2c";
  255. reg = <0x12CB0000 0x100>;
  256. interrupts = <0 61 0>;
  257. #address-cells = <1>;
  258. #size-cells = <0>;
  259. clocks = <&clock 299>;
  260. clock-names = "i2c";
  261. pinctrl-names = "default";
  262. pinctrl-0 = <&i2c5_bus>;
  263. };
  264. i2c_6: i2c@12CC0000 {
  265. compatible = "samsung,s3c2440-i2c";
  266. reg = <0x12CC0000 0x100>;
  267. interrupts = <0 62 0>;
  268. #address-cells = <1>;
  269. #size-cells = <0>;
  270. clocks = <&clock 300>;
  271. clock-names = "i2c";
  272. pinctrl-names = "default";
  273. pinctrl-0 = <&i2c6_bus>;
  274. };
  275. i2c_7: i2c@12CD0000 {
  276. compatible = "samsung,s3c2440-i2c";
  277. reg = <0x12CD0000 0x100>;
  278. interrupts = <0 63 0>;
  279. #address-cells = <1>;
  280. #size-cells = <0>;
  281. clocks = <&clock 301>;
  282. clock-names = "i2c";
  283. pinctrl-names = "default";
  284. pinctrl-0 = <&i2c7_bus>;
  285. };
  286. i2c_8: i2c@12CE0000 {
  287. compatible = "samsung,s3c2440-hdmiphy-i2c";
  288. reg = <0x12CE0000 0x1000>;
  289. interrupts = <0 64 0>;
  290. #address-cells = <1>;
  291. #size-cells = <0>;
  292. clocks = <&clock 302>;
  293. clock-names = "i2c";
  294. };
  295. i2c@121D0000 {
  296. compatible = "samsung,exynos5-sata-phy-i2c";
  297. reg = <0x121D0000 0x100>;
  298. #address-cells = <1>;
  299. #size-cells = <0>;
  300. clocks = <&clock 288>;
  301. clock-names = "i2c";
  302. };
  303. spi_0: spi@12d20000 {
  304. compatible = "samsung,exynos4210-spi";
  305. reg = <0x12d20000 0x100>;
  306. interrupts = <0 66 0>;
  307. dmas = <&pdma0 5
  308. &pdma0 4>;
  309. dma-names = "tx", "rx";
  310. #address-cells = <1>;
  311. #size-cells = <0>;
  312. clocks = <&clock 304>, <&clock 154>;
  313. clock-names = "spi", "spi_busclk0";
  314. pinctrl-names = "default";
  315. pinctrl-0 = <&spi0_bus>;
  316. };
  317. spi_1: spi@12d30000 {
  318. compatible = "samsung,exynos4210-spi";
  319. reg = <0x12d30000 0x100>;
  320. interrupts = <0 67 0>;
  321. dmas = <&pdma1 5
  322. &pdma1 4>;
  323. dma-names = "tx", "rx";
  324. #address-cells = <1>;
  325. #size-cells = <0>;
  326. clocks = <&clock 305>, <&clock 155>;
  327. clock-names = "spi", "spi_busclk0";
  328. pinctrl-names = "default";
  329. pinctrl-0 = <&spi1_bus>;
  330. };
  331. spi_2: spi@12d40000 {
  332. compatible = "samsung,exynos4210-spi";
  333. reg = <0x12d40000 0x100>;
  334. interrupts = <0 68 0>;
  335. dmas = <&pdma0 7
  336. &pdma0 6>;
  337. dma-names = "tx", "rx";
  338. #address-cells = <1>;
  339. #size-cells = <0>;
  340. clocks = <&clock 306>, <&clock 156>;
  341. clock-names = "spi", "spi_busclk0";
  342. pinctrl-names = "default";
  343. pinctrl-0 = <&spi2_bus>;
  344. };
  345. dwmmc_0: dwmmc0@12200000 {
  346. reg = <0x12200000 0x1000>;
  347. clocks = <&clock 280>, <&clock 139>;
  348. clock-names = "biu", "ciu";
  349. };
  350. dwmmc_1: dwmmc1@12210000 {
  351. reg = <0x12210000 0x1000>;
  352. clocks = <&clock 281>, <&clock 140>;
  353. clock-names = "biu", "ciu";
  354. };
  355. dwmmc_2: dwmmc2@12220000 {
  356. reg = <0x12220000 0x1000>;
  357. clocks = <&clock 282>, <&clock 141>;
  358. clock-names = "biu", "ciu";
  359. };
  360. dwmmc_3: dwmmc3@12230000 {
  361. compatible = "samsung,exynos5250-dw-mshc";
  362. reg = <0x12230000 0x1000>;
  363. interrupts = <0 78 0>;
  364. #address-cells = <1>;
  365. #size-cells = <0>;
  366. clocks = <&clock 283>, <&clock 142>;
  367. clock-names = "biu", "ciu";
  368. };
  369. i2s0: i2s@03830000 {
  370. compatible = "samsung,i2s-v5";
  371. reg = <0x03830000 0x100>;
  372. dmas = <&pdma0 10
  373. &pdma0 9
  374. &pdma0 8>;
  375. dma-names = "tx", "rx", "tx-sec";
  376. clocks = <&clock_audss EXYNOS_I2S_BUS>,
  377. <&clock_audss EXYNOS_I2S_BUS>,
  378. <&clock_audss EXYNOS_SCLK_I2S>;
  379. clock-names = "iis", "i2s_opclk0", "i2s_opclk1";
  380. samsung,supports-6ch;
  381. samsung,supports-rstclr;
  382. samsung,supports-secdai;
  383. samsung,idma-addr = <0x03000000>;
  384. pinctrl-names = "default";
  385. pinctrl-0 = <&i2s0_bus>;
  386. };
  387. i2s1: i2s@12D60000 {
  388. compatible = "samsung,i2s-v5";
  389. reg = <0x12D60000 0x100>;
  390. dmas = <&pdma1 12
  391. &pdma1 11>;
  392. dma-names = "tx", "rx";
  393. clocks = <&clock 307>, <&clock 157>;
  394. clock-names = "iis", "i2s_opclk0";
  395. pinctrl-names = "default";
  396. pinctrl-0 = <&i2s1_bus>;
  397. };
  398. i2s2: i2s@12D70000 {
  399. compatible = "samsung,i2s-v5";
  400. reg = <0x12D70000 0x100>;
  401. dmas = <&pdma0 12
  402. &pdma0 11>;
  403. dma-names = "tx", "rx";
  404. clocks = <&clock 308>, <&clock 158>;
  405. clock-names = "iis", "i2s_opclk0";
  406. pinctrl-names = "default";
  407. pinctrl-0 = <&i2s2_bus>;
  408. };
  409. usb@12000000 {
  410. compatible = "samsung,exynos5250-dwusb3";
  411. clocks = <&clock 286>;
  412. clock-names = "usbdrd30";
  413. #address-cells = <1>;
  414. #size-cells = <1>;
  415. ranges;
  416. dwc3 {
  417. compatible = "synopsys,dwc3";
  418. reg = <0x12000000 0x10000>;
  419. interrupts = <0 72 0>;
  420. usb-phy = <&usb2_phy &usb3_phy>;
  421. };
  422. };
  423. usb3_phy: usbphy@12100000 {
  424. compatible = "samsung,exynos5250-usb3phy";
  425. reg = <0x12100000 0x100>;
  426. clocks = <&clock 1>, <&clock 286>;
  427. clock-names = "ext_xtal", "usbdrd30";
  428. #address-cells = <1>;
  429. #size-cells = <1>;
  430. ranges;
  431. usbphy-sys {
  432. reg = <0x10040704 0x8>;
  433. };
  434. };
  435. usb@12110000 {
  436. compatible = "samsung,exynos4210-ehci";
  437. reg = <0x12110000 0x100>;
  438. interrupts = <0 71 0>;
  439. clocks = <&clock 285>;
  440. clock-names = "usbhost";
  441. };
  442. usb@12120000 {
  443. compatible = "samsung,exynos4210-ohci";
  444. reg = <0x12120000 0x100>;
  445. interrupts = <0 71 0>;
  446. clocks = <&clock 285>;
  447. clock-names = "usbhost";
  448. };
  449. usb2_phy: usbphy@12130000 {
  450. compatible = "samsung,exynos5250-usb2phy";
  451. reg = <0x12130000 0x100>;
  452. clocks = <&clock 1>, <&clock 285>;
  453. clock-names = "ext_xtal", "usbhost";
  454. #address-cells = <1>;
  455. #size-cells = <1>;
  456. ranges;
  457. usbphy-sys {
  458. reg = <0x10040704 0x8>,
  459. <0x10050230 0x4>;
  460. };
  461. };
  462. amba {
  463. #address-cells = <1>;
  464. #size-cells = <1>;
  465. compatible = "arm,amba-bus";
  466. interrupt-parent = <&gic>;
  467. ranges;
  468. pdma0: pdma@121A0000 {
  469. compatible = "arm,pl330", "arm,primecell";
  470. reg = <0x121A0000 0x1000>;
  471. interrupts = <0 34 0>;
  472. clocks = <&clock 275>;
  473. clock-names = "apb_pclk";
  474. #dma-cells = <1>;
  475. #dma-channels = <8>;
  476. #dma-requests = <32>;
  477. };
  478. pdma1: pdma@121B0000 {
  479. compatible = "arm,pl330", "arm,primecell";
  480. reg = <0x121B0000 0x1000>;
  481. interrupts = <0 35 0>;
  482. clocks = <&clock 276>;
  483. clock-names = "apb_pclk";
  484. #dma-cells = <1>;
  485. #dma-channels = <8>;
  486. #dma-requests = <32>;
  487. };
  488. mdma0: mdma@10800000 {
  489. compatible = "arm,pl330", "arm,primecell";
  490. reg = <0x10800000 0x1000>;
  491. interrupts = <0 33 0>;
  492. clocks = <&clock 271>;
  493. clock-names = "apb_pclk";
  494. #dma-cells = <1>;
  495. #dma-channels = <8>;
  496. #dma-requests = <1>;
  497. };
  498. mdma1: mdma@11C10000 {
  499. compatible = "arm,pl330", "arm,primecell";
  500. reg = <0x11C10000 0x1000>;
  501. interrupts = <0 124 0>;
  502. clocks = <&clock 271>;
  503. clock-names = "apb_pclk";
  504. #dma-cells = <1>;
  505. #dma-channels = <8>;
  506. #dma-requests = <1>;
  507. };
  508. };
  509. gsc_0: gsc@0x13e00000 {
  510. compatible = "samsung,exynos5-gsc";
  511. reg = <0x13e00000 0x1000>;
  512. interrupts = <0 85 0>;
  513. samsung,power-domain = <&pd_gsc>;
  514. clocks = <&clock 256>;
  515. clock-names = "gscl";
  516. };
  517. gsc_1: gsc@0x13e10000 {
  518. compatible = "samsung,exynos5-gsc";
  519. reg = <0x13e10000 0x1000>;
  520. interrupts = <0 86 0>;
  521. samsung,power-domain = <&pd_gsc>;
  522. clocks = <&clock 257>;
  523. clock-names = "gscl";
  524. };
  525. gsc_2: gsc@0x13e20000 {
  526. compatible = "samsung,exynos5-gsc";
  527. reg = <0x13e20000 0x1000>;
  528. interrupts = <0 87 0>;
  529. samsung,power-domain = <&pd_gsc>;
  530. clocks = <&clock 258>;
  531. clock-names = "gscl";
  532. };
  533. gsc_3: gsc@0x13e30000 {
  534. compatible = "samsung,exynos5-gsc";
  535. reg = <0x13e30000 0x1000>;
  536. interrupts = <0 88 0>;
  537. samsung,power-domain = <&pd_gsc>;
  538. clocks = <&clock 259>;
  539. clock-names = "gscl";
  540. };
  541. hdmi {
  542. compatible = "samsung,exynos4212-hdmi";
  543. reg = <0x14530000 0x70000>;
  544. interrupts = <0 95 0>;
  545. clocks = <&clock 333>, <&clock 136>, <&clock 137>,
  546. <&clock 333>, <&clock 333>;
  547. clock-names = "hdmi", "sclk_hdmi", "sclk_pixel",
  548. "sclk_hdmiphy", "hdmiphy";
  549. };
  550. mixer {
  551. compatible = "samsung,exynos5250-mixer";
  552. reg = <0x14450000 0x10000>;
  553. interrupts = <0 94 0>;
  554. };
  555. dp_phy: video-phy@10040720 {
  556. compatible = "samsung,exynos5250-dp-video-phy";
  557. reg = <0x10040720 4>;
  558. #phy-cells = <0>;
  559. };
  560. dp-controller@145B0000 {
  561. clocks = <&clock 342>;
  562. clock-names = "dp";
  563. phys = <&dp_phy>;
  564. phy-names = "dp";
  565. };
  566. fimd@14400000 {
  567. clocks = <&clock 133>, <&clock 339>;
  568. clock-names = "sclk_fimd", "fimd";
  569. };
  570. };