mpc8572ds_36b.dts 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809
  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@fffe05000 {
  60. #address-cells = <2>;
  61. #size-cells = <1>;
  62. compatible = "fsl,mpc8572-elbc", "fsl,elbc", "simple-bus";
  63. reg = <0xf 0xffe05000 0 0x1000>;
  64. interrupts = <19 2>;
  65. interrupt-parent = <&mpic>;
  66. ranges = <0x0 0x0 0xf 0xe8000000 0x08000000
  67. 0x1 0x0 0xf 0xe0000000 0x08000000
  68. 0x2 0x0 0xf 0xffa00000 0x00040000
  69. 0x3 0x0 0xf 0xffdf0000 0x00008000
  70. 0x4 0x0 0xf 0xffa40000 0x00040000
  71. 0x5 0x0 0xf 0xffa80000 0x00040000
  72. 0x6 0x0 0xf 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@fffe00000 {
  153. #address-cells = <1>;
  154. #size-cells = <1>;
  155. device_type = "soc";
  156. compatible = "simple-bus";
  157. ranges = <0x0 0xf 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. enet0: ethernet@24000 {
  291. #address-cells = <1>;
  292. #size-cells = <1>;
  293. cell-index = <0>;
  294. device_type = "network";
  295. model = "eTSEC";
  296. compatible = "gianfar";
  297. reg = <0x24000 0x1000>;
  298. ranges = <0x0 0x24000 0x1000>;
  299. local-mac-address = [ 00 00 00 00 00 00 ];
  300. interrupts = <29 2 30 2 34 2>;
  301. interrupt-parent = <&mpic>;
  302. tbi-handle = <&tbi0>;
  303. phy-handle = <&phy0>;
  304. phy-connection-type = "rgmii-id";
  305. mdio@520 {
  306. #address-cells = <1>;
  307. #size-cells = <0>;
  308. compatible = "fsl,gianfar-mdio";
  309. reg = <0x520 0x20>;
  310. phy0: ethernet-phy@0 {
  311. interrupt-parent = <&mpic>;
  312. interrupts = <10 1>;
  313. reg = <0x0>;
  314. };
  315. phy1: ethernet-phy@1 {
  316. interrupt-parent = <&mpic>;
  317. interrupts = <10 1>;
  318. reg = <0x1>;
  319. };
  320. phy2: ethernet-phy@2 {
  321. interrupt-parent = <&mpic>;
  322. interrupts = <10 1>;
  323. reg = <0x2>;
  324. };
  325. phy3: ethernet-phy@3 {
  326. interrupt-parent = <&mpic>;
  327. interrupts = <10 1>;
  328. reg = <0x3>;
  329. };
  330. tbi0: tbi-phy@11 {
  331. reg = <0x11>;
  332. device_type = "tbi-phy";
  333. };
  334. };
  335. };
  336. enet1: ethernet@25000 {
  337. #address-cells = <1>;
  338. #size-cells = <1>;
  339. cell-index = <1>;
  340. device_type = "network";
  341. model = "eTSEC";
  342. compatible = "gianfar";
  343. reg = <0x25000 0x1000>;
  344. ranges = <0x0 0x25000 0x1000>;
  345. local-mac-address = [ 00 00 00 00 00 00 ];
  346. interrupts = <35 2 36 2 40 2>;
  347. interrupt-parent = <&mpic>;
  348. tbi-handle = <&tbi1>;
  349. phy-handle = <&phy1>;
  350. phy-connection-type = "rgmii-id";
  351. mdio@520 {
  352. #address-cells = <1>;
  353. #size-cells = <0>;
  354. compatible = "fsl,gianfar-tbi";
  355. reg = <0x520 0x20>;
  356. tbi1: tbi-phy@11 {
  357. reg = <0x11>;
  358. device_type = "tbi-phy";
  359. };
  360. };
  361. };
  362. enet2: ethernet@26000 {
  363. #address-cells = <1>;
  364. #size-cells = <1>;
  365. cell-index = <2>;
  366. device_type = "network";
  367. model = "eTSEC";
  368. compatible = "gianfar";
  369. reg = <0x26000 0x1000>;
  370. ranges = <0x0 0x26000 0x1000>;
  371. local-mac-address = [ 00 00 00 00 00 00 ];
  372. interrupts = <31 2 32 2 33 2>;
  373. interrupt-parent = <&mpic>;
  374. tbi-handle = <&tbi2>;
  375. phy-handle = <&phy2>;
  376. phy-connection-type = "rgmii-id";
  377. mdio@520 {
  378. #address-cells = <1>;
  379. #size-cells = <0>;
  380. compatible = "fsl,gianfar-tbi";
  381. reg = <0x520 0x20>;
  382. tbi2: tbi-phy@11 {
  383. reg = <0x11>;
  384. device_type = "tbi-phy";
  385. };
  386. };
  387. };
  388. enet3: ethernet@27000 {
  389. #address-cells = <1>;
  390. #size-cells = <1>;
  391. cell-index = <3>;
  392. device_type = "network";
  393. model = "eTSEC";
  394. compatible = "gianfar";
  395. reg = <0x27000 0x1000>;
  396. ranges = <0x0 0x27000 0x1000>;
  397. local-mac-address = [ 00 00 00 00 00 00 ];
  398. interrupts = <37 2 38 2 39 2>;
  399. interrupt-parent = <&mpic>;
  400. tbi-handle = <&tbi3>;
  401. phy-handle = <&phy3>;
  402. phy-connection-type = "rgmii-id";
  403. mdio@520 {
  404. #address-cells = <1>;
  405. #size-cells = <0>;
  406. compatible = "fsl,gianfar-tbi";
  407. reg = <0x520 0x20>;
  408. tbi3: tbi-phy@11 {
  409. reg = <0x11>;
  410. device_type = "tbi-phy";
  411. };
  412. };
  413. };
  414. serial0: serial@4500 {
  415. cell-index = <0>;
  416. device_type = "serial";
  417. compatible = "ns16550";
  418. reg = <0x4500 0x100>;
  419. clock-frequency = <0>;
  420. interrupts = <42 2>;
  421. interrupt-parent = <&mpic>;
  422. };
  423. serial1: serial@4600 {
  424. cell-index = <1>;
  425. device_type = "serial";
  426. compatible = "ns16550";
  427. reg = <0x4600 0x100>;
  428. clock-frequency = <0>;
  429. interrupts = <42 2>;
  430. interrupt-parent = <&mpic>;
  431. };
  432. global-utilities@e0000 { //global utilities block
  433. compatible = "fsl,mpc8572-guts";
  434. reg = <0xe0000 0x1000>;
  435. fsl,has-rstcr;
  436. };
  437. msi@41600 {
  438. compatible = "fsl,mpc8572-msi", "fsl,mpic-msi";
  439. reg = <0x41600 0x80>;
  440. msi-available-ranges = <0 0x100>;
  441. interrupts = <
  442. 0xe0 0
  443. 0xe1 0
  444. 0xe2 0
  445. 0xe3 0
  446. 0xe4 0
  447. 0xe5 0
  448. 0xe6 0
  449. 0xe7 0>;
  450. interrupt-parent = <&mpic>;
  451. };
  452. crypto@30000 {
  453. compatible = "fsl,sec3.0", "fsl,sec2.4", "fsl,sec2.2",
  454. "fsl,sec2.1", "fsl,sec2.0";
  455. reg = <0x30000 0x10000>;
  456. interrupts = <45 2 58 2>;
  457. interrupt-parent = <&mpic>;
  458. fsl,num-channels = <4>;
  459. fsl,channel-fifo-len = <24>;
  460. fsl,exec-units-mask = <0x9fe>;
  461. fsl,descriptor-types-mask = <0x3ab0ebf>;
  462. };
  463. mpic: pic@40000 {
  464. interrupt-controller;
  465. #address-cells = <0>;
  466. #interrupt-cells = <2>;
  467. reg = <0x40000 0x40000>;
  468. compatible = "chrp,open-pic";
  469. device_type = "open-pic";
  470. };
  471. };
  472. pci0: pcie@fffe08000 {
  473. compatible = "fsl,mpc8548-pcie";
  474. device_type = "pci";
  475. #interrupt-cells = <1>;
  476. #size-cells = <2>;
  477. #address-cells = <3>;
  478. reg = <0xf 0xffe08000 0 0x1000>;
  479. bus-range = <0 255>;
  480. ranges = <0x2000000 0x0 0xe0000000 0xc 0x00000000 0x0 0x20000000
  481. 0x1000000 0x0 0x00000000 0xf 0xffc00000 0x0 0x00010000>;
  482. clock-frequency = <33333333>;
  483. interrupt-parent = <&mpic>;
  484. interrupts = <24 2>;
  485. interrupt-map-mask = <0xff00 0x0 0x0 0x7>;
  486. interrupt-map = <
  487. /* IDSEL 0x11 func 0 - PCI slot 1 */
  488. 0x8800 0x0 0x0 0x1 &mpic 0x2 0x1
  489. 0x8800 0x0 0x0 0x2 &mpic 0x3 0x1
  490. 0x8800 0x0 0x0 0x3 &mpic 0x4 0x1
  491. 0x8800 0x0 0x0 0x4 &mpic 0x1 0x1
  492. /* IDSEL 0x11 func 1 - PCI slot 1 */
  493. 0x8900 0x0 0x0 0x1 &mpic 0x2 0x1
  494. 0x8900 0x0 0x0 0x2 &mpic 0x3 0x1
  495. 0x8900 0x0 0x0 0x3 &mpic 0x4 0x1
  496. 0x8900 0x0 0x0 0x4 &mpic 0x1 0x1
  497. /* IDSEL 0x11 func 2 - PCI slot 1 */
  498. 0x8a00 0x0 0x0 0x1 &mpic 0x2 0x1
  499. 0x8a00 0x0 0x0 0x2 &mpic 0x3 0x1
  500. 0x8a00 0x0 0x0 0x3 &mpic 0x4 0x1
  501. 0x8a00 0x0 0x0 0x4 &mpic 0x1 0x1
  502. /* IDSEL 0x11 func 3 - PCI slot 1 */
  503. 0x8b00 0x0 0x0 0x1 &mpic 0x2 0x1
  504. 0x8b00 0x0 0x0 0x2 &mpic 0x3 0x1
  505. 0x8b00 0x0 0x0 0x3 &mpic 0x4 0x1
  506. 0x8b00 0x0 0x0 0x4 &mpic 0x1 0x1
  507. /* IDSEL 0x11 func 4 - PCI slot 1 */
  508. 0x8c00 0x0 0x0 0x1 &mpic 0x2 0x1
  509. 0x8c00 0x0 0x0 0x2 &mpic 0x3 0x1
  510. 0x8c00 0x0 0x0 0x3 &mpic 0x4 0x1
  511. 0x8c00 0x0 0x0 0x4 &mpic 0x1 0x1
  512. /* IDSEL 0x11 func 5 - PCI slot 1 */
  513. 0x8d00 0x0 0x0 0x1 &mpic 0x2 0x1
  514. 0x8d00 0x0 0x0 0x2 &mpic 0x3 0x1
  515. 0x8d00 0x0 0x0 0x3 &mpic 0x4 0x1
  516. 0x8d00 0x0 0x0 0x4 &mpic 0x1 0x1
  517. /* IDSEL 0x11 func 6 - PCI slot 1 */
  518. 0x8e00 0x0 0x0 0x1 &mpic 0x2 0x1
  519. 0x8e00 0x0 0x0 0x2 &mpic 0x3 0x1
  520. 0x8e00 0x0 0x0 0x3 &mpic 0x4 0x1
  521. 0x8e00 0x0 0x0 0x4 &mpic 0x1 0x1
  522. /* IDSEL 0x11 func 7 - PCI slot 1 */
  523. 0x8f00 0x0 0x0 0x1 &mpic 0x2 0x1
  524. 0x8f00 0x0 0x0 0x2 &mpic 0x3 0x1
  525. 0x8f00 0x0 0x0 0x3 &mpic 0x4 0x1
  526. 0x8f00 0x0 0x0 0x4 &mpic 0x1 0x1
  527. /* IDSEL 0x12 func 0 - PCI slot 2 */
  528. 0x9000 0x0 0x0 0x1 &mpic 0x3 0x1
  529. 0x9000 0x0 0x0 0x2 &mpic 0x4 0x1
  530. 0x9000 0x0 0x0 0x3 &mpic 0x1 0x1
  531. 0x9000 0x0 0x0 0x4 &mpic 0x2 0x1
  532. /* IDSEL 0x12 func 1 - PCI slot 2 */
  533. 0x9100 0x0 0x0 0x1 &mpic 0x3 0x1
  534. 0x9100 0x0 0x0 0x2 &mpic 0x4 0x1
  535. 0x9100 0x0 0x0 0x3 &mpic 0x1 0x1
  536. 0x9100 0x0 0x0 0x4 &mpic 0x2 0x1
  537. /* IDSEL 0x12 func 2 - PCI slot 2 */
  538. 0x9200 0x0 0x0 0x1 &mpic 0x3 0x1
  539. 0x9200 0x0 0x0 0x2 &mpic 0x4 0x1
  540. 0x9200 0x0 0x0 0x3 &mpic 0x1 0x1
  541. 0x9200 0x0 0x0 0x4 &mpic 0x2 0x1
  542. /* IDSEL 0x12 func 3 - PCI slot 2 */
  543. 0x9300 0x0 0x0 0x1 &mpic 0x3 0x1
  544. 0x9300 0x0 0x0 0x2 &mpic 0x4 0x1
  545. 0x9300 0x0 0x0 0x3 &mpic 0x1 0x1
  546. 0x9300 0x0 0x0 0x4 &mpic 0x2 0x1
  547. /* IDSEL 0x12 func 4 - PCI slot 2 */
  548. 0x9400 0x0 0x0 0x1 &mpic 0x3 0x1
  549. 0x9400 0x0 0x0 0x2 &mpic 0x4 0x1
  550. 0x9400 0x0 0x0 0x3 &mpic 0x1 0x1
  551. 0x9400 0x0 0x0 0x4 &mpic 0x2 0x1
  552. /* IDSEL 0x12 func 5 - PCI slot 2 */
  553. 0x9500 0x0 0x0 0x1 &mpic 0x3 0x1
  554. 0x9500 0x0 0x0 0x2 &mpic 0x4 0x1
  555. 0x9500 0x0 0x0 0x3 &mpic 0x1 0x1
  556. 0x9500 0x0 0x0 0x4 &mpic 0x2 0x1
  557. /* IDSEL 0x12 func 6 - PCI slot 2 */
  558. 0x9600 0x0 0x0 0x1 &mpic 0x3 0x1
  559. 0x9600 0x0 0x0 0x2 &mpic 0x4 0x1
  560. 0x9600 0x0 0x0 0x3 &mpic 0x1 0x1
  561. 0x9600 0x0 0x0 0x4 &mpic 0x2 0x1
  562. /* IDSEL 0x12 func 7 - PCI slot 2 */
  563. 0x9700 0x0 0x0 0x1 &mpic 0x3 0x1
  564. 0x9700 0x0 0x0 0x2 &mpic 0x4 0x1
  565. 0x9700 0x0 0x0 0x3 &mpic 0x1 0x1
  566. 0x9700 0x0 0x0 0x4 &mpic 0x2 0x1
  567. // IDSEL 0x1c USB
  568. 0xe000 0x0 0x0 0x1 &i8259 0xc 0x2
  569. 0xe100 0x0 0x0 0x2 &i8259 0x9 0x2
  570. 0xe200 0x0 0x0 0x3 &i8259 0xa 0x2
  571. 0xe300 0x0 0x0 0x4 &i8259 0xb 0x2
  572. // IDSEL 0x1d Audio
  573. 0xe800 0x0 0x0 0x1 &i8259 0x6 0x2
  574. // IDSEL 0x1e Legacy
  575. 0xf000 0x0 0x0 0x1 &i8259 0x7 0x2
  576. 0xf100 0x0 0x0 0x1 &i8259 0x7 0x2
  577. // IDSEL 0x1f IDE/SATA
  578. 0xf800 0x0 0x0 0x1 &i8259 0xe 0x2
  579. 0xf900 0x0 0x0 0x1 &i8259 0x5 0x2
  580. >;
  581. pcie@0 {
  582. reg = <0x0 0x0 0x0 0x0 0x0>;
  583. #size-cells = <2>;
  584. #address-cells = <3>;
  585. device_type = "pci";
  586. ranges = <0x2000000 0x0 0xe0000000
  587. 0x2000000 0x0 0xe0000000
  588. 0x0 0x20000000
  589. 0x1000000 0x0 0x0
  590. 0x1000000 0x0 0x0
  591. 0x0 0x10000>;
  592. uli1575@0 {
  593. reg = <0x0 0x0 0x0 0x0 0x0>;
  594. #size-cells = <2>;
  595. #address-cells = <3>;
  596. ranges = <0x2000000 0x0 0xe0000000
  597. 0x2000000 0x0 0xe0000000
  598. 0x0 0x20000000
  599. 0x1000000 0x0 0x0
  600. 0x1000000 0x0 0x0
  601. 0x0 0x10000>;
  602. isa@1e {
  603. device_type = "isa";
  604. #interrupt-cells = <2>;
  605. #size-cells = <1>;
  606. #address-cells = <2>;
  607. reg = <0xf000 0x0 0x0 0x0 0x0>;
  608. ranges = <0x1 0x0 0x1000000 0x0 0x0
  609. 0x1000>;
  610. interrupt-parent = <&i8259>;
  611. i8259: interrupt-controller@20 {
  612. reg = <0x1 0x20 0x2
  613. 0x1 0xa0 0x2
  614. 0x1 0x4d0 0x2>;
  615. interrupt-controller;
  616. device_type = "interrupt-controller";
  617. #address-cells = <0>;
  618. #interrupt-cells = <2>;
  619. compatible = "chrp,iic";
  620. interrupts = <9 2>;
  621. interrupt-parent = <&mpic>;
  622. };
  623. i8042@60 {
  624. #size-cells = <0>;
  625. #address-cells = <1>;
  626. reg = <0x1 0x60 0x1 0x1 0x64 0x1>;
  627. interrupts = <1 3 12 3>;
  628. interrupt-parent =
  629. <&i8259>;
  630. keyboard@0 {
  631. reg = <0x0>;
  632. compatible = "pnpPNP,303";
  633. };
  634. mouse@1 {
  635. reg = <0x1>;
  636. compatible = "pnpPNP,f03";
  637. };
  638. };
  639. rtc@70 {
  640. compatible = "pnpPNP,b00";
  641. reg = <0x1 0x70 0x2>;
  642. };
  643. gpio@400 {
  644. reg = <0x1 0x400 0x80>;
  645. };
  646. };
  647. };
  648. };
  649. };
  650. pci1: pcie@fffe09000 {
  651. compatible = "fsl,mpc8548-pcie";
  652. device_type = "pci";
  653. #interrupt-cells = <1>;
  654. #size-cells = <2>;
  655. #address-cells = <3>;
  656. reg = <0xf 0xffe09000 0 0x1000>;
  657. bus-range = <0 255>;
  658. ranges = <0x2000000 0x0 0xe0000000 0xc 0x20000000 0x0 0x20000000
  659. 0x1000000 0x0 0x00000000 0xf 0xffc10000 0x0 0x00010000>;
  660. clock-frequency = <33333333>;
  661. interrupt-parent = <&mpic>;
  662. interrupts = <25 2>;
  663. interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
  664. interrupt-map = <
  665. /* IDSEL 0x0 */
  666. 0000 0x0 0x0 0x1 &mpic 0x4 0x1
  667. 0000 0x0 0x0 0x2 &mpic 0x5 0x1
  668. 0000 0x0 0x0 0x3 &mpic 0x6 0x1
  669. 0000 0x0 0x0 0x4 &mpic 0x7 0x1
  670. >;
  671. pcie@0 {
  672. reg = <0x0 0x0 0x0 0x0 0x0>;
  673. #size-cells = <2>;
  674. #address-cells = <3>;
  675. device_type = "pci";
  676. ranges = <0x2000000 0x0 0xe0000000
  677. 0x2000000 0x0 0xe0000000
  678. 0x0 0x20000000
  679. 0x1000000 0x0 0x0
  680. 0x1000000 0x0 0x0
  681. 0x0 0x10000>;
  682. };
  683. };
  684. pci2: pcie@fffe0a000 {
  685. compatible = "fsl,mpc8548-pcie";
  686. device_type = "pci";
  687. #interrupt-cells = <1>;
  688. #size-cells = <2>;
  689. #address-cells = <3>;
  690. reg = <0xf 0xffe0a000 0 0x1000>;
  691. bus-range = <0 255>;
  692. ranges = <0x2000000 0x0 0xe0000000 0xc 0x40000000 0x0 0x20000000
  693. 0x1000000 0x0 0x00000000 0xf 0xffc20000 0x0 0x00010000>;
  694. clock-frequency = <33333333>;
  695. interrupt-parent = <&mpic>;
  696. interrupts = <26 2>;
  697. interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
  698. interrupt-map = <
  699. /* IDSEL 0x0 */
  700. 0000 0x0 0x0 0x1 &mpic 0x0 0x1
  701. 0000 0x0 0x0 0x2 &mpic 0x1 0x1
  702. 0000 0x0 0x0 0x3 &mpic 0x2 0x1
  703. 0000 0x0 0x0 0x4 &mpic 0x3 0x1
  704. >;
  705. pcie@0 {
  706. reg = <0x0 0x0 0x0 0x0 0x0>;
  707. #size-cells = <2>;
  708. #address-cells = <3>;
  709. device_type = "pci";
  710. ranges = <0x2000000 0x0 0xe0000000
  711. 0x2000000 0x0 0xe0000000
  712. 0x0 0x20000000
  713. 0x1000000 0x0 0x0
  714. 0x1000000 0x0 0x0
  715. 0x0 0x10000>;
  716. };
  717. };
  718. };