socfpga.dtsi 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528
  1. /*
  2. * Copyright (C) 2012 Altera <www.altera.com>
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation; either version 2 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. /include/ "skeleton.dtsi"
  18. / {
  19. #address-cells = <1>;
  20. #size-cells = <1>;
  21. aliases {
  22. ethernet0 = &gmac0;
  23. ethernet1 = &gmac1;
  24. serial0 = &uart0;
  25. serial1 = &uart1;
  26. timer0 = &timer0;
  27. timer1 = &timer1;
  28. timer2 = &timer2;
  29. timer3 = &timer3;
  30. };
  31. cpus {
  32. #address-cells = <1>;
  33. #size-cells = <0>;
  34. cpu@0 {
  35. compatible = "arm,cortex-a9";
  36. device_type = "cpu";
  37. reg = <0>;
  38. next-level-cache = <&L2>;
  39. };
  40. cpu@1 {
  41. compatible = "arm,cortex-a9";
  42. device_type = "cpu";
  43. reg = <1>;
  44. next-level-cache = <&L2>;
  45. };
  46. };
  47. intc: intc@fffed000 {
  48. compatible = "arm,cortex-a9-gic";
  49. #interrupt-cells = <3>;
  50. interrupt-controller;
  51. reg = <0xfffed000 0x1000>,
  52. <0xfffec100 0x100>;
  53. };
  54. soc {
  55. #address-cells = <1>;
  56. #size-cells = <1>;
  57. compatible = "simple-bus";
  58. device_type = "soc";
  59. interrupt-parent = <&intc>;
  60. ranges;
  61. amba {
  62. compatible = "arm,amba-bus";
  63. #address-cells = <1>;
  64. #size-cells = <1>;
  65. ranges;
  66. pdma: pdma@ffe01000 {
  67. compatible = "arm,pl330", "arm,primecell";
  68. reg = <0xffe01000 0x1000>;
  69. interrupts = <0 180 4>;
  70. #dma-cells = <1>;
  71. #dma-channels = <8>;
  72. #dma-requests = <32>;
  73. };
  74. };
  75. clkmgr@ffd04000 {
  76. compatible = "altr,clk-mgr";
  77. reg = <0xffd04000 0x1000>;
  78. clocks {
  79. #address-cells = <1>;
  80. #size-cells = <0>;
  81. osc: osc1 {
  82. #clock-cells = <0>;
  83. compatible = "fixed-clock";
  84. };
  85. f2s_periph_ref_clk: f2s_periph_ref_clk {
  86. #clock-cells = <0>;
  87. compatible = "fixed-clock";
  88. clock-frequency = <10000000>;
  89. };
  90. main_pll: main_pll {
  91. #address-cells = <1>;
  92. #size-cells = <0>;
  93. #clock-cells = <0>;
  94. compatible = "altr,socfpga-pll-clock";
  95. clocks = <&osc>;
  96. reg = <0x40>;
  97. mpuclk: mpuclk {
  98. #clock-cells = <0>;
  99. compatible = "altr,socfpga-perip-clk";
  100. clocks = <&main_pll>;
  101. fixed-divider = <2>;
  102. reg = <0x48>;
  103. };
  104. mainclk: mainclk {
  105. #clock-cells = <0>;
  106. compatible = "altr,socfpga-perip-clk";
  107. clocks = <&main_pll>;
  108. fixed-divider = <4>;
  109. reg = <0x4C>;
  110. };
  111. dbg_base_clk: dbg_base_clk {
  112. #clock-cells = <0>;
  113. compatible = "altr,socfpga-perip-clk";
  114. clocks = <&main_pll>;
  115. fixed-divider = <4>;
  116. reg = <0x50>;
  117. };
  118. main_qspi_clk: main_qspi_clk {
  119. #clock-cells = <0>;
  120. compatible = "altr,socfpga-perip-clk";
  121. clocks = <&main_pll>;
  122. reg = <0x54>;
  123. };
  124. main_nand_sdmmc_clk: main_nand_sdmmc_clk {
  125. #clock-cells = <0>;
  126. compatible = "altr,socfpga-perip-clk";
  127. clocks = <&main_pll>;
  128. reg = <0x58>;
  129. };
  130. cfg_s2f_usr0_clk: cfg_s2f_usr0_clk {
  131. #clock-cells = <0>;
  132. compatible = "altr,socfpga-perip-clk";
  133. clocks = <&main_pll>;
  134. reg = <0x5C>;
  135. };
  136. };
  137. periph_pll: periph_pll {
  138. #address-cells = <1>;
  139. #size-cells = <0>;
  140. #clock-cells = <0>;
  141. compatible = "altr,socfpga-pll-clock";
  142. clocks = <&osc>;
  143. reg = <0x80>;
  144. emac0_clk: emac0_clk {
  145. #clock-cells = <0>;
  146. compatible = "altr,socfpga-perip-clk";
  147. clocks = <&periph_pll>;
  148. reg = <0x88>;
  149. };
  150. emac1_clk: emac1_clk {
  151. #clock-cells = <0>;
  152. compatible = "altr,socfpga-perip-clk";
  153. clocks = <&periph_pll>;
  154. reg = <0x8C>;
  155. };
  156. per_qspi_clk: per_qsi_clk {
  157. #clock-cells = <0>;
  158. compatible = "altr,socfpga-perip-clk";
  159. clocks = <&periph_pll>;
  160. reg = <0x90>;
  161. };
  162. per_nand_mmc_clk: per_nand_mmc_clk {
  163. #clock-cells = <0>;
  164. compatible = "altr,socfpga-perip-clk";
  165. clocks = <&periph_pll>;
  166. reg = <0x94>;
  167. };
  168. per_base_clk: per_base_clk {
  169. #clock-cells = <0>;
  170. compatible = "altr,socfpga-perip-clk";
  171. clocks = <&periph_pll>;
  172. reg = <0x98>;
  173. };
  174. s2f_usr1_clk: s2f_usr1_clk {
  175. #clock-cells = <0>;
  176. compatible = "altr,socfpga-perip-clk";
  177. clocks = <&periph_pll>;
  178. reg = <0x9C>;
  179. };
  180. };
  181. sdram_pll: sdram_pll {
  182. #address-cells = <1>;
  183. #size-cells = <0>;
  184. #clock-cells = <0>;
  185. compatible = "altr,socfpga-pll-clock";
  186. clocks = <&osc>;
  187. reg = <0xC0>;
  188. ddr_dqs_clk: ddr_dqs_clk {
  189. #clock-cells = <0>;
  190. compatible = "altr,socfpga-perip-clk";
  191. clocks = <&sdram_pll>;
  192. reg = <0xC8>;
  193. };
  194. ddr_2x_dqs_clk: ddr_2x_dqs_clk {
  195. #clock-cells = <0>;
  196. compatible = "altr,socfpga-perip-clk";
  197. clocks = <&sdram_pll>;
  198. reg = <0xCC>;
  199. };
  200. ddr_dq_clk: ddr_dq_clk {
  201. #clock-cells = <0>;
  202. compatible = "altr,socfpga-perip-clk";
  203. clocks = <&sdram_pll>;
  204. reg = <0xD0>;
  205. };
  206. s2f_usr2_clk: s2f_usr2_clk {
  207. #clock-cells = <0>;
  208. compatible = "altr,socfpga-perip-clk";
  209. clocks = <&sdram_pll>;
  210. reg = <0xD4>;
  211. };
  212. };
  213. mpu_periph_clk: mpu_periph_clk {
  214. #clock-cells = <0>;
  215. compatible = "altr,socfpga-gate-clk";
  216. clocks = <&mpuclk>;
  217. fixed-divider = <4>;
  218. };
  219. mpu_l2_ram_clk: mpu_l2_ram_clk {
  220. #clock-cells = <0>;
  221. compatible = "altr,socfpga-gate-clk";
  222. clocks = <&mpuclk>;
  223. fixed-divider = <2>;
  224. };
  225. l4_main_clk: l4_main_clk {
  226. #clock-cells = <0>;
  227. compatible = "altr,socfpga-gate-clk";
  228. clocks = <&mainclk>;
  229. clk-gate = <0x60 0>;
  230. };
  231. l3_main_clk: l3_main_clk {
  232. #clock-cells = <0>;
  233. compatible = "altr,socfpga-gate-clk";
  234. clocks = <&mainclk>;
  235. };
  236. l3_mp_clk: l3_mp_clk {
  237. #clock-cells = <0>;
  238. compatible = "altr,socfpga-gate-clk";
  239. clocks = <&mainclk>;
  240. div-reg = <0x64 0 2>;
  241. clk-gate = <0x60 1>;
  242. };
  243. l3_sp_clk: l3_sp_clk {
  244. #clock-cells = <0>;
  245. compatible = "altr,socfpga-gate-clk";
  246. clocks = <&mainclk>;
  247. div-reg = <0x64 2 2>;
  248. };
  249. l4_mp_clk: l4_mp_clk {
  250. #clock-cells = <0>;
  251. compatible = "altr,socfpga-gate-clk";
  252. clocks = <&mainclk>, <&per_base_clk>;
  253. div-reg = <0x64 4 3>;
  254. clk-gate = <0x60 2>;
  255. };
  256. l4_sp_clk: l4_sp_clk {
  257. #clock-cells = <0>;
  258. compatible = "altr,socfpga-gate-clk";
  259. clocks = <&mainclk>, <&per_base_clk>;
  260. div-reg = <0x64 7 3>;
  261. clk-gate = <0x60 3>;
  262. };
  263. dbg_at_clk: dbg_at_clk {
  264. #clock-cells = <0>;
  265. compatible = "altr,socfpga-gate-clk";
  266. clocks = <&dbg_base_clk>;
  267. div-reg = <0x68 0 2>;
  268. clk-gate = <0x60 4>;
  269. };
  270. dbg_clk: dbg_clk {
  271. #clock-cells = <0>;
  272. compatible = "altr,socfpga-gate-clk";
  273. clocks = <&dbg_base_clk>;
  274. div-reg = <0x68 2 2>;
  275. clk-gate = <0x60 5>;
  276. };
  277. dbg_trace_clk: dbg_trace_clk {
  278. #clock-cells = <0>;
  279. compatible = "altr,socfpga-gate-clk";
  280. clocks = <&dbg_base_clk>;
  281. div-reg = <0x6C 0 3>;
  282. clk-gate = <0x60 6>;
  283. };
  284. dbg_timer_clk: dbg_timer_clk {
  285. #clock-cells = <0>;
  286. compatible = "altr,socfpga-gate-clk";
  287. clocks = <&dbg_base_clk>;
  288. clk-gate = <0x60 7>;
  289. };
  290. cfg_clk: cfg_clk {
  291. #clock-cells = <0>;
  292. compatible = "altr,socfpga-gate-clk";
  293. clocks = <&cfg_s2f_usr0_clk>;
  294. clk-gate = <0x60 8>;
  295. };
  296. s2f_user0_clk: s2f_user0_clk {
  297. #clock-cells = <0>;
  298. compatible = "altr,socfpga-gate-clk";
  299. clocks = <&cfg_s2f_usr0_clk>;
  300. clk-gate = <0x60 9>;
  301. };
  302. emac_0_clk: emac_0_clk {
  303. #clock-cells = <0>;
  304. compatible = "altr,socfpga-gate-clk";
  305. clocks = <&emac0_clk>;
  306. clk-gate = <0xa0 0>;
  307. };
  308. emac_1_clk: emac_1_clk {
  309. #clock-cells = <0>;
  310. compatible = "altr,socfpga-gate-clk";
  311. clocks = <&emac1_clk>;
  312. clk-gate = <0xa0 1>;
  313. };
  314. usb_mp_clk: usb_mp_clk {
  315. #clock-cells = <0>;
  316. compatible = "altr,socfpga-gate-clk";
  317. clocks = <&per_base_clk>;
  318. clk-gate = <0xa0 2>;
  319. div-reg = <0xa4 0 3>;
  320. };
  321. spi_m_clk: spi_m_clk {
  322. #clock-cells = <0>;
  323. compatible = "altr,socfpga-gate-clk";
  324. clocks = <&per_base_clk>;
  325. clk-gate = <0xa0 3>;
  326. div-reg = <0xa4 3 3>;
  327. };
  328. can0_clk: can0_clk {
  329. #clock-cells = <0>;
  330. compatible = "altr,socfpga-gate-clk";
  331. clocks = <&per_base_clk>;
  332. clk-gate = <0xa0 4>;
  333. div-reg = <0xa4 6 3>;
  334. };
  335. can1_clk: can1_clk {
  336. #clock-cells = <0>;
  337. compatible = "altr,socfpga-gate-clk";
  338. clocks = <&per_base_clk>;
  339. clk-gate = <0xa0 5>;
  340. div-reg = <0xa4 9 3>;
  341. };
  342. gpio_db_clk: gpio_db_clk {
  343. #clock-cells = <0>;
  344. compatible = "altr,socfpga-gate-clk";
  345. clocks = <&per_base_clk>;
  346. clk-gate = <0xa0 6>;
  347. div-reg = <0xa8 0 24>;
  348. };
  349. s2f_user1_clk: s2f_user1_clk {
  350. #clock-cells = <0>;
  351. compatible = "altr,socfpga-gate-clk";
  352. clocks = <&s2f_usr1_clk>;
  353. clk-gate = <0xa0 7>;
  354. };
  355. sdmmc_clk: sdmmc_clk {
  356. #clock-cells = <0>;
  357. compatible = "altr,socfpga-gate-clk";
  358. clocks = <&f2s_periph_ref_clk>, <&main_nand_sdmmc_clk>, <&per_nand_mmc_clk>;
  359. clk-gate = <0xa0 8>;
  360. };
  361. nand_x_clk: nand_x_clk {
  362. #clock-cells = <0>;
  363. compatible = "altr,socfpga-gate-clk";
  364. clocks = <&f2s_periph_ref_clk>, <&main_nand_sdmmc_clk>, <&per_nand_mmc_clk>;
  365. clk-gate = <0xa0 9>;
  366. };
  367. nand_clk: nand_clk {
  368. #clock-cells = <0>;
  369. compatible = "altr,socfpga-gate-clk";
  370. clocks = <&f2s_periph_ref_clk>, <&main_nand_sdmmc_clk>, <&per_nand_mmc_clk>;
  371. clk-gate = <0xa0 10>;
  372. fixed-divider = <4>;
  373. };
  374. qspi_clk: qspi_clk {
  375. #clock-cells = <0>;
  376. compatible = "altr,socfpga-gate-clk";
  377. clocks = <&f2s_periph_ref_clk>, <&main_qspi_clk>, <&per_qspi_clk>;
  378. clk-gate = <0xa0 11>;
  379. };
  380. };
  381. };
  382. gmac0: ethernet@ff700000 {
  383. compatible = "altr,socfpga-stmmac", "snps,dwmac-3.70a", "snps,dwmac";
  384. reg = <0xff700000 0x2000>;
  385. interrupts = <0 115 4>;
  386. interrupt-names = "macirq";
  387. mac-address = [00 00 00 00 00 00];/* Filled in by U-Boot */
  388. clocks = <&emac0_clk>;
  389. clock-names = "stmmaceth";
  390. status = "disabled";
  391. };
  392. gmac1: ethernet@ff702000 {
  393. compatible = "altr,socfpga-stmmac", "snps,dwmac-3.70a", "snps,dwmac";
  394. reg = <0xff702000 0x2000>;
  395. interrupts = <0 120 4>;
  396. interrupt-names = "macirq";
  397. mac-address = [00 00 00 00 00 00];/* Filled in by U-Boot */
  398. clocks = <&emac1_clk>;
  399. clock-names = "stmmaceth";
  400. status = "disabled";
  401. };
  402. L2: l2-cache@fffef000 {
  403. compatible = "arm,pl310-cache";
  404. reg = <0xfffef000 0x1000>;
  405. interrupts = <0 38 0x04>;
  406. cache-unified;
  407. cache-level = <2>;
  408. };
  409. /* Local timer */
  410. timer@fffec600 {
  411. compatible = "arm,cortex-a9-twd-timer";
  412. reg = <0xfffec600 0x100>;
  413. interrupts = <1 13 0xf04>;
  414. };
  415. timer0: timer0@ffc08000 {
  416. compatible = "snps,dw-apb-timer-sp";
  417. interrupts = <0 167 4>;
  418. reg = <0xffc08000 0x1000>;
  419. };
  420. timer1: timer1@ffc09000 {
  421. compatible = "snps,dw-apb-timer-sp";
  422. interrupts = <0 168 4>;
  423. reg = <0xffc09000 0x1000>;
  424. };
  425. timer2: timer2@ffd00000 {
  426. compatible = "snps,dw-apb-timer-osc";
  427. interrupts = <0 169 4>;
  428. reg = <0xffd00000 0x1000>;
  429. };
  430. timer3: timer3@ffd01000 {
  431. compatible = "snps,dw-apb-timer-osc";
  432. interrupts = <0 170 4>;
  433. reg = <0xffd01000 0x1000>;
  434. };
  435. uart0: serial0@ffc02000 {
  436. compatible = "snps,dw-apb-uart";
  437. reg = <0xffc02000 0x1000>;
  438. interrupts = <0 162 4>;
  439. reg-shift = <2>;
  440. reg-io-width = <4>;
  441. };
  442. uart1: serial1@ffc03000 {
  443. compatible = "snps,dw-apb-uart";
  444. reg = <0xffc03000 0x1000>;
  445. interrupts = <0 163 4>;
  446. reg-shift = <2>;
  447. reg-io-width = <4>;
  448. };
  449. rstmgr@ffd05000 {
  450. compatible = "altr,rst-mgr";
  451. reg = <0xffd05000 0x1000>;
  452. };
  453. sysmgr@ffd08000 {
  454. compatible = "altr,sys-mgr";
  455. reg = <0xffd08000 0x4000>;
  456. };
  457. };
  458. };