mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 14:01:50 +01:00 
			
		
		
		
	The MPC8308 has two I2C controllers, but no PCI controller. Fix the register map layout for this SoC. Signed-off-by: Mario Six <mario.six@gdsys.cc>
		
			
				
	
	
		
			997 lines
		
	
	
		
			29 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			997 lines
		
	
	
		
			29 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Copyright 2004-2011 Freescale Semiconductor, Inc.
 | |
|  *
 | |
|  * MPC83xx Internal Memory Map
 | |
|  *
 | |
|  * Contributors:
 | |
|  *	Dave Liu <daveliu@freescale.com>
 | |
|  *	Tanya Jiang <tanya.jiang@freescale.com>
 | |
|  *	Mandy Lavi <mandy.lavi@freescale.com>
 | |
|  *	Eran Liberty <liberty@freescale.com>
 | |
|  */
 | |
| #ifndef __IMMAP_83xx__
 | |
| #define __IMMAP_83xx__
 | |
| 
 | |
| #include <fsl_immap.h>
 | |
| #include <asm/types.h>
 | |
| #include <asm/fsl_i2c.h>
 | |
| #include <asm/mpc8xxx_spi.h>
 | |
| #include <asm/fsl_lbc.h>
 | |
| #include <asm/fsl_dma.h>
 | |
| 
 | |
| /*
 | |
|  * Local Access Window
 | |
|  */
 | |
| typedef struct law83xx {
 | |
| 	u32 bar;		/* LBIU local access window base address register */
 | |
| 	u32 ar;			/* LBIU local access window attribute register */
 | |
| } law83xx_t;
 | |
| 
 | |
| /*
 | |
|  * System configuration registers
 | |
|  */
 | |
| typedef struct sysconf83xx {
 | |
| 	u32 immrbar;		/* Internal memory map base address register */
 | |
| 	u8 res0[0x04];
 | |
| 	u32 altcbar;		/* Alternate configuration base address register */
 | |
| 	u8 res1[0x14];
 | |
| 	law83xx_t lblaw[4];	/* LBIU local access window */
 | |
| 	u8 res2[0x20];
 | |
| 	law83xx_t pcilaw[2];	/* PCI local access window */
 | |
| 	u8 res3[0x10];
 | |
| 	law83xx_t pcielaw[2];	/* PCI Express local access window */
 | |
| 	u8 res4[0x10];
 | |
| 	law83xx_t ddrlaw[2];	/* DDR local access window */
 | |
| 	u8 res5[0x50];
 | |
| 	u32 sgprl;		/* System General Purpose Register Low */
 | |
| 	u32 sgprh;		/* System General Purpose Register High */
 | |
| 	u32 spridr;		/* System Part and Revision ID Register */
 | |
| 	u8 res6[0x04];
 | |
| 	u32 spcr;		/* System Priority Configuration Register */
 | |
| 	u32 sicrl;		/* System I/O Configuration Register Low */
 | |
| 	u32 sicrh;		/* System I/O Configuration Register High */
 | |
| 	u8 res7[0x04];
 | |
| 	u32 sidcr0;		/* System I/O Delay Configuration Register 0 */
 | |
| 	u32 sidcr1;		/* System I/O Delay Configuration Register 1 */
 | |
| 	u32 ddrcdr;		/* DDR Control Driver Register */
 | |
| 	u32 ddrdsr;		/* DDR Debug Status Register */
 | |
| 	u32 obir;		/* Output Buffer Impedance Register */
 | |
| 	u8 res8[0xC];
 | |
| 	u32 pecr1;		/* PCI Express control register 1 */
 | |
| #if defined(CONFIG_ARCH_MPC830X)
 | |
| 	u32 sdhccr;		/* eSDHC Control Registers for MPC830x */
 | |
| #else
 | |
| 	u32 pecr2;		/* PCI Express control register 2 */
 | |
| #endif
 | |
| #if defined(CONFIG_ARCH_MPC8309)
 | |
| 	u32 can_dbg_ctrl;
 | |
| 	u32 res9a;
 | |
| 	u32 gpr1;
 | |
| 	u8 res9b[0xAC];
 | |
| #else
 | |
| 	u8 res9[0xB8];
 | |
| #endif
 | |
| } sysconf83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Watch Dog Timer (WDT) Registers
 | |
|  */
 | |
| typedef struct wdt83xx {
 | |
| 	u8 res0[4];
 | |
| 	u32 swcrr;		/* System watchdog control register */
 | |
| 	u32 swcnr;		/* System watchdog count register */
 | |
| 	u8 res1[2];
 | |
| 	u16 swsrr;		/* System watchdog service register */
 | |
| 	u8 res2[0xF0];
 | |
| } wdt83xx_t;
 | |
| 
 | |
| /*
 | |
|  * RTC/PIT Module Registers
 | |
|  */
 | |
| typedef struct rtclk83xx {
 | |
| 	u32 cnr;		/* control register */
 | |
| 	u32 ldr;		/* load register */
 | |
| 	u32 psr;		/* prescale register */
 | |
| 	u32 ctr;		/* counter value field register */
 | |
| 	u32 evr;		/* event register */
 | |
| 	u32 alr;		/* alarm register */
 | |
| 	u8 res0[0xE8];
 | |
| } rtclk83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Global timer module
 | |
|  */
 | |
| typedef struct gtm83xx {
 | |
| 	u8 cfr1;		/* Timer1/2 Configuration */
 | |
| 	u8 res0[3];
 | |
| 	u8 cfr2;		/* Timer3/4 Configuration */
 | |
| 	u8 res1[11];
 | |
| 	u16 mdr1;		/* Timer1 Mode Register */
 | |
| 	u16 mdr2;		/* Timer2 Mode Register */
 | |
| 	u16 rfr1;		/* Timer1 Reference Register */
 | |
| 	u16 rfr2;		/* Timer2 Reference Register */
 | |
| 	u16 cpr1;		/* Timer1 Capture Register */
 | |
| 	u16 cpr2;		/* Timer2 Capture Register */
 | |
| 	u16 cnr1;		/* Timer1 Counter Register */
 | |
| 	u16 cnr2;		/* Timer2 Counter Register */
 | |
| 	u16 mdr3;		/* Timer3 Mode Register */
 | |
| 	u16 mdr4;		/* Timer4 Mode Register */
 | |
| 	u16 rfr3;		/* Timer3 Reference Register */
 | |
| 	u16 rfr4;		/* Timer4 Reference Register */
 | |
| 	u16 cpr3;		/* Timer3 Capture Register */
 | |
| 	u16 cpr4;		/* Timer4 Capture Register */
 | |
| 	u16 cnr3;		/* Timer3 Counter Register */
 | |
| 	u16 cnr4;		/* Timer4 Counter Register */
 | |
| 	u16 evr1;		/* Timer1 Event Register */
 | |
| 	u16 evr2;		/* Timer2 Event Register */
 | |
| 	u16 evr3;		/* Timer3 Event Register */
 | |
| 	u16 evr4;		/* Timer4 Event Register */
 | |
| 	u16 psr1;		/* Timer1 Prescaler Register */
 | |
| 	u16 psr2;		/* Timer2 Prescaler Register */
 | |
| 	u16 psr3;		/* Timer3 Prescaler Register */
 | |
| 	u16 psr4;		/* Timer4 Prescaler Register */
 | |
| 	u8 res[0xC0];
 | |
| } gtm83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Integrated Programmable Interrupt Controller
 | |
|  */
 | |
| typedef struct ipic83xx {
 | |
| 	u32 sicfr;		/* System Global Interrupt Configuration Register */
 | |
| 	u32 sivcr;		/* System Global Interrupt Vector Register */
 | |
| 	u32 sipnr_h;		/* System Internal Interrupt Pending Register - High */
 | |
| 	u32 sipnr_l;		/* System Internal Interrupt Pending Register - Low */
 | |
| 	u32 siprr_a;		/* System Internal Interrupt Group A Priority Register */
 | |
| 	u32 siprr_b;		/* System Internal Interrupt Group B Priority Register */
 | |
| 	u32 siprr_c;		/* System Internal Interrupt Group C Priority Register */
 | |
| 	u32 siprr_d;		/* System Internal Interrupt Group D Priority Register */
 | |
| 	u32 simsr_h;		/* System Internal Interrupt Mask Register - High */
 | |
| 	u32 simsr_l;		/* System Internal Interrupt Mask Register - Low */
 | |
| 	u32 sicnr;		/* System Internal Interrupt Control Register */
 | |
| 	u32 sepnr;		/* System External Interrupt Pending Register */
 | |
| 	u32 smprr_a;		/* System Mixed Interrupt Group A Priority Register */
 | |
| 	u32 smprr_b;		/* System Mixed Interrupt Group B Priority Register */
 | |
| 	u32 semsr;		/* System External Interrupt Mask Register */
 | |
| 	u32 secnr;		/* System External Interrupt Control Register */
 | |
| 	u32 sersr;		/* System Error Status Register */
 | |
| 	u32 sermr;		/* System Error Mask Register */
 | |
| 	u32 sercr;		/* System Error Control Register */
 | |
| 	u32 sepcr;		/* System External Interrupt Polarity Control Register */
 | |
| 	u32 sifcr_h;		/* System Internal Interrupt Force Register - High */
 | |
| 	u32 sifcr_l;		/* System Internal Interrupt Force Register - Low */
 | |
| 	u32 sefcr;		/* System External Interrupt Force Register */
 | |
| 	u32 serfr;		/* System Error Force Register */
 | |
| 	u32 scvcr;		/* System Critical Interrupt Vector Register */
 | |
| 	u32 smvcr;		/* System Management Interrupt Vector Register */
 | |
| 	u8 res[0x98];
 | |
| } ipic83xx_t;
 | |
| 
 | |
| /*
 | |
|  * System Arbiter Registers
 | |
|  */
 | |
| typedef struct arbiter83xx {
 | |
| 	u32 acr;		/* Arbiter Configuration Register */
 | |
| 	u32 atr;		/* Arbiter Timers Register */
 | |
| 	u8 res[4];
 | |
| 	u32 aer;		/* Arbiter Event Register */
 | |
| 	u32 aidr;		/* Arbiter Interrupt Definition Register */
 | |
| 	u32 amr;		/* Arbiter Mask Register */
 | |
| 	u32 aeatr;		/* Arbiter Event Attributes Register */
 | |
| 	u32 aeadr;		/* Arbiter Event Address Register */
 | |
| 	u32 aerr;		/* Arbiter Event Response Register */
 | |
| 	u8 res1[0xDC];
 | |
| } arbiter83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Reset Module
 | |
|  */
 | |
| typedef struct reset83xx {
 | |
| 	u32 rcwl;		/* Reset Configuration Word Low Register */
 | |
| 	u32 rcwh;		/* Reset Configuration Word High Register */
 | |
| 	u8 res0[8];
 | |
| 	u32 rsr;		/* Reset Status Register */
 | |
| 	u32 rmr;		/* Reset Mode Register */
 | |
| 	u32 rpr;		/* Reset protection Register */
 | |
| 	u32 rcr;		/* Reset Control Register */
 | |
| 	u32 rcer;		/* Reset Control Enable Register */
 | |
| 	u8 res1[0xDC];
 | |
| } reset83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Clock Module
 | |
|  */
 | |
| typedef struct clk83xx {
 | |
| 	u32 spmr;		/* system PLL mode Register */
 | |
| 	u32 occr;		/* output clock control Register */
 | |
| 	u32 sccr;		/* system clock control Register */
 | |
| 	u8 res0[0xF4];
 | |
| } clk83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Power Management Control Module
 | |
|  */
 | |
| typedef struct pmc83xx {
 | |
| 	u32 pmccr;		/* PMC Configuration Register */
 | |
| 	u32 pmcer;		/* PMC Event Register */
 | |
| 	u32 pmcmr;		/* PMC Mask Register */
 | |
| 	u32 pmccr1;		/* PMC Configuration Register 1 */
 | |
| 	u32 pmccr2;		/* PMC Configuration Register 2 */
 | |
| 	u8 res0[0xEC];
 | |
| } pmc83xx_t;
 | |
| 
 | |
| /*
 | |
|  * General purpose I/O module
 | |
|  */
 | |
| typedef struct gpio83xx {
 | |
| 	u32 dir;		/* direction register */
 | |
| 	u32 odr;		/* open drain register */
 | |
| 	u32 dat;		/* data register */
 | |
| 	u32 ier;		/* interrupt event register */
 | |
| 	u32 imr;		/* interrupt mask register */
 | |
| 	u32 icr;		/* external interrupt control register */
 | |
| 	u8 res0[0xE8];
 | |
| } gpio83xx_t;
 | |
| 
 | |
| /*
 | |
|  * QE Ports Interrupts Registers
 | |
|  */
 | |
| typedef struct qepi83xx {
 | |
| 	u8 res0[0xC];
 | |
| 	u32 qepier;		/* QE Ports Interrupt Event Register */
 | |
| 	u32 qepimr;		/* QE Ports Interrupt Mask Register */
 | |
| 	u32 qepicr;		/* QE Ports Interrupt Control Register */
 | |
| 	u8 res1[0xE8];
 | |
| } qepi83xx_t;
 | |
| 
 | |
| /*
 | |
|  * QE Parallel I/O Ports
 | |
|  */
 | |
| typedef struct gpio_n {
 | |
| 	u32 podr;		/* Open Drain Register */
 | |
| 	u32 pdat;		/* Data Register */
 | |
| 	u32 dir1;		/* direction register 1 */
 | |
| 	u32 dir2;		/* direction register 2 */
 | |
| 	u32 ppar1;		/* Pin Assignment Register 1 */
 | |
| 	u32 ppar2;		/* Pin Assignment Register 2 */
 | |
| } gpio_n_t;
 | |
| 
 | |
| typedef struct qegpio83xx {
 | |
| 	gpio_n_t ioport[0x7];
 | |
| 	u8 res0[0x358];
 | |
| } qepio83xx_t;
 | |
| 
 | |
| /*
 | |
|  * QE Secondary Bus Access Windows
 | |
|  */
 | |
| typedef struct qesba83xx {
 | |
| 	u32 lbmcsar;		/* Local bus memory controller start address */
 | |
| 	u32 sdmcsar;		/* Secondary DDR memory controller start address */
 | |
| 	u8 res0[0x38];
 | |
| 	u32 lbmcear;		/* Local bus memory controller end address */
 | |
| 	u32 sdmcear;		/* Secondary DDR memory controller end address */
 | |
| 	u8 res1[0x38];
 | |
| 	u32 lbmcar;		/* Local bus memory controller attributes */
 | |
| 	u32 sdmcar;		/* Secondary DDR memory controller attributes */
 | |
| 	u8 res2[0x378];
 | |
| } qesba83xx_t;
 | |
| 
 | |
| /*
 | |
|  * DDR Memory Controller Memory Map for DDR1
 | |
|  * The structure of DDR2, or DDR3 is defined in fsl_immap.h
 | |
|  */
 | |
| #if !defined(CONFIG_SYS_FSL_DDR2) && !defined(CONFIG_SYS_FSL_DDR3)
 | |
| typedef struct ddr_cs_bnds {
 | |
| 	u32 csbnds;
 | |
| 	u8 res0[4];
 | |
| } ddr_cs_bnds_t;
 | |
| 
 | |
| typedef struct ddr83xx {
 | |
| 	ddr_cs_bnds_t csbnds[4];/* Chip Select x Memory Bounds */
 | |
| 	u8 res0[0x60];
 | |
| 	u32 cs_config[4];	/* Chip Select x Configuration */
 | |
| 	u8 res1[0x70];
 | |
| 	u32 timing_cfg_3;	/* SDRAM Timing Configuration 3 */
 | |
| 	u32 timing_cfg_0;	/* SDRAM Timing Configuration 0 */
 | |
| 	u32 timing_cfg_1;	/* SDRAM Timing Configuration 1 */
 | |
| 	u32 timing_cfg_2;	/* SDRAM Timing Configuration 2 */
 | |
| 	u32 sdram_cfg;		/* SDRAM Control Configuration */
 | |
| 	u32 sdram_cfg2;		/* SDRAM Control Configuration 2 */
 | |
| 	u32 sdram_mode;		/* SDRAM Mode Configuration */
 | |
| 	u32 sdram_mode2;	/* SDRAM Mode Configuration 2 */
 | |
| 	u32 sdram_md_cntl;	/* SDRAM Mode Control */
 | |
| 	u32 sdram_interval;	/* SDRAM Interval Configuration */
 | |
| 	u32 ddr_data_init;	/* SDRAM Data Initialization */
 | |
| 	u8 res2[4];
 | |
| 	u32 sdram_clk_cntl;	/* SDRAM Clock Control */
 | |
| 	u8 res3[0x14];
 | |
| 	u32 ddr_init_addr;	/* DDR training initialization address */
 | |
| 	u32 ddr_init_ext_addr;	/* DDR training initialization extended address */
 | |
| 	u8 res4[0xAA8];
 | |
| 	u32 ddr_ip_rev1;	/* DDR IP block revision 1 */
 | |
| 	u32 ddr_ip_rev2;	/* DDR IP block revision 2 */
 | |
| 	u8 res5[0x200];
 | |
| 	u32 data_err_inject_hi;	/* Memory Data Path Error Injection Mask High */
 | |
| 	u32 data_err_inject_lo;	/* Memory Data Path Error Injection Mask Low */
 | |
| 	u32 ecc_err_inject;	/* Memory Data Path Error Injection Mask ECC */
 | |
| 	u8 res6[0x14];
 | |
| 	u32 capture_data_hi;	/* Memory Data Path Read Capture High */
 | |
| 	u32 capture_data_lo;	/* Memory Data Path Read Capture Low */
 | |
| 	u32 capture_ecc;	/* Memory Data Path Read Capture ECC */
 | |
| 	u8 res7[0x14];
 | |
| 	u32 err_detect;		/* Memory Error Detect */
 | |
| 	u32 err_disable;	/* Memory Error Disable */
 | |
| 	u32 err_int_en;		/* Memory Error Interrupt Enable */
 | |
| 	u32 capture_attributes;	/* Memory Error Attributes Capture */
 | |
| 	u32 capture_address;	/* Memory Error Address Capture */
 | |
| 	u32 capture_ext_address;/* Memory Error Extended Address Capture */
 | |
| 	u32 err_sbe;		/* Memory Single-Bit ECC Error Management */
 | |
| 	u8 res8[0xA4];
 | |
| 	u32 debug_reg;
 | |
| 	u8 res9[0xFC];
 | |
| } ddr83xx_t;
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * DUART
 | |
|  */
 | |
| typedef struct duart83xx {
 | |
| 	u8 urbr_ulcr_udlb;	/* combined register for URBR, UTHR and UDLB */
 | |
| 	u8 uier_udmb;		/* combined register for UIER and UDMB */
 | |
| 	u8 uiir_ufcr_uafr;	/* combined register for UIIR, UFCR and UAFR */
 | |
| 	u8 ulcr;		/* line control register */
 | |
| 	u8 umcr;		/* MODEM control register */
 | |
| 	u8 ulsr;		/* line status register */
 | |
| 	u8 umsr;		/* MODEM status register */
 | |
| 	u8 uscr;		/* scratch register */
 | |
| 	u8 res0[8];
 | |
| 	u8 udsr;		/* DMA status register */
 | |
| 	u8 res1[3];
 | |
| 	u8 res2[0xEC];
 | |
| } duart83xx_t;
 | |
| 
 | |
| /*
 | |
|  * DMA/Messaging Unit
 | |
|  */
 | |
| typedef struct dma83xx {
 | |
| 	u32 res0[0xC];		/* 0x0-0x29 reseverd */
 | |
| 	u32 omisr;		/* 0x30 Outbound message interrupt status register */
 | |
| 	u32 omimr;		/* 0x34 Outbound message interrupt mask register */
 | |
| 	u32 res1[0x6];		/* 0x38-0x49 reserved */
 | |
| 	u32 imr0;		/* 0x50 Inbound message register 0 */
 | |
| 	u32 imr1;		/* 0x54 Inbound message register 1 */
 | |
| 	u32 omr0;		/* 0x58 Outbound message register 0 */
 | |
| 	u32 omr1;		/* 0x5C Outbound message register 1 */
 | |
| 	u32 odr;		/* 0x60 Outbound doorbell register */
 | |
| 	u32 res2;		/* 0x64-0x67 reserved */
 | |
| 	u32 idr;		/* 0x68 Inbound doorbell register */
 | |
| 	u32 res3[0x5];		/* 0x6C-0x79 reserved */
 | |
| 	u32 imisr;		/* 0x80 Inbound message interrupt status register */
 | |
| 	u32 imimr;		/* 0x84 Inbound message interrupt mask register */
 | |
| 	u32 res4[0x1E];		/* 0x88-0x99 reserved */
 | |
| 	struct fsl_dma dma[4];
 | |
| } dma83xx_t;
 | |
| 
 | |
| /*
 | |
|  * PCI Software Configuration Registers
 | |
|  */
 | |
| typedef struct pciconf83xx {
 | |
| 	u32 config_address;
 | |
| 	u32 config_data;
 | |
| 	u32 int_ack;
 | |
| 	u8 res[116];
 | |
| } pciconf83xx_t;
 | |
| 
 | |
| /*
 | |
|  * PCI Outbound Translation Register
 | |
|  */
 | |
| typedef struct pci_outbound_window {
 | |
| 	u32 potar;
 | |
| 	u8 res0[4];
 | |
| 	u32 pobar;
 | |
| 	u8 res1[4];
 | |
| 	u32 pocmr;
 | |
| 	u8 res2[4];
 | |
| } pot83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Sequencer
 | |
|  */
 | |
| typedef struct ios83xx {
 | |
| 	pot83xx_t pot[6];
 | |
| 	u8 res0[0x60];
 | |
| 	u32 pmcr;
 | |
| 	u8 res1[4];
 | |
| 	u32 dtcr;
 | |
| 	u8 res2[4];
 | |
| } ios83xx_t;
 | |
| 
 | |
| /*
 | |
|  * PCI Controller Control and Status Registers
 | |
|  */
 | |
| typedef struct pcictrl83xx {
 | |
| 	u32 esr;
 | |
| 	u32 ecdr;
 | |
| 	u32 eer;
 | |
| 	u32 eatcr;
 | |
| 	u32 eacr;
 | |
| 	u32 eeacr;
 | |
| 	u32 edlcr;
 | |
| 	u32 edhcr;
 | |
| 	u32 gcr;
 | |
| 	u32 ecr;
 | |
| 	u32 gsr;
 | |
| 	u8 res0[12];
 | |
| 	u32 pitar2;
 | |
| 	u8 res1[4];
 | |
| 	u32 pibar2;
 | |
| 	u32 piebar2;
 | |
| 	u32 piwar2;
 | |
| 	u8 res2[4];
 | |
| 	u32 pitar1;
 | |
| 	u8 res3[4];
 | |
| 	u32 pibar1;
 | |
| 	u32 piebar1;
 | |
| 	u32 piwar1;
 | |
| 	u8 res4[4];
 | |
| 	u32 pitar0;
 | |
| 	u8 res5[4];
 | |
| 	u32 pibar0;
 | |
| 	u8 res6[4];
 | |
| 	u32 piwar0;
 | |
| 	u8 res7[132];
 | |
| } pcictrl83xx_t;
 | |
| 
 | |
| /*
 | |
|  * USB
 | |
|  */
 | |
| typedef struct usb83xx {
 | |
| 	u8 fixme[0x1000];
 | |
| } usb83xx_t;
 | |
| 
 | |
| /*
 | |
|  * TSEC
 | |
|  */
 | |
| typedef struct tsec83xx {
 | |
| 	u8 fixme[0x1000];
 | |
| } tsec83xx_t;
 | |
| 
 | |
| /*
 | |
|  * Security
 | |
|  */
 | |
| typedef struct security83xx {
 | |
| 	u8 fixme[0x10000];
 | |
| } security83xx_t;
 | |
| 
 | |
| /*
 | |
|  *  PCI Express
 | |
|  */
 | |
| struct pex_inbound_window {
 | |
| 	u32 ar;
 | |
| 	u32 tar;
 | |
| 	u32 barl;
 | |
| 	u32 barh;
 | |
| };
 | |
| 
 | |
| struct pex_outbound_window {
 | |
| 	u32 ar;
 | |
| 	u32 bar;
 | |
| 	u32 tarl;
 | |
| 	u32 tarh;
 | |
| };
 | |
| 
 | |
| struct pex_csb_bridge {
 | |
| 	u32 pex_csb_ver;
 | |
| 	u32 pex_csb_cab;
 | |
| 	u32 pex_csb_ctrl;
 | |
| 	u8 res0[8];
 | |
| 	u32 pex_dms_dstmr;
 | |
| 	u8 res1[4];
 | |
| 	u32 pex_cbs_stat;
 | |
| 	u8 res2[0x20];
 | |
| 	u32 pex_csb_obctrl;
 | |
| 	u32 pex_csb_obstat;
 | |
| 	u8 res3[0x98];
 | |
| 	u32 pex_csb_ibctrl;
 | |
| 	u32 pex_csb_ibstat;
 | |
| 	u8 res4[0xb8];
 | |
| 	u32 pex_wdma_ctrl;
 | |
| 	u32 pex_wdma_addr;
 | |
| 	u32 pex_wdma_stat;
 | |
| 	u8 res5[0x94];
 | |
| 	u32 pex_rdma_ctrl;
 | |
| 	u32 pex_rdma_addr;
 | |
| 	u32 pex_rdma_stat;
 | |
| 	u8 res6[0xd4];
 | |
| 	u32 pex_ombcr;
 | |
| 	u32 pex_ombdr;
 | |
| 	u8 res7[0x38];
 | |
| 	u32 pex_imbcr;
 | |
| 	u32 pex_imbdr;
 | |
| 	u8 res8[0x38];
 | |
| 	u32 pex_int_enb;
 | |
| 	u32 pex_int_stat;
 | |
| 	u32 pex_int_apio_vec1;
 | |
| 	u32 pex_int_apio_vec2;
 | |
| 	u8 res9[0x10];
 | |
| 	u32 pex_int_ppio_vec1;
 | |
| 	u32 pex_int_ppio_vec2;
 | |
| 	u32 pex_int_wdma_vec1;
 | |
| 	u32 pex_int_wdma_vec2;
 | |
| 	u32 pex_int_rdma_vec1;
 | |
| 	u32 pex_int_rdma_vec2;
 | |
| 	u32 pex_int_misc_vec;
 | |
| 	u8 res10[4];
 | |
| 	u32 pex_int_axi_pio_enb;
 | |
| 	u32 pex_int_axi_wdma_enb;
 | |
| 	u32 pex_int_axi_rdma_enb;
 | |
| 	u32 pex_int_axi_misc_enb;
 | |
| 	u32 pex_int_axi_pio_stat;
 | |
| 	u32 pex_int_axi_wdma_stat;
 | |
| 	u32 pex_int_axi_rdma_stat;
 | |
| 	u32 pex_int_axi_misc_stat;
 | |
| 	u8 res11[0xa0];
 | |
| 	struct pex_outbound_window pex_outbound_win[4];
 | |
| 	u8 res12[0x100];
 | |
| 	u32 pex_epiwtar0;
 | |
| 	u32 pex_epiwtar1;
 | |
| 	u32 pex_epiwtar2;
 | |
| 	u32 pex_epiwtar3;
 | |
| 	u8 res13[0x70];
 | |
| 	struct pex_inbound_window pex_inbound_win[4];
 | |
| };
 | |
| 
 | |
| typedef struct pex83xx {
 | |
| 	u8 pex_cfg_header[0x404];
 | |
| 	u32 pex_ltssm_stat;
 | |
| 	u8 res0[0x30];
 | |
| 	u32 pex_ack_replay_timeout;
 | |
| 	u8 res1[4];
 | |
| 	u32 pex_gclk_ratio;
 | |
| 	u8 res2[0xc];
 | |
| 	u32 pex_pm_timer;
 | |
| 	u32 pex_pme_timeout;
 | |
| 	u8 res3[4];
 | |
| 	u32 pex_aspm_req_timer;
 | |
| 	u8 res4[0x18];
 | |
| 	u32 pex_ssvid_update;
 | |
| 	u8 res5[0x34];
 | |
| 	u32 pex_cfg_ready;
 | |
| 	u8 res6[0x24];
 | |
| 	u32 pex_bar_sizel;
 | |
| 	u8 res7[4];
 | |
| 	u32 pex_bar_sel;
 | |
| 	u8 res8[0x20];
 | |
| 	u32 pex_bar_pf;
 | |
| 	u8 res9[0x88];
 | |
| 	u32 pex_pme_to_ack_tor;
 | |
| 	u8 res10[0xc];
 | |
| 	u32 pex_ss_intr_mask;
 | |
| 	u8 res11[0x25c];
 | |
| 	struct pex_csb_bridge bridge;
 | |
| 	u8 res12[0x160];
 | |
| } pex83xx_t;
 | |
| 
 | |
| /*
 | |
|  * SATA
 | |
|  */
 | |
| typedef struct sata83xx {
 | |
| 	u8 fixme[0x1000];
 | |
| } sata83xx_t;
 | |
| 
 | |
| /*
 | |
|  * eSDHC
 | |
|  */
 | |
| typedef struct sdhc83xx {
 | |
| 	u8 fixme[0x1000];
 | |
| } sdhc83xx_t;
 | |
| 
 | |
| /*
 | |
|  * SerDes
 | |
|  */
 | |
| typedef struct serdes83xx {
 | |
| 	u32 srdscr0;
 | |
| 	u32 srdscr1;
 | |
| 	u32 srdscr2;
 | |
| 	u32 srdscr3;
 | |
| 	u32 srdscr4;
 | |
| 	u8 res0[0xc];
 | |
| 	u32 srdsrstctl;
 | |
| 	u8 res1[0xdc];
 | |
| } serdes83xx_t;
 | |
| 
 | |
| /*
 | |
|  * On Chip ROM
 | |
|  */
 | |
| typedef struct rom83xx {
 | |
| #if defined(CONFIG_ARCH_MPC8309)
 | |
| 	u8 mem[0x8000];
 | |
| #else
 | |
| 	u8 mem[0x10000];
 | |
| #endif
 | |
| } rom83xx_t;
 | |
| 
 | |
| /*
 | |
|  * TDM
 | |
|  */
 | |
| typedef struct tdm83xx {
 | |
| 	u8 fixme[0x200];
 | |
| } tdm83xx_t;
 | |
| 
 | |
| /*
 | |
|  * TDM DMAC
 | |
|  */
 | |
| typedef struct tdmdmac83xx {
 | |
| 	u8 fixme[0x2000];
 | |
| } tdmdmac83xx_t;
 | |
| 
 | |
| #if defined(CONFIG_ARCH_MPC834X)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[2];		/* Global Timers Module */
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	gpio83xx_t		gpio[2];	/* General purpose I/O module */
 | |
| 	u8			res0[0x200];
 | |
| 	u8			dll_ddr[0x100];
 | |
| 	u8			dll_lbc[0x100];
 | |
| 	u8			res1[0xE00];
 | |
| #if defined(CONFIG_SYS_FSL_DDR2) || defined(CONFIG_SYS_FSL_DDR3)
 | |
| 	struct ccsr_ddr		ddr;	/* DDR Memory Controller Memory */
 | |
| #else
 | |
| 	ddr83xx_t		ddr;	/* DDR Memory Controller Memory */
 | |
| #endif
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res2[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res3[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res4[0x1000];
 | |
| 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[2];	/* PCI Software Configuration Registers */
 | |
| 	ios83xx_t		ios;		/* Sequencer */
 | |
| 	pcictrl83xx_t		pci_ctrl[2];	/* PCI Controller Control and Status Registers */
 | |
| 	u8			res5[0x19900];
 | |
| 	usb83xx_t		usb[2];
 | |
| 	tsec83xx_t		tsec[2];
 | |
| 	u8			res6[0xA000];
 | |
| 	security83xx_t		security;
 | |
| 	u8			res7[0xC0000];
 | |
| } immap_t;
 | |
| 
 | |
| #ifndef	CONFIG_ARCH_MPC834X
 | |
| #ifdef CONFIG_HAS_FSL_MPH_USB
 | |
| #define CONFIG_SYS_MPC83xx_USB1_OFFSET  0x22000	/* use the MPH controller */
 | |
| #define CONFIG_SYS_MPC83xx_USB2_OFFSET	0
 | |
| #else
 | |
| #define CONFIG_SYS_MPC83xx_USB1_OFFSET	0
 | |
| #define CONFIG_SYS_MPC83xx_USB2_OFFSET  0x23000	/* use the DR controller */
 | |
| #endif
 | |
| #else
 | |
| #define CONFIG_SYS_MPC83xx_USB1_OFFSET	0x22000
 | |
| #define CONFIG_SYS_MPC83xx_USB2_OFFSET  0x23000
 | |
| #endif
 | |
| 
 | |
| #elif defined(CONFIG_ARCH_MPC8313)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[2];		/* Global Timers Module */
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	gpio83xx_t		gpio[1];	/* General purpose I/O module */
 | |
| 	u8			res0[0x1300];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res1[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res2[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res3[0x1000];
 | |
| 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
 | |
| 	u8			res4[0x80];
 | |
| 	ios83xx_t		ios;		/* Sequencer */
 | |
| 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
 | |
| 	u8			res5[0x1aa00];
 | |
| 	usb83xx_t		usb[1];
 | |
| 	tsec83xx_t		tsec[2];
 | |
| 	u8			res6[0xA000];
 | |
| 	security83xx_t		security;
 | |
| 	u8			res7[0xC0000];
 | |
| } immap_t;
 | |
| 
 | |
| #elif defined(CONFIG_ARCH_MPC8315)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[2];		/* Global Timers Module */
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	gpio83xx_t		gpio[1];	/* General purpose I/O module */
 | |
| 	u8			res0[0x1300];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[1];		/* I2C Controllers */
 | |
| 	u8			res1[0x1400];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res2[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res3[0x1000];
 | |
| 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
 | |
| 	u8			res4[0x80];
 | |
| 	ios83xx_t		ios;		/* Sequencer */
 | |
| 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
 | |
| 	u8			res5[0xa00];
 | |
| 	pex83xx_t		pciexp[2];	/* PCI Express Controller */
 | |
| 	u8			res6[0xb000];
 | |
| 	tdm83xx_t		tdm;		/* TDM Controller */
 | |
| 	u8			res7[0x1e00];
 | |
| 	sata83xx_t		sata[2];	/* SATA Controller */
 | |
| 	u8			res8[0x9000];
 | |
| 	usb83xx_t		usb[1];		/* USB DR Controller */
 | |
| 	tsec83xx_t		tsec[2];
 | |
| 	u8			res9[0x6000];
 | |
| 	tdmdmac83xx_t		tdmdmac;	/* TDM DMAC */
 | |
| 	u8			res10[0x2000];
 | |
| 	security83xx_t		security;
 | |
| 	u8			res11[0xA3000];
 | |
| 	serdes83xx_t		serdes[1];	/* SerDes Registers */
 | |
| 	u8			res12[0x1CF00];
 | |
| } immap_t;
 | |
| 
 | |
| #elif defined(CONFIG_ARCH_MPC8308)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[1];		/* Global Timers Module */
 | |
| 	u8			res0[0x100];
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	gpio83xx_t		gpio[1];	/* General purpose I/O module */
 | |
| 	u8			res1[0x1300];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res2[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res3[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res4[0x1000];
 | |
| 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
 | |
| 	u8			res5[0x1000];
 | |
| 	pex83xx_t		pciexp[1];	/* PCI Express Controller */
 | |
| 	u8			res6[0x19000];
 | |
| 	usb83xx_t		usb[1];		/* USB DR Controller */
 | |
| 	tsec83xx_t		tsec[2];
 | |
| 	u8			res7[0x6000];
 | |
| 	tdmdmac83xx_t		tdmdmac;	/* TDM DMAC */
 | |
| 	sdhc83xx_t		sdhc;		/* SDHC Controller */
 | |
| 	u8			res8[0xb4000];
 | |
| 	serdes83xx_t		serdes[1];	/* SerDes Registers */
 | |
| 	u8			res9[0x1CF00];
 | |
| } immap_t;
 | |
| 
 | |
| #elif defined(CONFIG_ARCH_MPC837X)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[2];		/* Global Timers Module */
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	gpio83xx_t		gpio[2];	/* General purpose I/O module */
 | |
| 	u8			res0[0x1200];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res1[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res2[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res3[0x1000];
 | |
| 	spi8xxx_t		spi;		/* Serial Peripheral Interface */
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
 | |
| 	u8			res4[0x80];
 | |
| 	ios83xx_t		ios;		/* Sequencer */
 | |
| 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
 | |
| 	u8			res5[0xa00];
 | |
| 	pex83xx_t		pciexp[2];	/* PCI Express Controller */
 | |
| 	u8			res6[0xd000];
 | |
| 	sata83xx_t		sata[4];	/* SATA Controller */
 | |
| 	u8			res7[0x7000];
 | |
| 	usb83xx_t		usb[1];		/* USB DR Controller */
 | |
| 	tsec83xx_t		tsec[2];
 | |
| 	u8			res8[0x8000];
 | |
| 	sdhc83xx_t		sdhc;		/* SDHC Controller */
 | |
| 	u8			res9[0x1000];
 | |
| 	security83xx_t		security;
 | |
| 	u8			res10[0xA3000];
 | |
| 	serdes83xx_t		serdes[2];	/* SerDes Registers */
 | |
| 	u8			res11[0xCE00];
 | |
| 	rom83xx_t		rom;		/* On Chip ROM */
 | |
| } immap_t;
 | |
| 
 | |
| #elif defined(CONFIG_ARCH_MPC8360)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	u8			res0[0x200];
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	qepi83xx_t		qepi;		/* QE Ports Interrupts Registers */
 | |
| 	u8			res1[0x300];
 | |
| 	u8			dll_ddr[0x100];
 | |
| 	u8			dll_lbc[0x100];
 | |
| 	u8			res2[0x200];
 | |
| 	qepio83xx_t		qepio;		/* QE Parallel I/O ports */
 | |
| 	qesba83xx_t		qesba;		/* QE Secondary Bus Access Windows */
 | |
| 	u8			res3[0x400];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res4[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res5[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res6[0x2000];
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
 | |
| 	u8			res7[128];
 | |
| 	ios83xx_t		ios;		/* Sequencer (IOS) */
 | |
| 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
 | |
| 	u8			res8[0x4A00];
 | |
| 	ddr83xx_t		ddr_secondary;	/* Secondary DDR Memory Controller Memory Map */
 | |
| 	u8			res9[0x22000];
 | |
| 	security83xx_t		security;
 | |
| 	u8			res10[0xC0000];
 | |
| 	u8			qe[0x100000];	/* QE block */
 | |
| } immap_t;
 | |
| 
 | |
| #elif defined(CONFIG_ARCH_MPC832X)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[2];		/* Global Timers Module */
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	qepi83xx_t		qepi;		/* QE Ports Interrupts Registers */
 | |
| 	u8			res0[0x300];
 | |
| 	u8			dll_ddr[0x100];
 | |
| 	u8			dll_lbc[0x100];
 | |
| 	u8			res1[0x200];
 | |
| 	qepio83xx_t		qepio;		/* QE Parallel I/O ports */
 | |
| 	u8			res2[0x800];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res3[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res4[0x900];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res5[0x2000];
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[1];	/* PCI Software Configuration Registers */
 | |
| 	u8			res6[128];
 | |
| 	ios83xx_t		ios;		/* Sequencer (IOS) */
 | |
| 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Controller Control and Status Registers */
 | |
| 	u8			res7[0x27A00];
 | |
| 	security83xx_t		security;
 | |
| 	u8			res8[0xC0000];
 | |
| 	u8			qe[0x100000];	/* QE block */
 | |
| } immap_t;
 | |
| #elif defined(CONFIG_ARCH_MPC8309)
 | |
| typedef struct immap {
 | |
| 	sysconf83xx_t		sysconf;	/* System configuration */
 | |
| 	wdt83xx_t		wdt;		/* Watch Dog Timer (WDT) Registers */
 | |
| 	rtclk83xx_t		rtc;		/* Real Time Clock Module Registers */
 | |
| 	rtclk83xx_t		pit;		/* Periodic Interval Timer */
 | |
| 	gtm83xx_t		gtm[2];		/* Global Timers Module */
 | |
| 	ipic83xx_t		ipic;		/* Integrated Programmable Interrupt Controller */
 | |
| 	arbiter83xx_t		arbiter;	/* System Arbiter Registers */
 | |
| 	reset83xx_t		reset;		/* Reset Module */
 | |
| 	clk83xx_t		clk;		/* System Clock Module */
 | |
| 	pmc83xx_t		pmc;		/* Power Management Control Module */
 | |
| 	gpio83xx_t		gpio[2];	/* General purpose I/O module */
 | |
| 	u8			res0[0x500];	/* res0 1.25 KBytes added for 8309 */
 | |
| 	qepi83xx_t		qepi;		/* QE Ports Interrupts Registers */
 | |
| 	qepio83xx_t		qepio;		/* QE Parallel I/O ports */
 | |
| 	u8			res1[0x800];
 | |
| 	ddr83xx_t		ddr;		/* DDR Memory Controller Memory */
 | |
| 	fsl_i2c_t		i2c[2];		/* I2C Controllers */
 | |
| 	u8			res2[0x1300];
 | |
| 	duart83xx_t		duart[2];	/* DUART */
 | |
| 	u8			res3[0x200];
 | |
| 	duart83xx_t		duart1[2];	/* DUART */
 | |
| 	u8			res4[0x500];
 | |
| 	fsl_lbc_t		im_lbc;		/* Local Bus Controller Regs */
 | |
| 	u8			res5[0x1000];
 | |
| 	u8			spi[0x100];
 | |
| 	u8			res6[0xf00];
 | |
| 	dma83xx_t		dma;		/* DMA */
 | |
| 	pciconf83xx_t		pci_conf[1];	/* PCI Configuration Registers */
 | |
| 	u8			res7[0x80];
 | |
| 	ios83xx_t		ios;		/* Sequencer (IOS) */
 | |
| 	pcictrl83xx_t		pci_ctrl[1];	/* PCI Control & Status Registers */
 | |
| 	u8			res8[0x13A00];
 | |
| 	u8			can1[0x1000];	/* Flexcan 1 */
 | |
| 	u8			can2[0x1000];	/* Flexcan 2 */
 | |
| 	u8			res9[0x5000];
 | |
| 	usb83xx_t		usb;
 | |
| 	u8			res10[0x5000];
 | |
| 	u8			can3[0x1000];	/* Flexcan 3 */
 | |
| 	u8			can4[0x1000];	/* Flexcan 4 */
 | |
| 	u8			res11[0x1000];
 | |
| 	u8			dma1[0x2000];	/* DMA */
 | |
| 	sdhc83xx_t		sdhc;		/* SDHC Controller */
 | |
| 	u8			res12[0xC1000];
 | |
| 	rom83xx_t		rom;		/* On Chip ROM */
 | |
| 	u8			res13[0x8000];
 | |
| 	u8			qe[0x100000];	/* QE block */
 | |
| 	u8			res14[0xE00000];/* Added for 8309 */
 | |
| } immap_t;
 | |
| #endif
 | |
| 
 | |
| #define CONFIG_SYS_MPC8xxx_DDR_OFFSET	(0x2000)
 | |
| #define CONFIG_SYS_FSL_DDR_ADDR \
 | |
| 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC8xxx_DDR_OFFSET)
 | |
| #define CONFIG_SYS_MPC83xx_DMA_OFFSET	(0x8000)
 | |
| #define CONFIG_SYS_MPC83xx_DMA_ADDR \
 | |
| 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_DMA_OFFSET)
 | |
| #define CONFIG_SYS_MPC83xx_ESDHC_OFFSET	(0x2e000)
 | |
| #define CONFIG_SYS_MPC83xx_ESDHC_ADDR \
 | |
| 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_ESDHC_OFFSET)
 | |
| 
 | |
| #ifndef CONFIG_SYS_MPC83xx_USB1_OFFSET
 | |
| #define CONFIG_SYS_MPC83xx_USB1_OFFSET  0x23000
 | |
| #endif
 | |
| #define CONFIG_SYS_MPC83xx_USB1_ADDR \
 | |
| 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_USB1_OFFSET)
 | |
| #if defined(CONFIG_ARCH_MPC834X)
 | |
| #define CONFIG_SYS_MPC83xx_USB2_ADDR \
 | |
| 			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_USB2_OFFSET)
 | |
| #endif
 | |
| #define CONFIG_SYS_LBC_ADDR (&((immap_t *)CONFIG_SYS_IMMR)->im_lbc)
 | |
| 
 | |
| #define CONFIG_SYS_TSEC1_OFFSET		0x24000
 | |
| #define CONFIG_SYS_MDIO1_OFFSET		0x24000
 | |
| 
 | |
| #define TSEC_BASE_ADDR		(CONFIG_SYS_IMMR + CONFIG_SYS_TSEC1_OFFSET)
 | |
| #define MDIO_BASE_ADDR		(CONFIG_SYS_IMMR + CONFIG_SYS_MDIO1_OFFSET)
 | |
| #endif				/* __IMMAP_83xx__ */
 |