mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	The Integrated Flash Controller (IFC) is used to access the external
NAND Flash, NOR Flash, EPROM, SRAM and Generic ASIC memories.Four chip
selects are provided in IFC so that maximum of four Flash devices can be
hooked, but only one can be accessed at a given time.
Features supported by IFC are,
        - Functional muxing of pins between NAND, NOR and GPCM
        - Support memory banks of size 64KByte to 4 GBytes
        - Write protection capability (only for NAND and NOR)
        - Provision of Software Reset
        - Flexible Timing programmability for every chip select
        - NAND Machine
                - x8/ x16 NAND Flash Interface
                - SLC and MLC NAND Flash devices support with
                  configurable
                  page sizes of upto 4KB
                - Internal SRAM of 9KB which is directly mapped and
                  availble at
                  boot time for NAND Boot
                - Configurable block size
                - Boot chip select (CS0) available at system reset
        - NOR Machine
                - Data bus width of 8/16/32
                - Compatible with asynchronous NOR Flash
                - Directly memory mapped
                - Supports address data multiplexed (ADM) NOR device
                - Boot chip select (CS0) available at system reset
        - GPCM Machine (NORMAL GPCM Mode)
                - Support for x8/16/32 bit device
                - Compatible with general purpose addressable device
                  e.g. SRAM, ROM
                - External clock is supported with programmable division
                  ratio
        - GPCM Machine (Generic ASIC Mode)
                - Support for x8/16/32 bit device
                - Address and Data are shared on I/O bus
                - Following Address and Data sequences can be supported
                  on I/O bus
                       - 32 bit I/O: AD
                       - 16 bit I/O: AADD
                       - 8 bit I/O : AAAADDDD
                - Configurable Even/Odd Parity on Address/Data bus
                  supported
Signed-off-by: Dipen Dudhat <Dipen.Dudhat@freescale.com>
Acked-by: Scott Wood <scottwood@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
		
	
			
		
			
				
	
	
		
			87 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2009-2011 Freescale Semiconductor, Inc.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License as
 | |
|  * published by the Free Software Foundation; either version 2 of
 | |
|  * the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 | |
|  * MA 02111-1307 USA
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef _ASM_CONFIG_H_
 | |
| #define _ASM_CONFIG_H_
 | |
| 
 | |
| #ifdef CONFIG_MPC85xx
 | |
| #include <asm/config_mpc85xx.h>
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MPC86xx
 | |
| #include <asm/config_mpc86xx.h>
 | |
| #endif
 | |
| 
 | |
| #define CONFIG_LMB
 | |
| #define CONFIG_SYS_BOOT_RAMDISK_HIGH
 | |
| #define CONFIG_SYS_BOOT_GET_CMDLINE
 | |
| #define CONFIG_SYS_BOOT_GET_KBD
 | |
| 
 | |
| #ifndef CONFIG_MAX_MEM_MAPPED
 | |
| #if defined(CONFIG_4xx) || defined(CONFIG_E500) || defined(CONFIG_MPC86xx)
 | |
| #define CONFIG_MAX_MEM_MAPPED	((phys_size_t)2 << 30)
 | |
| #else
 | |
| #define CONFIG_MAX_MEM_MAPPED	(256 << 20)
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| /* Check if boards need to enable FSL DMA engine for SDRAM init */
 | |
| #if !defined(CONFIG_FSL_DMA) && defined(CONFIG_DDR_ECC)
 | |
| #if (defined(CONFIG_MPC83xx) && defined(CONFIG_DDR_ECC_INIT_VIA_DMA)) || \
 | |
| 	((defined(CONFIG_MPC85xx) || defined(CONFIG_MPC86xx)) && \
 | |
| 	!defined(CONFIG_ECC_INIT_VIA_DDRCONTROLLER))
 | |
| #define CONFIG_FSL_DMA
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| #ifndef CONFIG_MAX_CPUS
 | |
| #define CONFIG_MAX_CPUS		1
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * Provide a default boot page translation virtual address that lines up with
 | |
|  * Freescale's default e500 reset page.
 | |
|  */
 | |
| #if (defined(CONFIG_E500) && defined(CONFIG_MP))
 | |
| #ifndef CONFIG_BPTR_VIRT_ADDR
 | |
| #define CONFIG_BPTR_VIRT_ADDR	0xfffff000
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * SEC (crypto unit) major compatible version determination
 | |
|  */
 | |
| #if defined(CONFIG_MPC83xx)
 | |
| #define CONFIG_SYS_FSL_SEC_COMPAT	2
 | |
| #endif
 | |
| 
 | |
| /* Since so many PPC SOCs have a semi-common LBC, define this here */
 | |
| #if defined(CONFIG_MPC85xx) || defined(CONFIG_MPC86xx) || \
 | |
| 	defined(CONFIG_MPC83xx)
 | |
| #if !defined(CONFIG_FSL_IFC)
 | |
| #define CONFIG_FSL_LBC
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| /* All PPC boards must swap IDE bytes */
 | |
| #define CONFIG_IDE_SWAP_IO
 | |
| 
 | |
| #endif /* _ASM_CONFIG_H_ */
 |