mpc8572ds.dts 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822
  1. /*
  2. * MPC8572 DS Device Tree Source
  3. *
  4. * Copyright 2007-2009 Freescale Semiconductor Inc.
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License as published by the
  8. * Free Software Foundation; either version 2 of the License, or (at your
  9. * option) any later version.
  10. */
  11. /dts-v1/;
  12. / {
  13. model = "fsl,MPC8572DS";
  14. compatible = "fsl,MPC8572DS";
  15. #address-cells = <2>;
  16. #size-cells = <2>;
  17. aliases {
  18. ethernet0 = &enet0;
  19. ethernet1 = &enet1;
  20. ethernet2 = &enet2;
  21. ethernet3 = &enet3;
  22. serial0 = &serial0;
  23. serial1 = &serial1;
  24. pci0 = &pci0;
  25. pci1 = &pci1;
  26. pci2 = &pci2;
  27. };
  28. cpus {
  29. #address-cells = <1>;
  30. #size-cells = <0>;
  31. PowerPC,8572@0 {
  32. device_type = "cpu";
  33. reg = <0x0>;
  34. d-cache-line-size = <32>; // 32 bytes
  35. i-cache-line-size = <32>; // 32 bytes
  36. d-cache-size = <0x8000>; // L1, 32K
  37. i-cache-size = <0x8000>; // L1, 32K
  38. timebase-frequency = <0>;
  39. bus-frequency = <0>;
  40. clock-frequency = <0>;
  41. next-level-cache = <&L2>;
  42. };
  43. PowerPC,8572@1 {
  44. device_type = "cpu";
  45. reg = <0x1>;
  46. d-cache-line-size = <32>; // 32 bytes
  47. i-cache-line-size = <32>; // 32 bytes
  48. d-cache-size = <0x8000>; // L1, 32K
  49. i-cache-size = <0x8000>; // L1, 32K
  50. timebase-frequency = <0>;
  51. bus-frequency = <0>;
  52. clock-frequency = <0>;
  53. next-level-cache = <&L2>;
  54. };
  55. };
  56. memory {
  57. device_type = "memory";
  58. };
  59. localbus@ffe05000 {
  60. #address-cells = <2>;
  61. #size-cells = <1>;
  62. compatible = "fsl,mpc8572-elbc", "fsl,elbc", "simple-bus";
  63. reg = <0 0xffe05000 0 0x1000>;
  64. interrupts = <19 2>;
  65. interrupt-parent = <&mpic>;
  66. ranges = <0x0 0x0 0x0 0xe8000000 0x08000000
  67. 0x1 0x0 0x0 0xe0000000 0x08000000
  68. 0x2 0x0 0x0 0xffa00000 0x00040000
  69. 0x3 0x0 0x0 0xffdf0000 0x00008000
  70. 0x4 0x0 0x0 0xffa40000 0x00040000
  71. 0x5 0x0 0x0 0xffa80000 0x00040000
  72. 0x6 0x0 0x0 0xffac0000 0x00040000>;
  73. nor@0,0 {
  74. #address-cells = <1>;
  75. #size-cells = <1>;
  76. compatible = "cfi-flash";
  77. reg = <0x0 0x0 0x8000000>;
  78. bank-width = <2>;
  79. device-width = <1>;
  80. ramdisk@0 {
  81. reg = <0x0 0x03000000>;
  82. read-only;
  83. };
  84. diagnostic@3000000 {
  85. reg = <0x03000000 0x00e00000>;
  86. read-only;
  87. };
  88. dink@3e00000 {
  89. reg = <0x03e00000 0x00200000>;
  90. read-only;
  91. };
  92. kernel@4000000 {
  93. reg = <0x04000000 0x00400000>;
  94. read-only;
  95. };
  96. jffs2@4400000 {
  97. reg = <0x04400000 0x03b00000>;
  98. };
  99. dtb@7f00000 {
  100. reg = <0x07f00000 0x00080000>;
  101. read-only;
  102. };
  103. u-boot@7f80000 {
  104. reg = <0x07f80000 0x00080000>;
  105. read-only;
  106. };
  107. };
  108. nand@2,0 {
  109. #address-cells = <1>;
  110. #size-cells = <1>;
  111. compatible = "fsl,mpc8572-fcm-nand",
  112. "fsl,elbc-fcm-nand";
  113. reg = <0x2 0x0 0x40000>;
  114. u-boot@0 {
  115. reg = <0x0 0x02000000>;
  116. read-only;
  117. };
  118. jffs2@2000000 {
  119. reg = <0x02000000 0x10000000>;
  120. };
  121. ramdisk@12000000 {
  122. reg = <0x12000000 0x08000000>;
  123. read-only;
  124. };
  125. kernel@1a000000 {
  126. reg = <0x1a000000 0x04000000>;
  127. };
  128. dtb@1e000000 {
  129. reg = <0x1e000000 0x01000000>;
  130. read-only;
  131. };
  132. empty@1f000000 {
  133. reg = <0x1f000000 0x21000000>;
  134. };
  135. };
  136. nand@4,0 {
  137. compatible = "fsl,mpc8572-fcm-nand",
  138. "fsl,elbc-fcm-nand";
  139. reg = <0x4 0x0 0x40000>;
  140. };
  141. nand@5,0 {
  142. compatible = "fsl,mpc8572-fcm-nand",
  143. "fsl,elbc-fcm-nand";
  144. reg = <0x5 0x0 0x40000>;
  145. };
  146. nand@6,0 {
  147. compatible = "fsl,mpc8572-fcm-nand",
  148. "fsl,elbc-fcm-nand";
  149. reg = <0x6 0x0 0x40000>;
  150. };
  151. };
  152. soc8572@ffe00000 {
  153. #address-cells = <1>;
  154. #size-cells = <1>;
  155. device_type = "soc";
  156. compatible = "simple-bus";
  157. ranges = <0x0 0 0xffe00000 0x100000>;
  158. bus-frequency = <0>; // Filled out by uboot.
  159. ecm-law@0 {
  160. compatible = "fsl,ecm-law";
  161. reg = <0x0 0x1000>;
  162. fsl,num-laws = <12>;
  163. };
  164. ecm@1000 {
  165. compatible = "fsl,mpc8572-ecm", "fsl,ecm";
  166. reg = <0x1000 0x1000>;
  167. interrupts = <17 2>;
  168. interrupt-parent = <&mpic>;
  169. };
  170. memory-controller@2000 {
  171. compatible = "fsl,mpc8572-memory-controller";
  172. reg = <0x2000 0x1000>;
  173. interrupt-parent = <&mpic>;
  174. interrupts = <18 2>;
  175. };
  176. memory-controller@6000 {
  177. compatible = "fsl,mpc8572-memory-controller";
  178. reg = <0x6000 0x1000>;
  179. interrupt-parent = <&mpic>;
  180. interrupts = <18 2>;
  181. };
  182. L2: l2-cache-controller@20000 {
  183. compatible = "fsl,mpc8572-l2-cache-controller";
  184. reg = <0x20000 0x1000>;
  185. cache-line-size = <32>; // 32 bytes
  186. cache-size = <0x100000>; // L2, 1M
  187. interrupt-parent = <&mpic>;
  188. interrupts = <16 2>;
  189. };
  190. i2c@3000 {
  191. #address-cells = <1>;
  192. #size-cells = <0>;
  193. cell-index = <0>;
  194. compatible = "fsl-i2c";
  195. reg = <0x3000 0x100>;
  196. interrupts = <43 2>;
  197. interrupt-parent = <&mpic>;
  198. dfsrr;
  199. };
  200. i2c@3100 {
  201. #address-cells = <1>;
  202. #size-cells = <0>;
  203. cell-index = <1>;
  204. compatible = "fsl-i2c";
  205. reg = <0x3100 0x100>;
  206. interrupts = <43 2>;
  207. interrupt-parent = <&mpic>;
  208. dfsrr;
  209. };
  210. dma@c300 {
  211. #address-cells = <1>;
  212. #size-cells = <1>;
  213. compatible = "fsl,mpc8572-dma", "fsl,eloplus-dma";
  214. reg = <0xc300 0x4>;
  215. ranges = <0x0 0xc100 0x200>;
  216. cell-index = <1>;
  217. dma-channel@0 {
  218. compatible = "fsl,mpc8572-dma-channel",
  219. "fsl,eloplus-dma-channel";
  220. reg = <0x0 0x80>;
  221. cell-index = <0>;
  222. interrupt-parent = <&mpic>;
  223. interrupts = <76 2>;
  224. };
  225. dma-channel@80 {
  226. compatible = "fsl,mpc8572-dma-channel",
  227. "fsl,eloplus-dma-channel";
  228. reg = <0x80 0x80>;
  229. cell-index = <1>;
  230. interrupt-parent = <&mpic>;
  231. interrupts = <77 2>;
  232. };
  233. dma-channel@100 {
  234. compatible = "fsl,mpc8572-dma-channel",
  235. "fsl,eloplus-dma-channel";
  236. reg = <0x100 0x80>;
  237. cell-index = <2>;
  238. interrupt-parent = <&mpic>;
  239. interrupts = <78 2>;
  240. };
  241. dma-channel@180 {
  242. compatible = "fsl,mpc8572-dma-channel",
  243. "fsl,eloplus-dma-channel";
  244. reg = <0x180 0x80>;
  245. cell-index = <3>;
  246. interrupt-parent = <&mpic>;
  247. interrupts = <79 2>;
  248. };
  249. };
  250. dma@21300 {
  251. #address-cells = <1>;
  252. #size-cells = <1>;
  253. compatible = "fsl,mpc8572-dma", "fsl,eloplus-dma";
  254. reg = <0x21300 0x4>;
  255. ranges = <0x0 0x21100 0x200>;
  256. cell-index = <0>;
  257. dma-channel@0 {
  258. compatible = "fsl,mpc8572-dma-channel",
  259. "fsl,eloplus-dma-channel";
  260. reg = <0x0 0x80>;
  261. cell-index = <0>;
  262. interrupt-parent = <&mpic>;
  263. interrupts = <20 2>;
  264. };
  265. dma-channel@80 {
  266. compatible = "fsl,mpc8572-dma-channel",
  267. "fsl,eloplus-dma-channel";
  268. reg = <0x80 0x80>;
  269. cell-index = <1>;
  270. interrupt-parent = <&mpic>;
  271. interrupts = <21 2>;
  272. };
  273. dma-channel@100 {
  274. compatible = "fsl,mpc8572-dma-channel",
  275. "fsl,eloplus-dma-channel";
  276. reg = <0x100 0x80>;
  277. cell-index = <2>;
  278. interrupt-parent = <&mpic>;
  279. interrupts = <22 2>;
  280. };
  281. dma-channel@180 {
  282. compatible = "fsl,mpc8572-dma-channel",
  283. "fsl,eloplus-dma-channel";
  284. reg = <0x180 0x80>;
  285. cell-index = <3>;
  286. interrupt-parent = <&mpic>;
  287. interrupts = <23 2>;
  288. };
  289. };
  290. ptp_clock@24E00 {
  291. compatible = "fsl,etsec-ptp";
  292. reg = <0x24E00 0xB0>;
  293. interrupts = <68 2 69 2 70 2 71 2>;
  294. interrupt-parent = < &mpic >;
  295. fsl,tclk-period = <5>;
  296. fsl,tmr-prsc = <200>;
  297. fsl,tmr-add = <0xAAAAAAAB>;
  298. fsl,tmr-fiper1 = <0x3B9AC9FB>;
  299. fsl,tmr-fiper2 = <0x3B9AC9FB>;
  300. fsl,max-adj = <499999999>;
  301. };
  302. enet0: ethernet@24000 {
  303. #address-cells = <1>;
  304. #size-cells = <1>;
  305. cell-index = <0>;
  306. device_type = "network";
  307. model = "eTSEC";
  308. compatible = "gianfar";
  309. reg = <0x24000 0x1000>;
  310. ranges = <0x0 0x24000 0x1000>;
  311. local-mac-address = [ 00 00 00 00 00 00 ];
  312. interrupts = <29 2 30 2 34 2>;
  313. interrupt-parent = <&mpic>;
  314. tbi-handle = <&tbi0>;
  315. phy-handle = <&phy0>;
  316. phy-connection-type = "rgmii-id";
  317. mdio@520 {
  318. #address-cells = <1>;
  319. #size-cells = <0>;
  320. compatible = "fsl,gianfar-mdio";
  321. reg = <0x520 0x20>;
  322. phy0: ethernet-phy@0 {
  323. interrupt-parent = <&mpic>;
  324. interrupts = <10 1>;
  325. reg = <0x0>;
  326. };
  327. phy1: ethernet-phy@1 {
  328. interrupt-parent = <&mpic>;
  329. interrupts = <10 1>;
  330. reg = <0x1>;
  331. };
  332. phy2: ethernet-phy@2 {
  333. interrupt-parent = <&mpic>;
  334. interrupts = <10 1>;
  335. reg = <0x2>;
  336. };
  337. phy3: ethernet-phy@3 {
  338. interrupt-parent = <&mpic>;
  339. interrupts = <10 1>;
  340. reg = <0x3>;
  341. };
  342. tbi0: tbi-phy@11 {
  343. reg = <0x11>;
  344. device_type = "tbi-phy";
  345. };
  346. };
  347. };
  348. enet1: ethernet@25000 {
  349. #address-cells = <1>;
  350. #size-cells = <1>;
  351. cell-index = <1>;
  352. device_type = "network";
  353. model = "eTSEC";
  354. compatible = "gianfar";
  355. reg = <0x25000 0x1000>;
  356. ranges = <0x0 0x25000 0x1000>;
  357. local-mac-address = [ 00 00 00 00 00 00 ];
  358. interrupts = <35 2 36 2 40 2>;
  359. interrupt-parent = <&mpic>;
  360. tbi-handle = <&tbi1>;
  361. phy-handle = <&phy1>;
  362. phy-connection-type = "rgmii-id";
  363. mdio@520 {
  364. #address-cells = <1>;
  365. #size-cells = <0>;
  366. compatible = "fsl,gianfar-tbi";
  367. reg = <0x520 0x20>;
  368. tbi1: tbi-phy@11 {
  369. reg = <0x11>;
  370. device_type = "tbi-phy";
  371. };
  372. };
  373. };
  374. enet2: ethernet@26000 {
  375. #address-cells = <1>;
  376. #size-cells = <1>;
  377. cell-index = <2>;
  378. device_type = "network";
  379. model = "eTSEC";
  380. compatible = "gianfar";
  381. reg = <0x26000 0x1000>;
  382. ranges = <0x0 0x26000 0x1000>;
  383. local-mac-address = [ 00 00 00 00 00 00 ];
  384. interrupts = <31 2 32 2 33 2>;
  385. interrupt-parent = <&mpic>;
  386. tbi-handle = <&tbi2>;
  387. phy-handle = <&phy2>;
  388. phy-connection-type = "rgmii-id";
  389. mdio@520 {
  390. #address-cells = <1>;
  391. #size-cells = <0>;
  392. compatible = "fsl,gianfar-tbi";
  393. reg = <0x520 0x20>;
  394. tbi2: tbi-phy@11 {
  395. reg = <0x11>;
  396. device_type = "tbi-phy";
  397. };
  398. };
  399. };
  400. enet3: ethernet@27000 {
  401. #address-cells = <1>;
  402. #size-cells = <1>;
  403. cell-index = <3>;
  404. device_type = "network";
  405. model = "eTSEC";
  406. compatible = "gianfar";
  407. reg = <0x27000 0x1000>;
  408. ranges = <0x0 0x27000 0x1000>;
  409. local-mac-address = [ 00 00 00 00 00 00 ];
  410. interrupts = <37 2 38 2 39 2>;
  411. interrupt-parent = <&mpic>;
  412. tbi-handle = <&tbi3>;
  413. phy-handle = <&phy3>;
  414. phy-connection-type = "rgmii-id";
  415. mdio@520 {
  416. #address-cells = <1>;
  417. #size-cells = <0>;
  418. compatible = "fsl,gianfar-tbi";
  419. reg = <0x520 0x20>;
  420. tbi3: tbi-phy@11 {
  421. reg = <0x11>;
  422. device_type = "tbi-phy";
  423. };
  424. };
  425. };
  426. serial0: serial@4500 {
  427. cell-index = <0>;
  428. device_type = "serial";
  429. compatible = "ns16550";
  430. reg = <0x4500 0x100>;
  431. clock-frequency = <0>;
  432. interrupts = <42 2>;
  433. interrupt-parent = <&mpic>;
  434. };
  435. serial1: serial@4600 {
  436. cell-index = <1>;
  437. device_type = "serial";
  438. compatible = "ns16550";
  439. reg = <0x4600 0x100>;
  440. clock-frequency = <0>;
  441. interrupts = <42 2>;
  442. interrupt-parent = <&mpic>;
  443. };
  444. global-utilities@e0000 { //global utilities block
  445. compatible = "fsl,mpc8572-guts";
  446. reg = <0xe0000 0x1000>;
  447. fsl,has-rstcr;
  448. };
  449. msi@41600 {
  450. compatible = "fsl,mpc8572-msi", "fsl,mpic-msi";
  451. reg = <0x41600 0x80>;
  452. msi-available-ranges = <0 0x100>;
  453. interrupts = <
  454. 0xe0 0
  455. 0xe1 0
  456. 0xe2 0
  457. 0xe3 0
  458. 0xe4 0
  459. 0xe5 0
  460. 0xe6 0
  461. 0xe7 0>;
  462. interrupt-parent = <&mpic>;
  463. };
  464. crypto@30000 {
  465. compatible = "fsl,sec3.0", "fsl,sec2.4", "fsl,sec2.2",
  466. "fsl,sec2.1", "fsl,sec2.0";
  467. reg = <0x30000 0x10000>;
  468. interrupts = <45 2 58 2>;
  469. interrupt-parent = <&mpic>;
  470. fsl,num-channels = <4>;
  471. fsl,channel-fifo-len = <24>;
  472. fsl,exec-units-mask = <0x9fe>;
  473. fsl,descriptor-types-mask = <0x3ab0ebf>;
  474. };
  475. mpic: pic@40000 {
  476. interrupt-controller;
  477. #address-cells = <0>;
  478. #interrupt-cells = <2>;
  479. reg = <0x40000 0x40000>;
  480. compatible = "chrp,open-pic";
  481. device_type = "open-pic";
  482. };
  483. };
  484. pci0: pcie@ffe08000 {
  485. compatible = "fsl,mpc8548-pcie";
  486. device_type = "pci";
  487. #interrupt-cells = <1>;
  488. #size-cells = <2>;
  489. #address-cells = <3>;
  490. reg = <0 0xffe08000 0 0x1000>;
  491. bus-range = <0 255>;
  492. ranges = <0x2000000 0x0 0x80000000 0 0x80000000 0x0 0x20000000
  493. 0x1000000 0x0 0x00000000 0 0xffc00000 0x0 0x00010000>;
  494. clock-frequency = <33333333>;
  495. interrupt-parent = <&mpic>;
  496. interrupts = <24 2>;
  497. interrupt-map-mask = <0xff00 0x0 0x0 0x7>;
  498. interrupt-map = <
  499. /* IDSEL 0x11 func 0 - PCI slot 1 */
  500. 0x8800 0x0 0x0 0x1 &mpic 0x2 0x1
  501. 0x8800 0x0 0x0 0x2 &mpic 0x3 0x1
  502. 0x8800 0x0 0x0 0x3 &mpic 0x4 0x1
  503. 0x8800 0x0 0x0 0x4 &mpic 0x1 0x1
  504. /* IDSEL 0x11 func 1 - PCI slot 1 */
  505. 0x8900 0x0 0x0 0x1 &mpic 0x2 0x1
  506. 0x8900 0x0 0x0 0x2 &mpic 0x3 0x1
  507. 0x8900 0x0 0x0 0x3 &mpic 0x4 0x1
  508. 0x8900 0x0 0x0 0x4 &mpic 0x1 0x1
  509. /* IDSEL 0x11 func 2 - PCI slot 1 */
  510. 0x8a00 0x0 0x0 0x1 &mpic 0x2 0x1
  511. 0x8a00 0x0 0x0 0x2 &mpic 0x3 0x1
  512. 0x8a00 0x0 0x0 0x3 &mpic 0x4 0x1
  513. 0x8a00 0x0 0x0 0x4 &mpic 0x1 0x1
  514. /* IDSEL 0x11 func 3 - PCI slot 1 */
  515. 0x8b00 0x0 0x0 0x1 &mpic 0x2 0x1
  516. 0x8b00 0x0 0x0 0x2 &mpic 0x3 0x1
  517. 0x8b00 0x0 0x0 0x3 &mpic 0x4 0x1
  518. 0x8b00 0x0 0x0 0x4 &mpic 0x1 0x1
  519. /* IDSEL 0x11 func 4 - PCI slot 1 */
  520. 0x8c00 0x0 0x0 0x1 &mpic 0x2 0x1
  521. 0x8c00 0x0 0x0 0x2 &mpic 0x3 0x1
  522. 0x8c00 0x0 0x0 0x3 &mpic 0x4 0x1
  523. 0x8c00 0x0 0x0 0x4 &mpic 0x1 0x1
  524. /* IDSEL 0x11 func 5 - PCI slot 1 */
  525. 0x8d00 0x0 0x0 0x1 &mpic 0x2 0x1
  526. 0x8d00 0x0 0x0 0x2 &mpic 0x3 0x1
  527. 0x8d00 0x0 0x0 0x3 &mpic 0x4 0x1
  528. 0x8d00 0x0 0x0 0x4 &mpic 0x1 0x1
  529. /* IDSEL 0x11 func 6 - PCI slot 1 */
  530. 0x8e00 0x0 0x0 0x1 &mpic 0x2 0x1
  531. 0x8e00 0x0 0x0 0x2 &mpic 0x3 0x1
  532. 0x8e00 0x0 0x0 0x3 &mpic 0x4 0x1
  533. 0x8e00 0x0 0x0 0x4 &mpic 0x1 0x1
  534. /* IDSEL 0x11 func 7 - PCI slot 1 */
  535. 0x8f00 0x0 0x0 0x1 &mpic 0x2 0x1
  536. 0x8f00 0x0 0x0 0x2 &mpic 0x3 0x1
  537. 0x8f00 0x0 0x0 0x3 &mpic 0x4 0x1
  538. 0x8f00 0x0 0x0 0x4 &mpic 0x1 0x1
  539. /* IDSEL 0x12 func 0 - PCI slot 2 */
  540. 0x9000 0x0 0x0 0x1 &mpic 0x3 0x1
  541. 0x9000 0x0 0x0 0x2 &mpic 0x4 0x1
  542. 0x9000 0x0 0x0 0x3 &mpic 0x1 0x1
  543. 0x9000 0x0 0x0 0x4 &mpic 0x2 0x1
  544. /* IDSEL 0x12 func 1 - PCI slot 2 */
  545. 0x9100 0x0 0x0 0x1 &mpic 0x3 0x1
  546. 0x9100 0x0 0x0 0x2 &mpic 0x4 0x1
  547. 0x9100 0x0 0x0 0x3 &mpic 0x1 0x1
  548. 0x9100 0x0 0x0 0x4 &mpic 0x2 0x1
  549. /* IDSEL 0x12 func 2 - PCI slot 2 */
  550. 0x9200 0x0 0x0 0x1 &mpic 0x3 0x1
  551. 0x9200 0x0 0x0 0x2 &mpic 0x4 0x1
  552. 0x9200 0x0 0x0 0x3 &mpic 0x1 0x1
  553. 0x9200 0x0 0x0 0x4 &mpic 0x2 0x1
  554. /* IDSEL 0x12 func 3 - PCI slot 2 */
  555. 0x9300 0x0 0x0 0x1 &mpic 0x3 0x1
  556. 0x9300 0x0 0x0 0x2 &mpic 0x4 0x1
  557. 0x9300 0x0 0x0 0x3 &mpic 0x1 0x1
  558. 0x9300 0x0 0x0 0x4 &mpic 0x2 0x1
  559. /* IDSEL 0x12 func 4 - PCI slot 2 */
  560. 0x9400 0x0 0x0 0x1 &mpic 0x3 0x1
  561. 0x9400 0x0 0x0 0x2 &mpic 0x4 0x1
  562. 0x9400 0x0 0x0 0x3 &mpic 0x1 0x1
  563. 0x9400 0x0 0x0 0x4 &mpic 0x2 0x1
  564. /* IDSEL 0x12 func 5 - PCI slot 2 */
  565. 0x9500 0x0 0x0 0x1 &mpic 0x3 0x1
  566. 0x9500 0x0 0x0 0x2 &mpic 0x4 0x1
  567. 0x9500 0x0 0x0 0x3 &mpic 0x1 0x1
  568. 0x9500 0x0 0x0 0x4 &mpic 0x2 0x1
  569. /* IDSEL 0x12 func 6 - PCI slot 2 */
  570. 0x9600 0x0 0x0 0x1 &mpic 0x3 0x1
  571. 0x9600 0x0 0x0 0x2 &mpic 0x4 0x1
  572. 0x9600 0x0 0x0 0x3 &mpic 0x1 0x1
  573. 0x9600 0x0 0x0 0x4 &mpic 0x2 0x1
  574. /* IDSEL 0x12 func 7 - PCI slot 2 */
  575. 0x9700 0x0 0x0 0x1 &mpic 0x3 0x1
  576. 0x9700 0x0 0x0 0x2 &mpic 0x4 0x1
  577. 0x9700 0x0 0x0 0x3 &mpic 0x1 0x1
  578. 0x9700 0x0 0x0 0x4 &mpic 0x2 0x1
  579. // IDSEL 0x1c USB
  580. 0xe000 0x0 0x0 0x1 &i8259 0xc 0x2
  581. 0xe100 0x0 0x0 0x2 &i8259 0x9 0x2
  582. 0xe200 0x0 0x0 0x3 &i8259 0xa 0x2
  583. 0xe300 0x0 0x0 0x4 &i8259 0xb 0x2
  584. // IDSEL 0x1d Audio
  585. 0xe800 0x0 0x0 0x1 &i8259 0x6 0x2
  586. // IDSEL 0x1e Legacy
  587. 0xf000 0x0 0x0 0x1 &i8259 0x7 0x2
  588. 0xf100 0x0 0x0 0x1 &i8259 0x7 0x2
  589. // IDSEL 0x1f IDE/SATA
  590. 0xf800 0x0 0x0 0x1 &i8259 0xe 0x2
  591. 0xf900 0x0 0x0 0x1 &i8259 0x5 0x2
  592. >;
  593. pcie@0 {
  594. reg = <0x0 0x0 0x0 0x0 0x0>;
  595. #size-cells = <2>;
  596. #address-cells = <3>;
  597. device_type = "pci";
  598. ranges = <0x2000000 0x0 0x80000000
  599. 0x2000000 0x0 0x80000000
  600. 0x0 0x20000000
  601. 0x1000000 0x0 0x0
  602. 0x1000000 0x0 0x0
  603. 0x0 0x10000>;
  604. uli1575@0 {
  605. reg = <0x0 0x0 0x0 0x0 0x0>;
  606. #size-cells = <2>;
  607. #address-cells = <3>;
  608. ranges = <0x2000000 0x0 0x80000000
  609. 0x2000000 0x0 0x80000000
  610. 0x0 0x20000000
  611. 0x1000000 0x0 0x0
  612. 0x1000000 0x0 0x0
  613. 0x0 0x10000>;
  614. isa@1e {
  615. device_type = "isa";
  616. #interrupt-cells = <2>;
  617. #size-cells = <1>;
  618. #address-cells = <2>;
  619. reg = <0xf000 0x0 0x0 0x0 0x0>;
  620. ranges = <0x1 0x0 0x1000000 0x0 0x0
  621. 0x1000>;
  622. interrupt-parent = <&i8259>;
  623. i8259: interrupt-controller@20 {
  624. reg = <0x1 0x20 0x2
  625. 0x1 0xa0 0x2
  626. 0x1 0x4d0 0x2>;
  627. interrupt-controller;
  628. device_type = "interrupt-controller";
  629. #address-cells = <0>;
  630. #interrupt-cells = <2>;
  631. compatible = "chrp,iic";
  632. interrupts = <9 2>;
  633. interrupt-parent = <&mpic>;
  634. };
  635. i8042@60 {
  636. #size-cells = <0>;
  637. #address-cells = <1>;
  638. reg = <0x1 0x60 0x1 0x1 0x64 0x1>;
  639. interrupts = <1 3 12 3>;
  640. interrupt-parent =
  641. <&i8259>;
  642. keyboard@0 {
  643. reg = <0x0>;
  644. compatible = "pnpPNP,303";
  645. };
  646. mouse@1 {
  647. reg = <0x1>;
  648. compatible = "pnpPNP,f03";
  649. };
  650. };
  651. rtc@70 {
  652. compatible = "pnpPNP,b00";
  653. reg = <0x1 0x70 0x2>;
  654. };
  655. gpio@400 {
  656. reg = <0x1 0x400 0x80>;
  657. };
  658. };
  659. };
  660. };
  661. };
  662. pci1: pcie@ffe09000 {
  663. compatible = "fsl,mpc8548-pcie";
  664. device_type = "pci";
  665. #interrupt-cells = <1>;
  666. #size-cells = <2>;
  667. #address-cells = <3>;
  668. reg = <0 0xffe09000 0 0x1000>;
  669. bus-range = <0 255>;
  670. ranges = <0x2000000 0x0 0xa0000000 0 0xa0000000 0x0 0x20000000
  671. 0x1000000 0x0 0x00000000 0 0xffc10000 0x0 0x00010000>;
  672. clock-frequency = <33333333>;
  673. interrupt-parent = <&mpic>;
  674. interrupts = <25 2>;
  675. interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
  676. interrupt-map = <
  677. /* IDSEL 0x0 */
  678. 0000 0x0 0x0 0x1 &mpic 0x4 0x1
  679. 0000 0x0 0x0 0x2 &mpic 0x5 0x1
  680. 0000 0x0 0x0 0x3 &mpic 0x6 0x1
  681. 0000 0x0 0x0 0x4 &mpic 0x7 0x1
  682. >;
  683. pcie@0 {
  684. reg = <0x0 0x0 0x0 0x0 0x0>;
  685. #size-cells = <2>;
  686. #address-cells = <3>;
  687. device_type = "pci";
  688. ranges = <0x2000000 0x0 0xa0000000
  689. 0x2000000 0x0 0xa0000000
  690. 0x0 0x20000000
  691. 0x1000000 0x0 0x0
  692. 0x1000000 0x0 0x0
  693. 0x0 0x10000>;
  694. };
  695. };
  696. pci2: pcie@ffe0a000 {
  697. compatible = "fsl,mpc8548-pcie";
  698. device_type = "pci";
  699. #interrupt-cells = <1>;
  700. #size-cells = <2>;
  701. #address-cells = <3>;
  702. reg = <0 0xffe0a000 0 0x1000>;
  703. bus-range = <0 255>;
  704. ranges = <0x2000000 0x0 0xc0000000 0 0xc0000000 0x0 0x20000000
  705. 0x1000000 0x0 0x00000000 0 0xffc20000 0x0 0x00010000>;
  706. clock-frequency = <33333333>;
  707. interrupt-parent = <&mpic>;
  708. interrupts = <26 2>;
  709. interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
  710. interrupt-map = <
  711. /* IDSEL 0x0 */
  712. 0000 0x0 0x0 0x1 &mpic 0x0 0x1
  713. 0000 0x0 0x0 0x2 &mpic 0x1 0x1
  714. 0000 0x0 0x0 0x3 &mpic 0x2 0x1
  715. 0000 0x0 0x0 0x4 &mpic 0x3 0x1
  716. >;
  717. pcie@0 {
  718. reg = <0x0 0x0 0x0 0x0 0x0>;
  719. #size-cells = <2>;
  720. #address-cells = <3>;
  721. device_type = "pci";
  722. ranges = <0x2000000 0x0 0xc0000000
  723. 0x2000000 0x0 0xc0000000
  724. 0x0 0x20000000
  725. 0x1000000 0x0 0x0
  726. 0x1000000 0x0 0x0
  727. 0x0 0x10000>;
  728. };
  729. };
  730. };