xref: /OK3568_Linux_fs/kernel/arch/powerpc/boot/dts/fsl/mpc8569si-post.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun/*
2*4882a593Smuzhiyun * MPC8569 Silicon/SoC Device Tree Source (post include)
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Copyright 2011 Freescale Semiconductor Inc.
5*4882a593Smuzhiyun *
6*4882a593Smuzhiyun * Redistribution and use in source and binary forms, with or without
7*4882a593Smuzhiyun * modification, are permitted provided that the following conditions are met:
8*4882a593Smuzhiyun *     * Redistributions of source code must retain the above copyright
9*4882a593Smuzhiyun *       notice, this list of conditions and the following disclaimer.
10*4882a593Smuzhiyun *     * Redistributions in binary form must reproduce the above copyright
11*4882a593Smuzhiyun *       notice, this list of conditions and the following disclaimer in the
12*4882a593Smuzhiyun *       documentation and/or other materials provided with the distribution.
13*4882a593Smuzhiyun *     * Neither the name of Freescale Semiconductor nor the
14*4882a593Smuzhiyun *       names of its contributors may be used to endorse or promote products
15*4882a593Smuzhiyun *       derived from this software without specific prior written permission.
16*4882a593Smuzhiyun *
17*4882a593Smuzhiyun *
18*4882a593Smuzhiyun * ALTERNATIVELY, this software may be distributed under the terms of the
19*4882a593Smuzhiyun * GNU General Public License ("GPL") as published by the Free Software
20*4882a593Smuzhiyun * Foundation, either version 2 of that License or (at your option) any
21*4882a593Smuzhiyun * later version.
22*4882a593Smuzhiyun *
23*4882a593Smuzhiyun * THIS SOFTWARE IS PROVIDED BY Freescale Semiconductor ``AS IS'' AND ANY
24*4882a593Smuzhiyun * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25*4882a593Smuzhiyun * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26*4882a593Smuzhiyun * DISCLAIMED. IN NO EVENT SHALL Freescale Semiconductor BE LIABLE FOR ANY
27*4882a593Smuzhiyun * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
28*4882a593Smuzhiyun * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29*4882a593Smuzhiyun * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
30*4882a593Smuzhiyun * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31*4882a593Smuzhiyun * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
32*4882a593Smuzhiyun * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33*4882a593Smuzhiyun */
34*4882a593Smuzhiyun
35*4882a593Smuzhiyun&lbc {
36*4882a593Smuzhiyun	#address-cells = <2>;
37*4882a593Smuzhiyun	#size-cells = <1>;
38*4882a593Smuzhiyun	compatible = "fsl,mpc8569-elbc", "fsl,elbc", "simple-bus";
39*4882a593Smuzhiyun	interrupts = <19 2 0 0>;
40*4882a593Smuzhiyun	sleep = <&pmc 0x08000000>;
41*4882a593Smuzhiyun};
42*4882a593Smuzhiyun
43*4882a593Smuzhiyun/* controller at 0xa000 */
44*4882a593Smuzhiyun&pci1 {
45*4882a593Smuzhiyun	compatible = "fsl,mpc8548-pcie";
46*4882a593Smuzhiyun	device_type = "pci";
47*4882a593Smuzhiyun	#size-cells = <2>;
48*4882a593Smuzhiyun	#address-cells = <3>;
49*4882a593Smuzhiyun	bus-range = <0 255>;
50*4882a593Smuzhiyun	clock-frequency = <33333333>;
51*4882a593Smuzhiyun	interrupts = <26 2 0 0>;
52*4882a593Smuzhiyun	sleep = <&pmc 0x20000000>;
53*4882a593Smuzhiyun
54*4882a593Smuzhiyun	pcie@0 {
55*4882a593Smuzhiyun		reg = <0 0 0 0 0>;
56*4882a593Smuzhiyun		#interrupt-cells = <1>;
57*4882a593Smuzhiyun		#size-cells = <2>;
58*4882a593Smuzhiyun		#address-cells = <3>;
59*4882a593Smuzhiyun		device_type = "pci";
60*4882a593Smuzhiyun		interrupts = <26 2 0 0>;
61*4882a593Smuzhiyun		interrupt-map-mask = <0xf800 0 0 7>;
62*4882a593Smuzhiyun		interrupt-map = <
63*4882a593Smuzhiyun			/* IDSEL 0x0 */
64*4882a593Smuzhiyun			0000 0x0 0x0 0x1 &mpic 0x0 0x1 0x0 0x0
65*4882a593Smuzhiyun			0000 0x0 0x0 0x2 &mpic 0x1 0x1 0x0 0x0
66*4882a593Smuzhiyun			0000 0x0 0x0 0x3 &mpic 0x2 0x1 0x0 0x0
67*4882a593Smuzhiyun			0000 0x0 0x0 0x4 &mpic 0x3 0x1 0x0 0x0
68*4882a593Smuzhiyun			>;
69*4882a593Smuzhiyun	};
70*4882a593Smuzhiyun};
71*4882a593Smuzhiyun
72*4882a593Smuzhiyun&rio {
73*4882a593Smuzhiyun	compatible = "fsl,srio";
74*4882a593Smuzhiyun	interrupts = <48 2 0 0>;
75*4882a593Smuzhiyun	#address-cells = <2>;
76*4882a593Smuzhiyun	#size-cells = <2>;
77*4882a593Smuzhiyun	fsl,srio-rmu-handle = <&rmu>;
78*4882a593Smuzhiyun	sleep = <&pmc 0x00080000>;
79*4882a593Smuzhiyun	ranges;
80*4882a593Smuzhiyun
81*4882a593Smuzhiyun	port1 {
82*4882a593Smuzhiyun		#address-cells = <2>;
83*4882a593Smuzhiyun		#size-cells = <2>;
84*4882a593Smuzhiyun		cell-index = <1>;
85*4882a593Smuzhiyun	};
86*4882a593Smuzhiyun
87*4882a593Smuzhiyun	port2 {
88*4882a593Smuzhiyun		#address-cells = <2>;
89*4882a593Smuzhiyun		#size-cells = <2>;
90*4882a593Smuzhiyun		cell-index = <2>;
91*4882a593Smuzhiyun	};
92*4882a593Smuzhiyun};
93*4882a593Smuzhiyun
94*4882a593Smuzhiyun&soc {
95*4882a593Smuzhiyun	#address-cells = <1>;
96*4882a593Smuzhiyun	#size-cells = <1>;
97*4882a593Smuzhiyun	device_type = "soc";
98*4882a593Smuzhiyun	compatible = "fsl,mpc8569-immr", "simple-bus";
99*4882a593Smuzhiyun	bus-frequency = <0>;		// Filled out by uboot.
100*4882a593Smuzhiyun
101*4882a593Smuzhiyun	ecm-law@0 {
102*4882a593Smuzhiyun		compatible = "fsl,ecm-law";
103*4882a593Smuzhiyun		reg = <0x0 0x1000>;
104*4882a593Smuzhiyun		fsl,num-laws = <10>;
105*4882a593Smuzhiyun	};
106*4882a593Smuzhiyun
107*4882a593Smuzhiyun	ecm@1000 {
108*4882a593Smuzhiyun		compatible = "fsl,mpc8569-ecm", "fsl,ecm";
109*4882a593Smuzhiyun		reg = <0x1000 0x1000>;
110*4882a593Smuzhiyun		interrupts = <17 2 0 0>;
111*4882a593Smuzhiyun	};
112*4882a593Smuzhiyun
113*4882a593Smuzhiyun	memory-controller@2000 {
114*4882a593Smuzhiyun		compatible = "fsl,mpc8569-memory-controller";
115*4882a593Smuzhiyun		reg = <0x2000 0x1000>;
116*4882a593Smuzhiyun		interrupts = <18 2 0 0>;
117*4882a593Smuzhiyun	};
118*4882a593Smuzhiyun
119*4882a593Smuzhiyun	i2c-sleep-nexus {
120*4882a593Smuzhiyun		#address-cells = <1>;
121*4882a593Smuzhiyun		#size-cells = <1>;
122*4882a593Smuzhiyun		compatible = "simple-bus";
123*4882a593Smuzhiyun		sleep = <&pmc 0x00000004>;
124*4882a593Smuzhiyun		ranges;
125*4882a593Smuzhiyun
126*4882a593Smuzhiyun/include/ "pq3-i2c-0.dtsi"
127*4882a593Smuzhiyun/include/ "pq3-i2c-1.dtsi"
128*4882a593Smuzhiyun
129*4882a593Smuzhiyun	};
130*4882a593Smuzhiyun
131*4882a593Smuzhiyun	duart-sleep-nexus {
132*4882a593Smuzhiyun		#address-cells = <1>;
133*4882a593Smuzhiyun		#size-cells = <1>;
134*4882a593Smuzhiyun		compatible = "simple-bus";
135*4882a593Smuzhiyun		sleep = <&pmc 0x00000002>;
136*4882a593Smuzhiyun		ranges;
137*4882a593Smuzhiyun
138*4882a593Smuzhiyun/include/ "pq3-duart-0.dtsi"
139*4882a593Smuzhiyun
140*4882a593Smuzhiyun	};
141*4882a593Smuzhiyun
142*4882a593Smuzhiyun	L2: l2-cache-controller@20000 {
143*4882a593Smuzhiyun		compatible = "fsl,mpc8569-l2-cache-controller";
144*4882a593Smuzhiyun		reg = <0x20000 0x1000>;
145*4882a593Smuzhiyun		cache-line-size = <32>;	// 32 bytes
146*4882a593Smuzhiyun		cache-size = <0x80000>; // L2, 512K
147*4882a593Smuzhiyun		interrupts = <16 2 0 0>;
148*4882a593Smuzhiyun	};
149*4882a593Smuzhiyun
150*4882a593Smuzhiyun/include/ "pq3-dma-0.dtsi"
151*4882a593Smuzhiyun/include/ "pq3-esdhc-0.dtsi"
152*4882a593Smuzhiyun	sdhc@2e000 {
153*4882a593Smuzhiyun		sleep = <&pmc 0x00200000>;
154*4882a593Smuzhiyun	};
155*4882a593Smuzhiyun
156*4882a593Smuzhiyun	par_io@e0100 {
157*4882a593Smuzhiyun		#address-cells = <1>;
158*4882a593Smuzhiyun		#size-cells = <1>;
159*4882a593Smuzhiyun		reg = <0xe0100 0x100>;
160*4882a593Smuzhiyun		ranges = <0x0 0xe0100 0x100>;
161*4882a593Smuzhiyun		device_type = "par_io";
162*4882a593Smuzhiyun	};
163*4882a593Smuzhiyun
164*4882a593Smuzhiyun/include/ "pq3-sec3.1-0.dtsi"
165*4882a593Smuzhiyun	crypto@30000 {
166*4882a593Smuzhiyun		sleep = <&pmc 0x01000000>;
167*4882a593Smuzhiyun	};
168*4882a593Smuzhiyun
169*4882a593Smuzhiyun/include/ "pq3-mpic.dtsi"
170*4882a593Smuzhiyun/include/ "pq3-rmu-0.dtsi"
171*4882a593Smuzhiyun	rmu@d3000 {
172*4882a593Smuzhiyun		sleep = <&pmc 0x00040000>;
173*4882a593Smuzhiyun	};
174*4882a593Smuzhiyun
175*4882a593Smuzhiyun	global-utilities@e0000 {
176*4882a593Smuzhiyun		#address-cells = <1>;
177*4882a593Smuzhiyun		#size-cells = <1>;
178*4882a593Smuzhiyun		compatible = "fsl,mpc8569-guts", "fsl,mpc8548-guts";
179*4882a593Smuzhiyun		reg = <0xe0000 0x1000>;
180*4882a593Smuzhiyun		ranges = <0 0xe0000 0x1000>;
181*4882a593Smuzhiyun		fsl,has-rstcr;
182*4882a593Smuzhiyun
183*4882a593Smuzhiyun		pmc: power@70 {
184*4882a593Smuzhiyun			compatible = "fsl,mpc8569-pmc",
185*4882a593Smuzhiyun				     "fsl,mpc8548-pmc";
186*4882a593Smuzhiyun			reg = <0x70 0x20>;
187*4882a593Smuzhiyun		};
188*4882a593Smuzhiyun	};
189*4882a593Smuzhiyun};
190*4882a593Smuzhiyun
191*4882a593Smuzhiyun&qe {
192*4882a593Smuzhiyun	#address-cells = <1>;
193*4882a593Smuzhiyun	#size-cells = <1>;
194*4882a593Smuzhiyun	device_type = "qe";
195*4882a593Smuzhiyun	compatible = "fsl,qe";
196*4882a593Smuzhiyun	sleep = <&pmc 0x00000800>;
197*4882a593Smuzhiyun	brg-frequency = <0>;
198*4882a593Smuzhiyun	bus-frequency = <0>;
199*4882a593Smuzhiyun	fsl,qe-num-riscs = <4>;
200*4882a593Smuzhiyun	fsl,qe-num-snums = <46>;
201*4882a593Smuzhiyun
202*4882a593Smuzhiyun	qeic: interrupt-controller@80 {
203*4882a593Smuzhiyun		interrupt-controller;
204*4882a593Smuzhiyun		compatible = "fsl,qe-ic";
205*4882a593Smuzhiyun		#address-cells = <0>;
206*4882a593Smuzhiyun		#interrupt-cells = <1>;
207*4882a593Smuzhiyun		reg = <0x80 0x80>;
208*4882a593Smuzhiyun		interrupts = <46 2 0 0 46 2 0 0>; //high:30 low:30
209*4882a593Smuzhiyun		interrupt-parent = <&mpic>;
210*4882a593Smuzhiyun	};
211*4882a593Smuzhiyun
212*4882a593Smuzhiyun	timer@440 {
213*4882a593Smuzhiyun		compatible = "fsl,mpc8569-qe-gtm",
214*4882a593Smuzhiyun			     "fsl,qe-gtm", "fsl,gtm";
215*4882a593Smuzhiyun		reg = <0x440 0x40>;
216*4882a593Smuzhiyun		interrupts = <12 13 14 15>;
217*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
218*4882a593Smuzhiyun		/* Filled in by U-Boot */
219*4882a593Smuzhiyun		clock-frequency = <0>;
220*4882a593Smuzhiyun	};
221*4882a593Smuzhiyun
222*4882a593Smuzhiyun	spi@4c0 {
223*4882a593Smuzhiyun		#address-cells = <1>;
224*4882a593Smuzhiyun		#size-cells = <0>;
225*4882a593Smuzhiyun		compatible = "fsl,mpc8569-qe-spi", "fsl,spi";
226*4882a593Smuzhiyun		reg = <0x4c0 0x40>;
227*4882a593Smuzhiyun		cell-index = <0>;
228*4882a593Smuzhiyun		interrupts = <2>;
229*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
230*4882a593Smuzhiyun	};
231*4882a593Smuzhiyun
232*4882a593Smuzhiyun	spi@500 {
233*4882a593Smuzhiyun		#address-cells = <1>;
234*4882a593Smuzhiyun		#size-cells = <0>;
235*4882a593Smuzhiyun		cell-index = <1>;
236*4882a593Smuzhiyun		compatible = "fsl,spi";
237*4882a593Smuzhiyun		reg = <0x500 0x40>;
238*4882a593Smuzhiyun		interrupts = <1>;
239*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
240*4882a593Smuzhiyun	};
241*4882a593Smuzhiyun
242*4882a593Smuzhiyun	usb@6c0 {
243*4882a593Smuzhiyun		compatible = "fsl,mpc8569-qe-usb",
244*4882a593Smuzhiyun			     "fsl,mpc8323-qe-usb";
245*4882a593Smuzhiyun		reg = <0x6c0 0x40 0x8b00 0x100>;
246*4882a593Smuzhiyun		interrupts = <11>;
247*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
248*4882a593Smuzhiyun	};
249*4882a593Smuzhiyun
250*4882a593Smuzhiyun	ucc@2000 {
251*4882a593Smuzhiyun		cell-index = <1>;
252*4882a593Smuzhiyun		reg = <0x2000 0x200>;
253*4882a593Smuzhiyun		interrupts = <32>;
254*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
255*4882a593Smuzhiyun	};
256*4882a593Smuzhiyun
257*4882a593Smuzhiyun	ucc@2200 {
258*4882a593Smuzhiyun		cell-index = <3>;
259*4882a593Smuzhiyun		reg = <0x2200 0x200>;
260*4882a593Smuzhiyun		interrupts = <34>;
261*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
262*4882a593Smuzhiyun	};
263*4882a593Smuzhiyun
264*4882a593Smuzhiyun	ucc@3000 {
265*4882a593Smuzhiyun		cell-index = <2>;
266*4882a593Smuzhiyun		reg = <0x3000 0x200>;
267*4882a593Smuzhiyun		interrupts = <33>;
268*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
269*4882a593Smuzhiyun	};
270*4882a593Smuzhiyun
271*4882a593Smuzhiyun	ucc@3200 {
272*4882a593Smuzhiyun		cell-index = <4>;
273*4882a593Smuzhiyun		reg = <0x3200 0x200>;
274*4882a593Smuzhiyun		interrupts = <35>;
275*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
276*4882a593Smuzhiyun	};
277*4882a593Smuzhiyun
278*4882a593Smuzhiyun	ucc@3400 {
279*4882a593Smuzhiyun		cell-index = <6>;
280*4882a593Smuzhiyun		reg = <0x3400 0x200>;
281*4882a593Smuzhiyun		interrupts = <41>;
282*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
283*4882a593Smuzhiyun	};
284*4882a593Smuzhiyun
285*4882a593Smuzhiyun	ucc@3600 {
286*4882a593Smuzhiyun		cell-index = <8>;
287*4882a593Smuzhiyun		reg = <0x3600 0x200>;
288*4882a593Smuzhiyun		interrupts = <43>;
289*4882a593Smuzhiyun		interrupt-parent = <&qeic>;
290*4882a593Smuzhiyun	};
291*4882a593Smuzhiyun
292*4882a593Smuzhiyun	muram@10000 {
293*4882a593Smuzhiyun		#address-cells = <1>;
294*4882a593Smuzhiyun		#size-cells = <1>;
295*4882a593Smuzhiyun		compatible = "fsl,qe-muram", "fsl,cpm-muram";
296*4882a593Smuzhiyun		ranges = <0x0 0x10000 0x20000>;
297*4882a593Smuzhiyun
298*4882a593Smuzhiyun		data-only@0 {
299*4882a593Smuzhiyun			compatible = "fsl,qe-muram-data",
300*4882a593Smuzhiyun				     "fsl,cpm-muram-data";
301*4882a593Smuzhiyun			reg = <0x0 0x20000>;
302*4882a593Smuzhiyun		};
303*4882a593Smuzhiyun	};
304*4882a593Smuzhiyun};
305