xref: /openbmc/u-boot/arch/powerpc/include/asm/immap_83xx.h (revision 3fdf7596dff87a79e2b41d07479c608d91d06cb3)
1 /*
2  * Copyright 2004-2011 Freescale Semiconductor, Inc.
3  *
4  * MPC83xx Internal Memory Map
5  *
6  * Contributors:
7  *	Dave Liu <daveliu@freescale.com>
8  *	Tanya Jiang <tanya.jiang@freescale.com>
9  *	Mandy Lavi <mandy.lavi@freescale.com>
10  *	Eran Liberty <liberty@freescale.com>
11  *
12  * This program is free software; you can redistribute it and/or
13  * modify it under the terms of the GNU General Public License as
14  * published by the Free Software Foundation; either version 2 of
15  * the License, or (at your option) any later version.
16  *
17  * This program is distributed in the hope that it will be useful,
18  * but WITHOUT ANY WARRANTY; without even the implied warranty of
19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20  * GNU General Public License for more details.
21  *
22  * You should have received a copy of the GNU General Public License
23  * along with this program; if not, write to the Free Software
24  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
25  * MA 02111-1307 USA
26  *
27  */
28 #ifndef __IMMAP_83xx__
29 #define __IMMAP_83xx__
30 
31 #include <asm/types.h>
32 #include <asm/fsl_i2c.h>
33 #include <asm/mpc8xxx_spi.h>
34 #include <asm/fsl_lbc.h>
35 #include <asm/fsl_dma.h>
36 
37 /*
38  * Local Access Window
39  */
40 typedef struct law83xx {
41 	u32 bar;		/* LBIU local access window base address register */
42 	u32 ar;			/* LBIU local access window attribute register */
43 } law83xx_t;
44 
45 /*
46  * System configuration registers
47  */
48 typedef struct sysconf83xx {
49 	u32 immrbar;		/* Internal memory map base address register */
50 	u8 res0[0x04];
51 	u32 altcbar;		/* Alternate configuration base address register */
52 	u8 res1[0x14];
53 	law83xx_t lblaw[4];	/* LBIU local access window */
54 	u8 res2[0x20];
55 	law83xx_t pcilaw[2];	/* PCI local access window */
56 	u8 res3[0x10];
57 	law83xx_t pcielaw[2];	/* PCI Express local access window */
58 	u8 res4[0x10];
59 	law83xx_t ddrlaw[2];	/* DDR local access window */
60 	u8 res5[0x50];
61 	u32 sgprl;		/* System General Purpose Register Low */
62 	u32 sgprh;		/* System General Purpose Register High */
63 	u32 spridr;		/* System Part and Revision ID Register */
64 	u8 res6[0x04];
65 	u32 spcr;		/* System Priority Configuration Register */
66 	u32 sicrl;		/* System I/O Configuration Register Low */
67 	u32 sicrh;		/* System I/O Configuration Register High */
68 	u8 res7[0x04];
69 	u32 sidcr0;		/* System I/O Delay Configuration Register 0 */
70 	u32 sidcr1;		/* System I/O Delay Configuration Register 1 */
71 	u32 ddrcdr;		/* DDR Control Driver Register */
72 	u32 ddrdsr;		/* DDR Debug Status Register */
73 	u32 obir;		/* Output Buffer Impedance Register */
74 	u8 res8[0xC];
75 	u32 pecr1;		/* PCI Express control register 1 */
76 #if defined(CONFIG_MPC830x)
77 	u32 sdhccr;		/* eSDHC Control Registers for MPC830x */
78 #else
79 	u32 pecr2;		/* PCI Express control register 2 */
80 #endif
81 #if defined(CONFIG_MPC8309)
82 	u32 can_dbg_ctrl;
83 	u32 res9a;
84 	u32 gpr1;
85 	u8 res9b[0xAC];
86 #else
87 	u8 res9[0xB8];
88 #endif
89 } sysconf83xx_t;
90 
91 /*
92  * Watch Dog Timer (WDT) Registers
93  */
94 typedef struct wdt83xx {
95 	u8 res0[4];
96 	u32 swcrr;		/* System watchdog control register */
97 	u32 swcnr;		/* System watchdog count register */
98 	u8 res1[2];
99 	u16 swsrr;		/* System watchdog service register */
100 	u8 res2[0xF0];
101 } wdt83xx_t;
102 
103 /*
104  * RTC/PIT Module Registers
105  */
106 typedef struct rtclk83xx {
107 	u32 cnr;		/* control register */
108 	u32 ldr;		/* load register */
109 	u32 psr;		/* prescale register */
110 	u32 ctr;		/* counter value field register */
111 	u32 evr;		/* event register */
112 	u32 alr;		/* alarm register */
113 	u8 res0[0xE8];
114 } rtclk83xx_t;
115 
116 /*
117  * Global timer module
118  */
119 typedef struct gtm83xx {
120 	u8 cfr1;		/* Timer1/2 Configuration */
121 	u8 res0[3];
122 	u8 cfr2;		/* Timer3/4 Configuration */
123 	u8 res1[11];
124 	u16 mdr1;		/* Timer1 Mode Register */
125 	u16 mdr2;		/* Timer2 Mode Register */
126 	u16 rfr1;		/* Timer1 Reference Register */
127 	u16 rfr2;		/* Timer2 Reference Register */
128 	u16 cpr1;		/* Timer1 Capture Register */
129 	u16 cpr2;		/* Timer2 Capture Register */
130 	u16 cnr1;		/* Timer1 Counter Register */
131 	u16 cnr2;		/* Timer2 Counter Register */
132 	u16 mdr3;		/* Timer3 Mode Register */
133 	u16 mdr4;		/* Timer4 Mode Register */
134 	u16 rfr3;		/* Timer3 Reference Register */
135 	u16 rfr4;		/* Timer4 Reference Register */
136 	u16 cpr3;		/* Timer3 Capture Register */
137 	u16 cpr4;		/* Timer4 Capture Register */
138 	u16 cnr3;		/* Timer3 Counter Register */
139 	u16 cnr4;		/* Timer4 Counter Register */
140 	u16 evr1;		/* Timer1 Event Register */
141 	u16 evr2;		/* Timer2 Event Register */
142 	u16 evr3;		/* Timer3 Event Register */
143 	u16 evr4;		/* Timer4 Event Register */
144 	u16 psr1;		/* Timer1 Prescaler Register */
145 	u16 psr2;		/* Timer2 Prescaler Register */
146 	u16 psr3;		/* Timer3 Prescaler Register */
147 	u16 psr4;		/* Timer4 Prescaler Register */
148 	u8 res[0xC0];
149 } gtm83xx_t;
150 
151 /*
152  * Integrated Programmable Interrupt Controller
153  */
154 typedef struct ipic83xx {
155 	u32 sicfr;		/* System Global Interrupt Configuration Register */
156 	u32 sivcr;		/* System Global Interrupt Vector Register */
157 	u32 sipnr_h;		/* System Internal Interrupt Pending Register - High */
158 	u32 sipnr_l;		/* System Internal Interrupt Pending Register - Low */
159 	u32 siprr_a;		/* System Internal Interrupt Group A Priority Register */
160 	u32 siprr_b;		/* System Internal Interrupt Group B Priority Register */
161 	u32 siprr_c;		/* System Internal Interrupt Group C Priority Register */
162 	u32 siprr_d;		/* System Internal Interrupt Group D Priority Register */
163 	u32 simsr_h;		/* System Internal Interrupt Mask Register - High */
164 	u32 simsr_l;		/* System Internal Interrupt Mask Register - Low */
165 	u32 sicnr;		/* System Internal Interrupt Control Register */
166 	u32 sepnr;		/* System External Interrupt Pending Register */
167 	u32 smprr_a;		/* System Mixed Interrupt Group A Priority Register */
168 	u32 smprr_b;		/* System Mixed Interrupt Group B Priority Register */
169 	u32 semsr;		/* System External Interrupt Mask Register */
170 	u32 secnr;		/* System External Interrupt Control Register */
171 	u32 sersr;		/* System Error Status Register */
172 	u32 sermr;		/* System Error Mask Register */
173 	u32 sercr;		/* System Error Control Register */
174 	u32 sepcr;		/* System External Interrupt Polarity Control Register */
175 	u32 sifcr_h;		/* System Internal Interrupt Force Register - High */
176 	u32 sifcr_l;		/* System Internal Interrupt Force Register - Low */
177 	u32 sefcr;		/* System External Interrupt Force Register */
178 	u32 serfr;		/* System Error Force Register */
179 	u32 scvcr;		/* System Critical Interrupt Vector Register */
180 	u32 smvcr;		/* System Management Interrupt Vector Register */
181 	u8 res[0x98];
182 } ipic83xx_t;
183 
184 /*
185  * System Arbiter Registers
186  */
187 typedef struct arbiter83xx {
188 	u32 acr;		/* Arbiter Configuration Register */
189 	u32 atr;		/* Arbiter Timers Register */
190 	u8 res[4];
191 	u32 aer;		/* Arbiter Event Register */
192 	u32 aidr;		/* Arbiter Interrupt Definition Register */
193 	u32 amr;		/* Arbiter Mask Register */
194 	u32 aeatr;		/* Arbiter Event Attributes Register */
195 	u32 aeadr;		/* Arbiter Event Address Register */
196 	u32 aerr;		/* Arbiter Event Response Register */
197 	u8 res1[0xDC];
198 } arbiter83xx_t;
199 
200 /*
201  * Reset Module
202  */
203 typedef struct reset83xx {
204 	u32 rcwl;		/* Reset Configuration Word Low Register */
205 	u32 rcwh;		/* Reset Configuration Word High Register */
206 	u8 res0[8];
207 	u32 rsr;		/* Reset Status Register */
208 	u32 rmr;		/* Reset Mode Register */
209 	u32 rpr;		/* Reset protection Register */
210 	u32 rcr;		/* Reset Control Register */
211 	u32 rcer;		/* Reset Control Enable Register */
212 	u8 res1[0xDC];
213 } reset83xx_t;
214 
215 /*
216  * Clock Module
217  */
218 typedef struct clk83xx {
219 	u32 spmr;		/* system PLL mode Register */
220 	u32 occr;		/* output clock control Register */
221 	u32 sccr;		/* system clock control Register */
222 	u8 res0[0xF4];
223 } clk83xx_t;
224 
225 /*
226  * Power Management Control Module
227  */
228 typedef struct pmc83xx {
229 	u32 pmccr;		/* PMC Configuration Register */
230 	u32 pmcer;		/* PMC Event Register */
231 	u32 pmcmr;		/* PMC Mask Register */
232 	u32 pmccr1;		/* PMC Configuration Register 1 */
233 	u32 pmccr2;		/* PMC Configuration Register 2 */
234 	u8 res0[0xEC];
235 } pmc83xx_t;
236 
237 /*
238  * General purpose I/O module
239  */
240 typedef struct gpio83xx {
241 	u32 dir;		/* direction register */
242 	u32 odr;		/* open drain register */
243 	u32 dat;		/* data register */
244 	u32 ier;		/* interrupt event register */
245 	u32 imr;		/* interrupt mask register */
246 	u32 icr;		/* external interrupt control register */
247 	u8 res0[0xE8];
248 } gpio83xx_t;
249 
250 /*
251  * QE Ports Interrupts Registers
252  */
253 typedef struct qepi83xx {
254 	u8 res0[0xC];
255 	u32 qepier;		/* QE Ports Interrupt Event Register */
256 	u32 qepimr;		/* QE Ports Interrupt Mask Register */
257 	u32 qepicr;		/* QE Ports Interrupt Control Register */
258 	u8 res1[0xE8];
259 } qepi83xx_t;
260 
261 /*
262  * QE Parallel I/O Ports
263  */
264 typedef struct gpio_n {
265 	u32 podr;		/* Open Drain Register */
266 	u32 pdat;		/* Data Register */
267 	u32 dir1;		/* direction register 1 */
268 	u32 dir2;		/* direction register 2 */
269 	u32 ppar1;		/* Pin Assignment Register 1 */
270 	u32 ppar2;		/* Pin Assignment Register 2 */
271 } gpio_n_t;
272 
273 typedef struct qegpio83xx {
274 	gpio_n_t ioport[0x7];
275 	u8 res0[0x358];
276 } qepio83xx_t;
277 
278 /*
279  * QE Secondary Bus Access Windows
280  */
281 typedef struct qesba83xx {
282 	u32 lbmcsar;		/* Local bus memory controller start address */
283 	u32 sdmcsar;		/* Secondary DDR memory controller start address */
284 	u8 res0[0x38];
285 	u32 lbmcear;		/* Local bus memory controller end address */
286 	u32 sdmcear;		/* Secondary DDR memory controller end address */
287 	u8 res1[0x38];
288 	u32 lbmcar;		/* Local bus memory controller attributes */
289 	u32 sdmcar;		/* Secondary DDR memory controller attributes */
290 	u8 res2[0x378];
291 } qesba83xx_t;
292 
293 /*
294  * DDR Memory Controller Memory Map
295  */
296 #if defined(CONFIG_FSL_DDR2) || defined(CONFIG_FSL_DDR3)
297 typedef struct ccsr_ddr {
298 	u32	cs0_bnds;		/* Chip Select 0 Memory Bounds */
299 	u8	res1[4];
300 	u32	cs1_bnds;		/* Chip Select 1 Memory Bounds */
301 	u8	res2[4];
302 	u32	cs2_bnds;		/* Chip Select 2 Memory Bounds */
303 	u8	res3[4];
304 	u32	cs3_bnds;		/* Chip Select 3 Memory Bounds */
305 	u8	res4[100];
306 	u32	cs0_config;		/* Chip Select Configuration */
307 	u32	cs1_config;		/* Chip Select Configuration */
308 	u32	cs2_config;		/* Chip Select Configuration */
309 	u32	cs3_config;		/* Chip Select Configuration */
310 	u8	res4a[48];
311 	u32	cs0_config_2;		/* Chip Select Configuration 2 */
312 	u32	cs1_config_2;		/* Chip Select Configuration 2 */
313 	u32	cs2_config_2;		/* Chip Select Configuration 2 */
314 	u32	cs3_config_2;		/* Chip Select Configuration 2 */
315 	u8	res5[48];
316 	u32	timing_cfg_3;		/* SDRAM Timing Configuration 3 */
317 	u32	timing_cfg_0;		/* SDRAM Timing Configuration 0 */
318 	u32	timing_cfg_1;		/* SDRAM Timing Configuration 1 */
319 	u32	timing_cfg_2;		/* SDRAM Timing Configuration 2 */
320 	u32	sdram_cfg;		/* SDRAM Control Configuration */
321 	u32	sdram_cfg_2;		/* SDRAM Control Configuration 2 */
322 	u32	sdram_mode;		/* SDRAM Mode Configuration */
323 	u32	sdram_mode_2;		/* SDRAM Mode Configuration 2 */
324 	u32	sdram_md_cntl;		/* SDRAM Mode Control */
325 	u32	sdram_interval;		/* SDRAM Interval Configuration */
326 	u32	sdram_data_init;	/* SDRAM Data initialization */
327 	u8	res6[4];
328 	u32	sdram_clk_cntl;		/* SDRAM Clock Control */
329 	u8	res7[20];
330 	u32	init_addr;		/* training init addr */
331 	u32	init_ext_addr;		/* training init extended addr */
332 	u8	res8_1[16];
333 	u32	timing_cfg_4;		/* SDRAM Timing Configuration 4 */
334 	u32	timing_cfg_5;		/* SDRAM Timing Configuration 5 */
335 	u8	reg8_1a[8];
336 	u32	ddr_zq_cntl;		/* ZQ calibration control*/
337 	u32	ddr_wrlvl_cntl;		/* write leveling control*/
338 	u8	reg8_1aa[4];
339 	u32	ddr_sr_cntr;		/* self refresh counter */
340 	u32	ddr_sdram_rcw_1;	/* Control Words 1 */
341 	u32	ddr_sdram_rcw_2;	/* Control Words 2 */
342 	u8	reg_1ab[8];
343 	u32	ddr_wrlvl_cntl_2;	/* write leveling control 2 */
344 	u32	ddr_wrlvl_cntl_3;	/* write leveling control 3 */
345 	u8	res8_1b[104];
346 	u32	sdram_mode_3;		/* SDRAM Mode Configuration 3 */
347 	u32	sdram_mode_4;		/* SDRAM Mode Configuration 4 */
348 	u32	sdram_mode_5;		/* SDRAM Mode Configuration 5 */
349 	u32	sdram_mode_6;		/* SDRAM Mode Configuration 6 */
350 	u32	sdram_mode_7;		/* SDRAM Mode Configuration 7 */
351 	u32	sdram_mode_8;		/* SDRAM Mode Configuration 8 */
352 	u8	res8_1ba[0x908];
353 	u32	ddr_dsr1;		/* Debug Status 1 */
354 	u32	ddr_dsr2;		/* Debug Status 2 */
355 	u32	ddr_cdr1;		/* Control Driver 1 */
356 	u32	ddr_cdr2;		/* Control Driver 2 */
357 	u8	res8_1c[200];
358 	u32	ip_rev1;		/* IP Block Revision 1 */
359 	u32	ip_rev2;		/* IP Block Revision 2 */
360 	u32	eor;			/* Enhanced Optimization Register */
361 	u8	res8_2[252];
362 	u32	mtcr;			/* Memory Test Control Register */
363 	u8	res8_3[28];
364 	u32	mtp1;			/* Memory Test Pattern 1 */
365 	u32	mtp2;			/* Memory Test Pattern 2 */
366 	u32	mtp3;			/* Memory Test Pattern 3 */
367 	u32	mtp4;			/* Memory Test Pattern 4 */
368 	u32	mtp5;			/* Memory Test Pattern 5 */
369 	u32	mtp6;			/* Memory Test Pattern 6 */
370 	u32	mtp7;			/* Memory Test Pattern 7 */
371 	u32	mtp8;			/* Memory Test Pattern 8 */
372 	u32	mtp9;			/* Memory Test Pattern 9 */
373 	u32	mtp10;			/* Memory Test Pattern 10 */
374 	u8	res8_4[184];
375 	u32	data_err_inject_hi;	/* Data Path Err Injection Mask High */
376 	u32	data_err_inject_lo;	/* Data Path Err Injection Mask Low */
377 	u32	ecc_err_inject;		/* Data Path Err Injection Mask ECC */
378 	u8	res9[20];
379 	u32	capture_data_hi;	/* Data Path Read Capture High */
380 	u32	capture_data_lo;	/* Data Path Read Capture Low */
381 	u32	capture_ecc;		/* Data Path Read Capture ECC */
382 	u8	res10[20];
383 	u32	err_detect;		/* Error Detect */
384 	u32	err_disable;		/* Error Disable */
385 	u32	err_int_en;
386 	u32	capture_attributes;	/* Error Attrs Capture */
387 	u32	capture_address;	/* Error Addr Capture */
388 	u32	capture_ext_address;	/* Error Extended Addr Capture */
389 	u32	err_sbe;		/* Single-Bit ECC Error Management */
390 	u8	res11[164];
391 	u32	debug[32];		/* debug_1 to debug_32 */
392 	u8	res12[128];
393 } ccsr_ddr_t;
394 #else
395 typedef struct ddr_cs_bnds {
396 	u32 csbnds;
397 	u8 res0[4];
398 } ddr_cs_bnds_t;
399 
400 typedef struct ddr83xx {
401 	ddr_cs_bnds_t csbnds[4];/* Chip Select x Memory Bounds */
402 	u8 res0[0x60];
403 	u32 cs_config[4];	/* Chip Select x Configuration */
404 	u8 res1[0x70];
405 	u32 timing_cfg_3;	/* SDRAM Timing Configuration 3 */
406 	u32 timing_cfg_0;	/* SDRAM Timing Configuration 0 */
407 	u32 timing_cfg_1;	/* SDRAM Timing Configuration 1 */
408 	u32 timing_cfg_2;	/* SDRAM Timing Configuration 2 */
409 	u32 sdram_cfg;		/* SDRAM Control Configuration */
410 	u32 sdram_cfg2;		/* SDRAM Control Configuration 2 */
411 	u32 sdram_mode;		/* SDRAM Mode Configuration */
412 	u32 sdram_mode2;	/* SDRAM Mode Configuration 2 */
413 	u32 sdram_md_cntl;	/* SDRAM Mode Control */
414 	u32 sdram_interval;	/* SDRAM Interval Configuration */
415 	u32 ddr_data_init;	/* SDRAM Data Initialization */
416 	u8 res2[4];
417 	u32 sdram_clk_cntl;	/* SDRAM Clock Control */
418 	u8 res3[0x14];
419 	u32 ddr_init_addr;	/* DDR training initialization address */
420 	u32 ddr_init_ext_addr;	/* DDR training initialization extended address */
421 	u8 res4[0xAA8];
422 	u32 ddr_ip_rev1;	/* DDR IP block revision 1 */
423 	u32 ddr_ip_rev2;	/* DDR IP block revision 2 */
424 	u8 res5[0x200];
425 	u32 data_err_inject_hi;	/* Memory Data Path Error Injection Mask High */
426 	u32 data_err_inject_lo;	/* Memory Data Path Error Injection Mask Low */
427 	u32 ecc_err_inject;	/* Memory Data Path Error Injection Mask ECC */
428 	u8 res6[0x14];
429 	u32 capture_data_hi;	/* Memory Data Path Read Capture High */
430 	u32 capture_data_lo;	/* Memory Data Path Read Capture Low */
431 	u32 capture_ecc;	/* Memory Data Path Read Capture ECC */
432 	u8 res7[0x14];
433 	u32 err_detect;		/* Memory Error Detect */
434 	u32 err_disable;	/* Memory Error Disable */
435 	u32 err_int_en;		/* Memory Error Interrupt Enable */
436 	u32 capture_attributes;	/* Memory Error Attributes Capture */
437 	u32 capture_address;	/* Memory Error Address Capture */
438 	u32 capture_ext_address;/* Memory Error Extended Address Capture */
439 	u32 err_sbe;		/* Memory Single-Bit ECC Error Management */
440 	u8 res8[0xA4];
441 	u32 debug_reg;
442 	u8 res9[0xFC];
443 } ddr83xx_t;
444 #endif
445 
446 /*
447  * DUART
448  */
449 typedef struct duart83xx {
450 	u8 urbr_ulcr_udlb;	/* combined register for URBR, UTHR and UDLB */
451 	u8 uier_udmb;		/* combined register for UIER and UDMB */
452 	u8 uiir_ufcr_uafr;	/* combined register for UIIR, UFCR and UAFR */
453 	u8 ulcr;		/* line control register */
454 	u8 umcr;		/* MODEM control register */
455 	u8 ulsr;		/* line status register */
456 	u8 umsr;		/* MODEM status register */
457 	u8 uscr;		/* scratch register */
458 	u8 res0[8];
459 	u8 udsr;		/* DMA status register */
460 	u8 res1[3];
461 	u8 res2[0xEC];
462 } duart83xx_t;
463 
464 /*
465  * DMA/Messaging Unit
466  */
467 typedef struct dma83xx {
468 	u32 res0[0xC];		/* 0x0-0x29 reseverd */
469 	u32 omisr;		/* 0x30 Outbound message interrupt status register */
470 	u32 omimr;		/* 0x34 Outbound message interrupt mask register */
471 	u32 res1[0x6];		/* 0x38-0x49 reserved */
472 	u32 imr0;		/* 0x50 Inbound message register 0 */
473 	u32 imr1;		/* 0x54 Inbound message register 1 */
474 	u32 omr0;		/* 0x58 Outbound message register 0 */
475 	u32 omr1;		/* 0x5C Outbound message register 1 */
476 	u32 odr;		/* 0x60 Outbound doorbell register */
477 	u32 res2;		/* 0x64-0x67 reserved */
478 	u32 idr;		/* 0x68 Inbound doorbell register */
479 	u32 res3[0x5];		/* 0x6C-0x79 reserved */
480 	u32 imisr;		/* 0x80 Inbound message interrupt status register */
481 	u32 imimr;		/* 0x84 Inbound message interrupt mask register */
482 	u32 res4[0x1E];		/* 0x88-0x99 reserved */
483 	struct fsl_dma dma[4];
484 } dma83xx_t;
485 
486 /*
487  * PCI Software Configuration Registers
488  */
489 typedef struct pciconf83xx {
490 	u32 config_address;
491 	u32 config_data;
492 	u32 int_ack;
493 	u8 res[116];
494 } pciconf83xx_t;
495 
496 /*
497  * PCI Outbound Translation Register
498  */
499 typedef struct pci_outbound_window {
500 	u32 potar;
501 	u8 res0[4];
502 	u32 pobar;
503 	u8 res1[4];
504 	u32 pocmr;
505 	u8 res2[4];
506 } pot83xx_t;
507 
508 /*
509  * Sequencer
510  */
511 typedef struct ios83xx {
512 	pot83xx_t pot[6];
513 	u8 res0[0x60];
514 	u32 pmcr;
515 	u8 res1[4];
516 	u32 dtcr;
517 	u8 res2[4];
518 } ios83xx_t;
519 
520 /*
521  * PCI Controller Control and Status Registers
522  */
523 typedef struct pcictrl83xx {
524 	u32 esr;
525 	u32 ecdr;
526 	u32 eer;
527 	u32 eatcr;
528 	u32 eacr;
529 	u32 eeacr;
530 	u32 edlcr;
531 	u32 edhcr;
532 	u32 gcr;
533 	u32 ecr;
534 	u32 gsr;
535 	u8 res0[12];
536 	u32 pitar2;
537 	u8 res1[4];
538 	u32 pibar2;
539 	u32 piebar2;
540 	u32 piwar2;
541 	u8 res2[4];
542 	u32 pitar1;
543 	u8 res3[4];
544 	u32 pibar1;
545 	u32 piebar1;
546 	u32 piwar1;
547 	u8 res4[4];
548 	u32 pitar0;
549 	u8 res5[4];
550 	u32 pibar0;
551 	u8 res6[4];
552 	u32 piwar0;
553 	u8 res7[132];
554 } pcictrl83xx_t;
555 
556 /*
557  * USB
558  */
559 typedef struct usb83xx {
560 	u8 fixme[0x1000];
561 } usb83xx_t;
562 
563 /*
564  * TSEC
565  */
566 typedef struct tsec83xx {
567 	u8 fixme[0x1000];
568 } tsec83xx_t;
569 
570 /*
571  * Security
572  */
573 typedef struct security83xx {
574 	u8 fixme[0x10000];
575 } security83xx_t;
576 
577 /*
578  *  PCI Express
579  */
580 struct pex_inbound_window {
581 	u32 ar;
582 	u32 tar;
583 	u32 barl;
584 	u32 barh;
585 };
586 
587 struct pex_outbound_window {
588 	u32 ar;
589 	u32 bar;
590 	u32 tarl;
591 	u32 tarh;
592 };
593 
594 struct pex_csb_bridge {
595 	u32 pex_csb_ver;
596 	u32 pex_csb_cab;
597 	u32 pex_csb_ctrl;
598 	u8 res0[8];
599 	u32 pex_dms_dstmr;
600 	u8 res1[4];
601 	u32 pex_cbs_stat;
602 	u8 res2[0x20];
603 	u32 pex_csb_obctrl;
604 	u32 pex_csb_obstat;
605 	u8 res3[0x98];
606 	u32 pex_csb_ibctrl;
607 	u32 pex_csb_ibstat;
608 	u8 res4[0xb8];
609 	u32 pex_wdma_ctrl;
610 	u32 pex_wdma_addr;
611 	u32 pex_wdma_stat;
612 	u8 res5[0x94];
613 	u32 pex_rdma_ctrl;
614 	u32 pex_rdma_addr;
615 	u32 pex_rdma_stat;
616 	u8 res6[0xd4];
617 	u32 pex_ombcr;
618 	u32 pex_ombdr;
619 	u8 res7[0x38];
620 	u32 pex_imbcr;
621 	u32 pex_imbdr;
622 	u8 res8[0x38];
623 	u32 pex_int_enb;
624 	u32 pex_int_stat;
625 	u32 pex_int_apio_vec1;
626 	u32 pex_int_apio_vec2;
627 	u8 res9[0x10];
628 	u32 pex_int_ppio_vec1;
629 	u32 pex_int_ppio_vec2;
630 	u32 pex_int_wdma_vec1;
631 	u32 pex_int_wdma_vec2;
632 	u32 pex_int_rdma_vec1;
633 	u32 pex_int_rdma_vec2;
634 	u32 pex_int_misc_vec;
635 	u8 res10[4];
636 	u32 pex_int_axi_pio_enb;
637 	u32 pex_int_axi_wdma_enb;
638 	u32 pex_int_axi_rdma_enb;
639 	u32 pex_int_axi_misc_enb;
640 	u32 pex_int_axi_pio_stat;
641 	u32 pex_int_axi_wdma_stat;
642 	u32 pex_int_axi_rdma_stat;
643 	u32 pex_int_axi_misc_stat;
644 	u8 res11[0xa0];
645 	struct pex_outbound_window pex_outbound_win[4];
646 	u8 res12[0x100];
647 	u32 pex_epiwtar0;
648 	u32 pex_epiwtar1;
649 	u32 pex_epiwtar2;
650 	u32 pex_epiwtar3;
651 	u8 res13[0x70];
652 	struct pex_inbound_window pex_inbound_win[4];
653 };
654 
655 typedef struct pex83xx {
656 	u8 pex_cfg_header[0x404];
657 	u32 pex_ltssm_stat;
658 	u8 res0[0x30];
659 	u32 pex_ack_replay_timeout;
660 	u8 res1[4];
661 	u32 pex_gclk_ratio;
662 	u8 res2[0xc];
663 	u32 pex_pm_timer;
664 	u32 pex_pme_timeout;
665 	u8 res3[4];
666 	u32 pex_aspm_req_timer;
667 	u8 res4[0x18];
668 	u32 pex_ssvid_update;
669 	u8 res5[0x34];
670 	u32 pex_cfg_ready;
671 	u8 res6[0x24];
672 	u32 pex_bar_sizel;
673 	u8 res7[4];
674 	u32 pex_bar_sel;
675 	u8 res8[0x20];
676 	u32 pex_bar_pf;
677 	u8 res9[0x88];
678 	u32 pex_pme_to_ack_tor;
679 	u8 res10[0xc];
680 	u32 pex_ss_intr_mask;
681 	u8 res11[0x25c];
682 	struct pex_csb_bridge bridge;
683 	u8 res12[0x160];
684 } pex83xx_t;
685 
686 /*
687  * SATA
688  */
689 typedef struct sata83xx {
690 	u8 fixme[0x1000];
691 } sata83xx_t;
692 
693 /*
694  * eSDHC
695  */
696 typedef struct sdhc83xx {
697 	u8 fixme[0x1000];
698 } sdhc83xx_t;
699 
700 /*
701  * SerDes
702  */
703 typedef struct serdes83xx {
704 	u32 srdscr0;
705 	u32 srdscr1;
706 	u32 srdscr2;
707 	u32 srdscr3;
708 	u32 srdscr4;
709 	u8 res0[0xc];
710 	u32 srdsrstctl;
711 	u8 res1[0xdc];
712 } serdes83xx_t;
713 
714 /*
715  * On Chip ROM
716  */
717 typedef struct rom83xx {
718 #if defined(CONFIG_MPC8309)
719 	u8 mem[0x8000];
720 #else
721 	u8 mem[0x10000];
722 #endif
723 } rom83xx_t;
724 
725 /*
726  * TDM
727  */
728 typedef struct tdm83xx {
729 	u8 fixme[0x200];
730 } tdm83xx_t;
731 
732 /*
733  * TDM DMAC
734  */
735 typedef struct tdmdmac83xx {
736 	u8 fixme[0x2000];
737 } tdmdmac83xx_t;
738 
739 #if defined(CONFIG_MPC834x)
740 typedef struct immap {
741 	sysconf83xx_t		sysconf;	/* System configuration */
742 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
743 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
744 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
745 	gtm83xx_t		gtm[2];		/* Global Timers Module */
746 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
747 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
748 	reset83xx_t		reset;		/* Reset Module */
749 	clk83xx_t		clk;		/* System Clock Module */
750 	pmc83xx_t		pmc;		/* Power Management Control Module */
751 	gpio83xx_t		gpio[2];	/* General purpose I/O module */
752 	u8			res0[0x200];
753 	u8			dll_ddr[0x100];
754 	u8			dll_lbc[0x100];
755 	u8			res1[0xE00];
756 #if defined(CONFIG_FSL_DDR2) || defined(CONFIG_FSL_DDR3)
757 	ccsr_ddr_t		ddr;	/* DDR Memory Controller Memory */
758 #else
759 	ddr83xx_t		ddr;	/* DDR Memory Controller Memory */
760 #endif
761 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
762 	u8			res2[0x1300];
763 	duart83xx_t		duart[2];	/* DUART */
764 	u8			res3[0x900];
765 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
766 	u8			res4[0x1000];
767 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
768 	dma83xx_t		dma;		/* DMA */
769 	pciconf83xx_t		pci_conf[2];	/* PCI Software Configuration Registers */
770 	ios83xx_t		ios;		/* Sequencer */
771 	pcictrl83xx_t		pci_ctrl[2];	/* PCI Controller Control and Status Registers */
772 	u8			res5[0x19900];
773 	usb83xx_t		usb[2];
774 	tsec83xx_t		tsec[2];
775 	u8			res6[0xA000];
776 	security83xx_t		security;
777 	u8			res7[0xC0000];
778 } immap_t;
779 
780 #ifdef CONFIG_HAS_FSL_MPH_USB
781 #define CONFIG_SYS_MPC83xx_USB_OFFSET  0x22000	/* use the MPH controller */
782 #else
783 #define CONFIG_SYS_MPC83xx_USB_OFFSET  0x23000	/* use the DR controller */
784 #endif
785 
786 #elif defined(CONFIG_MPC8313)
787 typedef struct immap {
788 	sysconf83xx_t		sysconf;	/* System configuration */
789 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
790 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
791 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
792 	gtm83xx_t		gtm[2];		/* Global Timers Module */
793 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
794 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
795 	reset83xx_t		reset;		/* Reset Module */
796 	clk83xx_t		clk;		/* System Clock Module */
797 	pmc83xx_t		pmc;		/* Power Management Control Module */
798 	gpio83xx_t		gpio[1];	/* General purpose I/O module */
799 	u8			res0[0x1300];
800 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
801 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
802 	u8			res1[0x1300];
803 	duart83xx_t		duart[2];	/* DUART */
804 	u8			res2[0x900];
805 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
806 	u8			res3[0x1000];
807 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
808 	dma83xx_t		dma;		/* DMA */
809 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
810 	u8			res4[0x80];
811 	ios83xx_t		ios;		/* Sequencer */
812 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
813 	u8			res5[0x1aa00];
814 	usb83xx_t		usb[1];
815 	tsec83xx_t		tsec[2];
816 	u8			res6[0xA000];
817 	security83xx_t		security;
818 	u8			res7[0xC0000];
819 } immap_t;
820 
821 #elif defined(CONFIG_MPC8308) || defined(CONFIG_MPC8315)
822 typedef struct immap {
823 	sysconf83xx_t		sysconf;	/* System configuration */
824 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
825 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
826 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
827 	gtm83xx_t		gtm[2];		/* Global Timers Module */
828 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
829 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
830 	reset83xx_t		reset;		/* Reset Module */
831 	clk83xx_t		clk;		/* System Clock Module */
832 	pmc83xx_t		pmc;		/* Power Management Control Module */
833 	gpio83xx_t		gpio[1];	/* General purpose I/O module */
834 	u8			res0[0x1300];
835 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
836 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
837 	u8			res1[0x1300];
838 	duart83xx_t		duart[2];	/* DUART */
839 	u8			res2[0x900];
840 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
841 	u8			res3[0x1000];
842 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
843 	dma83xx_t		dma;		/* DMA */
844 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
845 	u8			res4[0x80];
846 	ios83xx_t		ios;		/* Sequencer */
847 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
848 	u8			res5[0xa00];
849 	pex83xx_t		pciexp[2];	/* PCI Express Controller */
850 	u8			res6[0xb000];
851 	tdm83xx_t		tdm;		/* TDM Controller */
852 	u8			res7[0x1e00];
853 	sata83xx_t		sata[2];	/* SATA Controller */
854 	u8			res8[0x9000];
855 	usb83xx_t		usb[1];		/* USB DR Controller */
856 	tsec83xx_t		tsec[2];
857 	u8			res9[0x6000];
858 	tdmdmac83xx_t		tdmdmac;	/* TDM DMAC */
859 	u8			res10[0x2000];
860 	security83xx_t		security;
861 	u8			res11[0xA3000];
862 	serdes83xx_t		serdes[1];	/* SerDes Registers */
863 	u8			res12[0x1CF00];
864 } immap_t;
865 
866 #elif defined(CONFIG_MPC837x)
867 typedef struct immap {
868 	sysconf83xx_t		sysconf;	/* System configuration */
869 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
870 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
871 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
872 	gtm83xx_t		gtm[2];		/* Global Timers Module */
873 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
874 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
875 	reset83xx_t		reset;		/* Reset Module */
876 	clk83xx_t		clk;		/* System Clock Module */
877 	pmc83xx_t		pmc;		/* Power Management Control Module */
878 	gpio83xx_t		gpio[2];	/* General purpose I/O module */
879 	u8			res0[0x1200];
880 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
881 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
882 	u8			res1[0x1300];
883 	duart83xx_t		duart[2];	/* DUART */
884 	u8			res2[0x900];
885 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
886 	u8			res3[0x1000];
887 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
888 	dma83xx_t		dma;		/* DMA */
889 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
890 	u8			res4[0x80];
891 	ios83xx_t		ios;		/* Sequencer */
892 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
893 	u8			res5[0xa00];
894 	pex83xx_t		pciexp[2];	/* PCI Express Controller */
895 	u8			res6[0xd000];
896 	sata83xx_t		sata[4];	/* SATA Controller */
897 	u8			res7[0x7000];
898 	usb83xx_t		usb[1];		/* USB DR Controller */
899 	tsec83xx_t		tsec[2];
900 	u8			res8[0x8000];
901 	sdhc83xx_t		sdhc;		/* SDHC Controller */
902 	u8			res9[0x1000];
903 	security83xx_t		security;
904 	u8			res10[0xA3000];
905 	serdes83xx_t		serdes[2];	/* SerDes Registers */
906 	u8			res11[0xCE00];
907 	rom83xx_t		rom;		/* On Chip ROM */
908 } immap_t;
909 
910 #elif defined(CONFIG_MPC8360)
911 typedef struct immap {
912 	sysconf83xx_t		sysconf;	/* System configuration */
913 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
914 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
915 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
916 	u8			res0[0x200];
917 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
918 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
919 	reset83xx_t		reset;		/* Reset Module */
920 	clk83xx_t		clk;		/* System Clock Module */
921 	pmc83xx_t		pmc;		/* Power Management Control Module */
922 	qepi83xx_t		qepi;		/* QE Ports Interrupts Registers */
923 	u8			res1[0x300];
924 	u8			dll_ddr[0x100];
925 	u8			dll_lbc[0x100];
926 	u8			res2[0x200];
927 	qepio83xx_t		qepio;		/* QE Parallel I/O ports */
928 	qesba83xx_t		qesba;		/* QE Secondary Bus Access Windows */
929 	u8			res3[0x400];
930 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
931 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
932 	u8			res4[0x1300];
933 	duart83xx_t		duart[2];	/* DUART */
934 	u8			res5[0x900];
935 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
936 	u8			res6[0x2000];
937 	dma83xx_t		dma;		/* DMA */
938 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
939 	u8			res7[128];
940 	ios83xx_t		ios;		/* Sequencer (IOS) */
941 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
942 	u8			res8[0x4A00];
943 	ddr83xx_t		ddr_secondary;	/* Secondary DDR Memory Controller Memory Map */
944 	u8			res9[0x22000];
945 	security83xx_t		security;
946 	u8			res10[0xC0000];
947 	u8			qe[0x100000];	/* QE block */
948 } immap_t;
949 
950 #elif defined(CONFIG_MPC832x)
951 typedef struct immap {
952 	sysconf83xx_t		sysconf;	/* System configuration */
953 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
954 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
955 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
956 	gtm83xx_t		gtm[2];		/* Global Timers Module */
957 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
958 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
959 	reset83xx_t		reset;		/* Reset Module */
960 	clk83xx_t		clk;		/* System Clock Module */
961 	pmc83xx_t		pmc;		/* Power Management Control Module */
962 	qepi83xx_t		qepi;		/* QE Ports Interrupts Registers */
963 	u8			res0[0x300];
964 	u8			dll_ddr[0x100];
965 	u8			dll_lbc[0x100];
966 	u8			res1[0x200];
967 	qepio83xx_t		qepio;		/* QE Parallel I/O ports */
968 	u8			res2[0x800];
969 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
970 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
971 	u8			res3[0x1300];
972 	duart83xx_t		duart[2];	/* DUART */
973 	u8			res4[0x900];
974 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
975 	u8			res5[0x2000];
976 	dma83xx_t		dma;		/* DMA */
977 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
978 	u8			res6[128];
979 	ios83xx_t		ios;		/* Sequencer (IOS) */
980 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
981 	u8			res7[0x27A00];
982 	security83xx_t		security;
983 	u8			res8[0xC0000];
984 	u8			qe[0x100000];	/* QE block */
985 } immap_t;
986 #elif defined(CONFIG_MPC8309)
987 typedef struct immap {
988 	sysconf83xx_t		sysconf;	/* System configuration */
989 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
990 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
991 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
992 	gtm83xx_t		gtm[2];		/* Global Timers Module */
993 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
994 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
995 	reset83xx_t		reset;		/* Reset Module */
996 	clk83xx_t		clk;		/* System Clock Module */
997 	pmc83xx_t		pmc;		/* Power Management Control Module */
998 	gpio83xx_t		gpio[2];	/* General purpose I/O module */
999 	u8			res0[0x500];	/* res0 1.25 KBytes added for 8309 */
1000 	qepi83xx_t		qepi;		/* QE Ports Interrupts Registers */
1001 	qepio83xx_t		qepio;		/* QE Parallel I/O ports */
1002 	u8			res1[0x800];
1003 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
1004 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
1005 	u8			res2[0x1300];
1006 	duart83xx_t		duart[2];	/* DUART */
1007 	u8			res3[0x200];
1008 	duart83xx_t		duart1[2];	/* DUART */
1009 	u8			res4[0x500];
1010 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
1011 	u8			res5[0x1000];
1012 	u8			spi[0x100];
1013 	u8			res6[0xf00];
1014 	dma83xx_t		dma;		/* DMA */
1015 	pciconf83xx_t		pci_conf[1];	/* PCI Configuration Registers */
1016 	u8			res7[0x80];
1017 	ios83xx_t		ios;		/* Sequencer (IOS) */
1018 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Control & Status Registers */
1019 	u8			res8[0x13A00];
1020 	u8			can1[0x1000];	/* Flexcan 1 */
1021 	u8			can2[0x1000];	/* Flexcan 2 */
1022 	u8			res9[0x5000];
1023 	usb83xx_t		usb;
1024 	u8			res10[0x5000];
1025 	u8			can3[0x1000];	/* Flexcan 3 */
1026 	u8			can4[0x1000];	/* Flexcan 4 */
1027 	u8			res11[0x1000];
1028 	u8			dma1[0x2000];	/* DMA */
1029 	sdhc83xx_t		sdhc;		/* SDHC Controller */
1030 	u8			res12[0xC1000];
1031 	rom83xx_t		rom;		/* On Chip ROM */
1032 	u8			res13[0x8000];
1033 	u8			qe[0x100000];	/* QE block */
1034 	u8			res14[0xE00000];/* Added for 8309 */
1035 } immap_t;
1036 #endif
1037 
1038 #define CONFIG_SYS_MPC8xxx_DDR_OFFSET	(0x2000)
1039 #define CONFIG_SYS_MPC8xxx_DDR_ADDR \
1040 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC8xxx_DDR_OFFSET)
1041 #define CONFIG_SYS_MPC83xx_DMA_OFFSET	(0x8000)
1042 #define CONFIG_SYS_MPC83xx_DMA_ADDR \
1043 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_DMA_OFFSET)
1044 #define CONFIG_SYS_MPC83xx_ESDHC_OFFSET	(0x2e000)
1045 #define CONFIG_SYS_MPC83xx_ESDHC_ADDR \
1046 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_ESDHC_OFFSET)
1047 
1048 #ifndef CONFIG_SYS_MPC83xx_USB_OFFSET
1049 #define CONFIG_SYS_MPC83xx_USB_OFFSET  0x23000
1050 #endif
1051 #define CONFIG_SYS_MPC83xx_USB_ADDR \
1052 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_USB_OFFSET)
1053 #define CONFIG_SYS_LBC_ADDR (&((immap_t *)CONFIG_SYS_IMMR)->im_lbc)
1054 
1055 #define CONFIG_SYS_TSEC1_OFFSET		0x24000
1056 #define CONFIG_SYS_MDIO1_OFFSET		0x24000
1057 
1058 #define TSEC_BASE_ADDR		(CONFIG_SYS_IMMR + CONFIG_SYS_TSEC1_OFFSET)
1059 #define MDIO_BASE_ADDR		(CONFIG_SYS_IMMR + CONFIG_SYS_MDIO1_OFFSET)
1060 #endif				/* __IMMAP_83xx__ */
1061