mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	* Patches by Robert Schwebel, 26 Jun 2003:
- logdl - csb226 - innokom * Patch by Pantelis Antoniou, 25 Jun 2003: update NetVia with V2 board support
This commit is contained in:
		
							parent
							
								
									b783edaee8
								
							
						
					
					
						commit
						993cad9364
					
				@ -2,6 +2,14 @@
 | 
				
			|||||||
Changes since U-Boot 0.3.1:
 | 
					Changes since U-Boot 0.3.1:
 | 
				
			||||||
======================================================================
 | 
					======================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					* Patches by Robert Schwebel, 26 Jun 2003:
 | 
				
			||||||
 | 
					  - logdl
 | 
				
			||||||
 | 
					  - csb226
 | 
				
			||||||
 | 
					  - innokom
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					* Patch by Pantelis Antoniou, 25 Jun 2003:
 | 
				
			||||||
 | 
					  update NetVia with V2 board support
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Header file cleanup for ARM
 | 
					* Header file cleanup for ARM
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Patch by Murray Jensen, 24 Jun 2003:
 | 
					* Patch by Murray Jensen, 24 Jun 2003:
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										10
									
								
								CREDITS
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								CREDITS
									
									
									
									
									
								
							@ -146,6 +146,10 @@ N: Andreas Heppel
 | 
				
			|||||||
E: aheppel@sysgo.de
 | 
					E: aheppel@sysgo.de
 | 
				
			||||||
D: CPU Support for MPC 75x; board support for Eltec BAB750 [obsolete!]
 | 
					D: CPU Support for MPC 75x; board support for Eltec BAB750 [obsolete!]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					N: August Hoeraendl
 | 
				
			||||||
 | 
					E: august.hoerandl@gmx.at
 | 
				
			||||||
 | 
					D: Support for the logodl board (PXA2xx)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
N: Josh Huber
 | 
					N: Josh Huber
 | 
				
			||||||
E: huber@alum.wpi.edu
 | 
					E: huber@alum.wpi.edu
 | 
				
			||||||
D: Port to the Galileo Evaluation Board, and the MPC74xx cpu series.
 | 
					D: Port to the Galileo Evaluation Board, and the MPC74xx cpu series.
 | 
				
			||||||
@ -256,7 +260,7 @@ D: FADS823 configuration, MPC823 video support, I2C, wireless keyboard, lots mor
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
N: Robert Schwebel
 | 
					N: Robert Schwebel
 | 
				
			||||||
E: r.schwebel@pengutronix.de
 | 
					E: r.schwebel@pengutronix.de
 | 
				
			||||||
D: Support for csb226 and innokom boards (xscale)
 | 
					D: Support for csb226, logodl and innokom boards (PXA2xx)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
N: Rob Taylor
 | 
					N: Rob Taylor
 | 
				
			||||||
E: robt@flyingpig.com
 | 
					E: robt@flyingpig.com
 | 
				
			||||||
@ -294,3 +298,7 @@ N: Alex Zuepke
 | 
				
			|||||||
E: azu@sysgo.de
 | 
					E: azu@sysgo.de
 | 
				
			||||||
D: Overall improvements on StrongARM, ARM720TDMI; Support for Tuxscreen; initial PCMCIA support for ARM
 | 
					D: Overall improvements on StrongARM, ARM720TDMI; Support for Tuxscreen; initial PCMCIA support for ARM
 | 
				
			||||||
W: www.elinos.com
 | 
					W: www.elinos.com
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					N: Pantelis Antoniou
 | 
				
			||||||
 | 
					E: panto@intracom.gr
 | 
				
			||||||
 | 
					D: NETVIA board support, ARTOS support.
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										12
									
								
								MAKEALL
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								MAKEALL
									
									
									
									
									
								
							@ -31,12 +31,12 @@ LIST_8xx="	\
 | 
				
			|||||||
	IP860		IVML24		IVML24_128	IVML24_256	\
 | 
						IP860		IVML24		IVML24_128	IVML24_256	\
 | 
				
			||||||
	IVMS8		IVMS8_128	IVMS8_256	KUP4K           \
 | 
						IVMS8		IVMS8_128	IVMS8_256	KUP4K           \
 | 
				
			||||||
	LANTEC	        lwmon   	MBX		MBX860T		\
 | 
						LANTEC	        lwmon   	MBX		MBX860T		\
 | 
				
			||||||
	MHPC		MVS1		NETVIA		NX823		\
 | 
						MHPC		MVS1		NETVIA		NETVIA_V2	\
 | 
				
			||||||
	pcu_e		R360MPI		RBC823		rmu		\
 | 
						NX823		pcu_e		R360MPI		RBC823		\
 | 
				
			||||||
	RPXClassic	RPXlite		RRvision	SM850		\
 | 
						rmu		RPXClassic	RPXlite		RRvision	\
 | 
				
			||||||
	SPD823TS	svm_sc8xx	SXNI855T	TOP860		\
 | 
						SM850		SPD823TS	svm_sc8xx	SXNI855T	\
 | 
				
			||||||
	TQM823L		TQM823L_LCD	TQM850L		TQM855L		\
 | 
						TOP860		TQM823L		TQM823L_LCD	TQM850L		\
 | 
				
			||||||
	TQM860L		TTTech		v37				\
 | 
						TQM855L		TQM860L		TTTech		v37		\
 | 
				
			||||||
"
 | 
					"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#########################################################################
 | 
					#########################################################################
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										14
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								Makefile
									
									
									
									
									
								
							@ -302,8 +302,20 @@ MHPC_config:		unconfig
 | 
				
			|||||||
MVS1_config :		unconfig
 | 
					MVS1_config :		unconfig
 | 
				
			||||||
	@./mkconfig $(@:_config=) ppc mpc8xx mvs1
 | 
						@./mkconfig $(@:_config=) ppc mpc8xx mvs1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					xtract_NETVIA = $(subst _V2,,$(subst _config,,$1))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					NETVIA_V2_config \
 | 
				
			||||||
NETVIA_config:		unconfig
 | 
					NETVIA_config:		unconfig
 | 
				
			||||||
	@./mkconfig $(@:_config=) ppc mpc8xx netvia
 | 
						@ >include/config.h
 | 
				
			||||||
 | 
						@[ -z "$(findstring NETVIA_config,$@)" ] || \
 | 
				
			||||||
 | 
							 { echo "#define CONFIG_NETVIA_VERSION 1" >>include/config.h ; \
 | 
				
			||||||
 | 
							  echo "... Version 1" ; \
 | 
				
			||||||
 | 
							 }
 | 
				
			||||||
 | 
						@[ -z "$(findstring NETVIA_V2_config,$@)" ] || \
 | 
				
			||||||
 | 
							 { echo "#define CONFIG_NETVIA_VERSION 2" >>include/config.h ; \
 | 
				
			||||||
 | 
							  echo "... Version 2" ; \
 | 
				
			||||||
 | 
							 }
 | 
				
			||||||
 | 
						@./mkconfig -a $(call xtract_NETVIA,$@) ppc mpc8xx netvia
 | 
				
			||||||
 | 
					
 | 
				
			||||||
NX823_config:		unconfig
 | 
					NX823_config:		unconfig
 | 
				
			||||||
	@./mkconfig $(@:_config=) ppc mpc8xx nx823
 | 
						@./mkconfig $(@:_config=) ppc mpc8xx nx823
 | 
				
			||||||
 | 
				
			|||||||
@ -26,9 +26,9 @@
 | 
				
			|||||||
#include <common.h>
 | 
					#include <common.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define FLASH_BANK_SIZE 0x1000000
 | 
					#define FLASH_BANK_SIZE 0x1000000
 | 
				
			||||||
#define MAIN_SECT_SIZE  0x20000	/* 2x64k = 128k per sector */
 | 
					#define MAIN_SECT_SIZE  0x20000		/* 2x64k = 128k per sector */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
flash_info_t flash_info[CFG_MAX_FLASH_BANKS];	/* info for FLASH chips    */
 | 
					flash_info_t flash_info[CFG_MAX_FLASH_BANKS]; /* info for FLASH chips	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* NOTE - CONFIG_FLASH_16BIT means the CPU interface is 16-bit, it
 | 
					/* NOTE - CONFIG_FLASH_16BIT means the CPU interface is 16-bit, it
 | 
				
			||||||
 *        has nothing to do with the flash chip being 8-bit or 16-bit.
 | 
					 *        has nothing to do with the flash chip being 8-bit or 16-bit.
 | 
				
			||||||
@ -53,16 +53,14 @@ typedef volatile unsigned long FLASH_PORT_WIDTHV;
 | 
				
			|||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 * Functions
 | 
					 * Functions
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static ulong flash_get_size (FPWV * addr, flash_info_t * info);
 | 
					static ulong flash_get_size(FPWV *addr, flash_info_t *info);
 | 
				
			||||||
static void flash_reset (flash_info_t * info);
 | 
					static void flash_reset(flash_info_t *info);
 | 
				
			||||||
static int write_word_intel (flash_info_t * info, FPWV * dest, FPW data);
 | 
					static int write_word_intel(flash_info_t *info, FPWV *dest, FPW data);
 | 
				
			||||||
static int write_word_amd (flash_info_t * info, FPWV * dest, FPW data);
 | 
					static int write_word_amd(flash_info_t *info, FPWV *dest, FPW data);
 | 
				
			||||||
 | 
					 | 
				
			||||||
#define write_word(in, de, da)   write_word_amd(in, de, da)
 | 
					#define write_word(in, de, da)   write_word_amd(in, de, da)
 | 
				
			||||||
static void flash_get_offsets (ulong base, flash_info_t * info);
 | 
					static void flash_get_offsets(ulong base, flash_info_t *info);
 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef CFG_FLASH_PROTECTION
 | 
					#ifdef CFG_FLASH_PROTECTION
 | 
				
			||||||
static void flash_sync_real_protect (flash_info_t * info);
 | 
					static void flash_sync_real_protect(flash_info_t *info);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
@ -70,95 +68,99 @@ static void flash_sync_real_protect (flash_info_t * info);
 | 
				
			|||||||
 *
 | 
					 *
 | 
				
			||||||
 * sets up flash_info and returns size of FLASH (bytes)
 | 
					 * sets up flash_info and returns size of FLASH (bytes)
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
ulong flash_init (void)
 | 
					ulong flash_init(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int i, j;
 | 
					    int i, j;
 | 
				
			||||||
	ulong size = 0;
 | 
					    ulong size = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = 0; i < CFG_MAX_FLASH_BANKS; i++) {
 | 
					    for (i = 0; i < CFG_MAX_FLASH_BANKS; i++)
 | 
				
			||||||
		ulong flashbase = 0;
 | 
					    {
 | 
				
			||||||
 | 
						ulong flashbase = 0;
 | 
				
			||||||
		flash_info[i].flash_id =
 | 
						flash_info[i].flash_id =
 | 
				
			||||||
				(FLASH_MAN_AMD & FLASH_VENDMASK) |
 | 
						  (FLASH_MAN_AMD & FLASH_VENDMASK) |
 | 
				
			||||||
				(FLASH_AM640U & FLASH_TYPEMASK);
 | 
						  (FLASH_AM640U & FLASH_TYPEMASK);
 | 
				
			||||||
		flash_info[i].size = FLASH_BANK_SIZE;
 | 
						flash_info[i].size = FLASH_BANK_SIZE;
 | 
				
			||||||
		flash_info[i].sector_count = CFG_MAX_FLASH_SECT;
 | 
						flash_info[i].sector_count = CFG_MAX_FLASH_SECT;
 | 
				
			||||||
		memset (flash_info[i].protect, 0, CFG_MAX_FLASH_SECT);
 | 
						memset(flash_info[i].protect, 0, CFG_MAX_FLASH_SECT);
 | 
				
			||||||
		switch (i) {
 | 
					        switch (i)
 | 
				
			||||||
		case 0:
 | 
					        {
 | 
				
			||||||
			flashbase = PHYS_FLASH_1;
 | 
					           case 0:
 | 
				
			||||||
			break;
 | 
						        flashbase = PHYS_FLASH_1;
 | 
				
			||||||
		case 1:
 | 
					                break;
 | 
				
			||||||
			flashbase = PHYS_FLASH_2;
 | 
					           case 1:
 | 
				
			||||||
			break;
 | 
						        flashbase = PHYS_FLASH_2;
 | 
				
			||||||
		default:
 | 
					                break;
 | 
				
			||||||
			panic ("configured to many flash banks!\n");
 | 
					           default:
 | 
				
			||||||
			break;
 | 
						        panic("configured to many flash banks!\n");
 | 
				
			||||||
		}
 | 
					                break;
 | 
				
			||||||
		for (j = 0; j < flash_info[i].sector_count; j++) {
 | 
					        }
 | 
				
			||||||
			flash_info[i].start[j] = flashbase + j * MAIN_SECT_SIZE;
 | 
						for (j = 0; j < flash_info[i].sector_count; j++)
 | 
				
			||||||
		}
 | 
						{
 | 
				
			||||||
		size += flash_info[i].size;
 | 
						    flash_info[i].start[j] = flashbase + j*MAIN_SECT_SIZE;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						size += flash_info[i].size;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Protect monitor and environment sectors
 | 
					    /* Protect monitor and environment sectors
 | 
				
			||||||
	 */
 | 
					     */
 | 
				
			||||||
	flash_protect (FLAG_PROTECT_SET,
 | 
					    flash_protect(FLAG_PROTECT_SET,
 | 
				
			||||||
			CFG_FLASH_BASE,
 | 
							  CFG_FLASH_BASE,
 | 
				
			||||||
			CFG_FLASH_BASE + _armboot_end_data - _armboot_start,
 | 
							  CFG_FLASH_BASE + _armboot_end_data - _armboot_start,
 | 
				
			||||||
			&flash_info[0]);
 | 
							  &flash_info[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	flash_protect (FLAG_PROTECT_SET,
 | 
					    flash_protect(FLAG_PROTECT_SET,
 | 
				
			||||||
			CFG_ENV_ADDR,
 | 
							  CFG_ENV_ADDR,
 | 
				
			||||||
			CFG_ENV_ADDR + CFG_ENV_SIZE - 1, &flash_info[0]);
 | 
							  CFG_ENV_ADDR + CFG_ENV_SIZE - 1,
 | 
				
			||||||
 | 
							  &flash_info[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return size;
 | 
					    return size;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static void flash_reset (flash_info_t * info)
 | 
					static void flash_reset(flash_info_t *info)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	FPWV *base = (FPWV *) (info->start[0]);
 | 
						FPWV *base = (FPWV *)(info->start[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Put FLASH back in read mode */
 | 
						/* Put FLASH back in read mode */
 | 
				
			||||||
	if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_INTEL)
 | 
						if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_INTEL)
 | 
				
			||||||
		*base = (FPW) 0x00FF00FF;	/* Intel Read Mode */
 | 
							*base = (FPW)0x00FF00FF;	/* Intel Read Mode */
 | 
				
			||||||
	else if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_AMD)
 | 
						else if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_AMD)
 | 
				
			||||||
		*base = (FPW) 0x00F000F0;	/* AMD Read Mode */
 | 
							*base = (FPW)0x00F000F0;	/* AMD Read Mode */
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static void flash_get_offsets (ulong base, flash_info_t * info)
 | 
					static void flash_get_offsets (ulong base, flash_info_t *info)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* set up sector start address table */
 | 
						/* set up sector start address table */
 | 
				
			||||||
	if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_INTEL
 | 
						if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_INTEL
 | 
				
			||||||
		&& (info->flash_id & FLASH_BTYPE)) {
 | 
						    && (info->flash_id & FLASH_BTYPE)) {
 | 
				
			||||||
		int bootsect_size;	/* number of bytes/boot sector  */
 | 
							int bootsect_size;	/* number of bytes/boot sector	*/
 | 
				
			||||||
		int sect_size;		/* number of bytes/regular sector */
 | 
							int sect_size;		/* number of bytes/regular sector */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		bootsect_size = 0x00002000 * (sizeof (FPW) / 2);
 | 
							bootsect_size = 0x00002000 * (sizeof(FPW)/2);
 | 
				
			||||||
		sect_size = 0x00010000 * (sizeof (FPW) / 2);
 | 
							sect_size =     0x00010000 * (sizeof(FPW)/2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* set sector offsets for bottom boot block type    */
 | 
							/* set sector offsets for bottom boot block type	*/
 | 
				
			||||||
		for (i = 0; i < 8; ++i) {
 | 
							for (i = 0; i < 8; ++i) {
 | 
				
			||||||
			info->start[i] = base + (i * bootsect_size);
 | 
								info->start[i] = base + (i * bootsect_size);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		for (i = 8; i < info->sector_count; i++) {
 | 
							for (i = 8; i < info->sector_count; i++) {
 | 
				
			||||||
			info->start[i] = base + ((i - 7) * sect_size);
 | 
								info->start[i] = base + ((i - 7) * sect_size);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	} else if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_AMD
 | 
						}
 | 
				
			||||||
			   && (info->flash_id & FLASH_TYPEMASK) == FLASH_AM640U) {
 | 
						else if ((info->flash_id & FLASH_VENDMASK) == FLASH_MAN_AMD
 | 
				
			||||||
 | 
							 && (info->flash_id & FLASH_TYPEMASK) == FLASH_AM640U) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		int sect_size;		/* number of bytes/sector */
 | 
							int sect_size;		/* number of bytes/sector */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		sect_size = 0x00010000 * (sizeof (FPW) / 2);
 | 
							sect_size = 0x00010000 * (sizeof(FPW)/2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* set up sector start address table (uniform sector type) */
 | 
							/* set up sector start address table (uniform sector type) */
 | 
				
			||||||
		for (i = 0; i < info->sector_count; i++)
 | 
							for( i = 0; i < info->sector_count; i++ )
 | 
				
			||||||
			info->start[i] = base + (i * sect_size);
 | 
								info->start[i] = base + (i * sect_size);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -166,7 +168,7 @@ static void flash_get_offsets (ulong base, flash_info_t * info)
 | 
				
			|||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void flash_print_info (flash_info_t * info)
 | 
					void flash_print_info (flash_info_t *info)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	uchar *boottype;
 | 
						uchar *boottype;
 | 
				
			||||||
@ -183,34 +185,21 @@ void flash_print_info (flash_info_t * info)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	switch (info->flash_id & FLASH_VENDMASK) {
 | 
						switch (info->flash_id & FLASH_VENDMASK) {
 | 
				
			||||||
	case FLASH_MAN_AMD:
 | 
						case FLASH_MAN_AMD:	printf ("AMD ");		break;
 | 
				
			||||||
		printf ("AMD ");
 | 
						case FLASH_MAN_BM:	printf ("BRIGHT MICRO ");	break;
 | 
				
			||||||
		break;
 | 
						case FLASH_MAN_FUJ:	printf ("FUJITSU ");		break;
 | 
				
			||||||
	case FLASH_MAN_BM:
 | 
						case FLASH_MAN_SST:	printf ("SST ");		break;
 | 
				
			||||||
		printf ("BRIGHT MICRO ");
 | 
						case FLASH_MAN_STM:	printf ("STM ");		break;
 | 
				
			||||||
		break;
 | 
						case FLASH_MAN_INTEL:	printf ("INTEL ");		break;
 | 
				
			||||||
	case FLASH_MAN_FUJ:
 | 
						default:		printf ("Unknown Vendor ");	break;
 | 
				
			||||||
		printf ("FUJITSU ");
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	case FLASH_MAN_SST:
 | 
					 | 
				
			||||||
		printf ("SST ");
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	case FLASH_MAN_STM:
 | 
					 | 
				
			||||||
		printf ("STM ");
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	case FLASH_MAN_INTEL:
 | 
					 | 
				
			||||||
		printf ("INTEL ");
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	default:
 | 
					 | 
				
			||||||
		printf ("Unknown Vendor ");
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* check for top or bottom boot, if it applies */
 | 
						/* check for top or bottom boot, if it applies */
 | 
				
			||||||
	if (info->flash_id & FLASH_BTYPE) {
 | 
						if (info->flash_id & FLASH_BTYPE) {
 | 
				
			||||||
		boottype = botboottype;
 | 
							boottype = botboottype;
 | 
				
			||||||
		bootletter = botbootletter;
 | 
							bootletter = botbootletter;
 | 
				
			||||||
	} else {
 | 
						}
 | 
				
			||||||
 | 
						else {
 | 
				
			||||||
		boottype = topboottype;
 | 
							boottype = topboottype;
 | 
				
			||||||
		bootletter = topbootletter;
 | 
							bootletter = topbootletter;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@ -219,32 +208,32 @@ void flash_print_info (flash_info_t * info)
 | 
				
			|||||||
	case FLASH_AM640U:
 | 
						case FLASH_AM640U:
 | 
				
			||||||
		fmt = "29LV641D (64 Mbit, uniform sectors)\n";
 | 
							fmt = "29LV641D (64 Mbit, uniform sectors)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_28F800C3B:
 | 
					        case FLASH_28F800C3B:
 | 
				
			||||||
	case FLASH_28F800C3T:
 | 
					        case FLASH_28F800C3T:
 | 
				
			||||||
		fmt = "28F800C3%s (8 Mbit, %s)\n";
 | 
							fmt = "28F800C3%s (8 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_INTEL800B:
 | 
						case FLASH_INTEL800B:
 | 
				
			||||||
	case FLASH_INTEL800T:
 | 
						case FLASH_INTEL800T:
 | 
				
			||||||
		fmt = "28F800B3%s (8 Mbit, %s)\n";
 | 
							fmt = "28F800B3%s (8 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_28F160C3B:
 | 
					        case FLASH_28F160C3B:
 | 
				
			||||||
	case FLASH_28F160C3T:
 | 
					        case FLASH_28F160C3T:
 | 
				
			||||||
		fmt = "28F160C3%s (16 Mbit, %s)\n";
 | 
							fmt = "28F160C3%s (16 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_INTEL160B:
 | 
						case FLASH_INTEL160B:
 | 
				
			||||||
	case FLASH_INTEL160T:
 | 
						case FLASH_INTEL160T:
 | 
				
			||||||
		fmt = "28F160B3%s (16 Mbit, %s)\n";
 | 
							fmt = "28F160B3%s (16 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_28F320C3B:
 | 
					        case FLASH_28F320C3B:
 | 
				
			||||||
	case FLASH_28F320C3T:
 | 
					        case FLASH_28F320C3T:
 | 
				
			||||||
		fmt = "28F320C3%s (32 Mbit, %s)\n";
 | 
							fmt = "28F320C3%s (32 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_INTEL320B:
 | 
						case FLASH_INTEL320B:
 | 
				
			||||||
	case FLASH_INTEL320T:
 | 
						case FLASH_INTEL320T:
 | 
				
			||||||
		fmt = "28F320B3%s (32 Mbit, %s)\n";
 | 
							fmt = "28F320B3%s (32 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_28F640C3B:
 | 
					        case FLASH_28F640C3B:
 | 
				
			||||||
	case FLASH_28F640C3T:
 | 
					        case FLASH_28F640C3T:
 | 
				
			||||||
		fmt = "28F640C3%s (64 Mbit, %s)\n";
 | 
							fmt = "28F640C3%s (64 Mbit, %s)\n";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case FLASH_INTEL640B:
 | 
						case FLASH_INTEL640B:
 | 
				
			||||||
@ -259,11 +248,12 @@ void flash_print_info (flash_info_t * info)
 | 
				
			|||||||
	printf (fmt, bootletter, boottype);
 | 
						printf (fmt, bootletter, boottype);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	printf ("  Size: %ld MB in %d Sectors\n",
 | 
						printf ("  Size: %ld MB in %d Sectors\n",
 | 
				
			||||||
		info->size >> 20, info->sector_count);
 | 
							info->size >> 20,
 | 
				
			||||||
 | 
							info->sector_count);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	printf ("  Sector Start Addresses:");
 | 
						printf ("  Sector Start Addresses:");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = 0; i < info->sector_count; ++i) {
 | 
						for (i=0; i<info->sector_count; ++i) {
 | 
				
			||||||
		if ((i % 5) == 0) {
 | 
							if ((i % 5) == 0) {
 | 
				
			||||||
			printf ("\n   ");
 | 
								printf ("\n   ");
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@ -282,25 +272,25 @@ void flash_print_info (flash_info_t * info)
 | 
				
			|||||||
 * The following code cannot be run from FLASH!
 | 
					 * The following code cannot be run from FLASH!
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ulong flash_get_size (FPWV * addr, flash_info_t * info)
 | 
					ulong flash_get_size (FPWV *addr, flash_info_t *info)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	/* Write auto select command: read Manufacturer ID */
 | 
						/* Write auto select command: read Manufacturer ID */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Write auto select command sequence and test FLASH answer */
 | 
						/* Write auto select command sequence and test FLASH answer */
 | 
				
			||||||
	addr[0x0555] = (FPW) 0x00AA00AA;	/* for AMD, Intel ignores this */
 | 
						addr[0x0555] = (FPW)0x00AA00AA;	/* for AMD, Intel ignores this */
 | 
				
			||||||
	addr[0x02AA] = (FPW) 0x00550055;	/* for AMD, Intel ignores this */
 | 
						addr[0x02AA] = (FPW)0x00550055;	/* for AMD, Intel ignores this */
 | 
				
			||||||
	addr[0x0555] = (FPW) 0x00900090;	/* selects Intel or AMD */
 | 
						addr[0x0555] = (FPW)0x00900090;	/* selects Intel or AMD */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* The manufacturer codes are only 1 byte, so just use 1 byte.
 | 
						/* The manufacturer codes are only 1 byte, so just use 1 byte.
 | 
				
			||||||
	 * This works for any bus width and any FLASH device width.
 | 
						 * This works for any bus width and any FLASH device width.
 | 
				
			||||||
	 */
 | 
						 */
 | 
				
			||||||
	switch (addr[0] & 0xff) {
 | 
						switch (addr[0] & 0xff) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case (uchar) AMD_MANUFACT:
 | 
						case (uchar)AMD_MANUFACT:
 | 
				
			||||||
		info->flash_id = FLASH_MAN_AMD;
 | 
							info->flash_id = FLASH_MAN_AMD;
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case (uchar) INTEL_MANUFACT:
 | 
						case (uchar)INTEL_MANUFACT:
 | 
				
			||||||
		info->flash_id = FLASH_MAN_INTEL;
 | 
							info->flash_id = FLASH_MAN_INTEL;
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -312,74 +302,73 @@ ulong flash_get_size (FPWV * addr, flash_info_t * info)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Check 16 bits or 32 bits of ID so work on 32 or 16 bit bus. */
 | 
						/* Check 16 bits or 32 bits of ID so work on 32 or 16 bit bus. */
 | 
				
			||||||
	if (info->flash_id != FLASH_UNKNOWN)
 | 
						if (info->flash_id != FLASH_UNKNOWN) switch (addr[1]) {
 | 
				
			||||||
		switch (addr[1]) {
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) AMD_ID_LV640U:	/* 29LV640 and 29LV641 have same ID */
 | 
						case (FPW)AMD_ID_LV640U:	/* 29LV640 and 29LV641 have same ID */
 | 
				
			||||||
			info->flash_id += FLASH_AM640U;
 | 
							info->flash_id += FLASH_AM640U;
 | 
				
			||||||
			info->sector_count = 128;
 | 
							info->sector_count = 128;
 | 
				
			||||||
			info->size = 0x00800000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00800000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 8 or 16 MB    */
 | 
							break;				/* => 8 or 16 MB	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F800C3B:
 | 
						case (FPW)INTEL_ID_28F800C3B:
 | 
				
			||||||
			info->flash_id += FLASH_28F800C3B;
 | 
							info->flash_id += FLASH_28F800C3B;
 | 
				
			||||||
			info->sector_count = 23;
 | 
							info->sector_count = 23;
 | 
				
			||||||
			info->size = 0x00100000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00100000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 1 or 2 MB     */
 | 
							break;				/* => 1 or 2 MB		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F800B3B:
 | 
						case (FPW)INTEL_ID_28F800B3B:
 | 
				
			||||||
			info->flash_id += FLASH_INTEL800B;
 | 
							info->flash_id += FLASH_INTEL800B;
 | 
				
			||||||
			info->sector_count = 23;
 | 
							info->sector_count = 23;
 | 
				
			||||||
			info->size = 0x00100000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00100000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 1 or 2 MB     */
 | 
							break;				/* => 1 or 2 MB		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F160C3B:
 | 
						case (FPW)INTEL_ID_28F160C3B:
 | 
				
			||||||
			info->flash_id += FLASH_28F160C3B;
 | 
							info->flash_id += FLASH_28F160C3B;
 | 
				
			||||||
			info->sector_count = 39;
 | 
							info->sector_count = 39;
 | 
				
			||||||
			info->size = 0x00200000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00200000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 2 or 4 MB     */
 | 
							break;				/* => 2 or 4 MB		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F160B3B:
 | 
						case (FPW)INTEL_ID_28F160B3B:
 | 
				
			||||||
			info->flash_id += FLASH_INTEL160B;
 | 
							info->flash_id += FLASH_INTEL160B;
 | 
				
			||||||
			info->sector_count = 39;
 | 
							info->sector_count = 39;
 | 
				
			||||||
			info->size = 0x00200000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00200000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 2 or 4 MB     */
 | 
							break;				/* => 2 or 4 MB		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F320C3B:
 | 
						case (FPW)INTEL_ID_28F320C3B:
 | 
				
			||||||
			info->flash_id += FLASH_28F320C3B;
 | 
							info->flash_id += FLASH_28F320C3B;
 | 
				
			||||||
			info->sector_count = 71;
 | 
							info->sector_count = 71;
 | 
				
			||||||
			info->size = 0x00400000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00400000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 4 or 8 MB     */
 | 
							break;				/* => 4 or 8 MB		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F320B3B:
 | 
						case (FPW)INTEL_ID_28F320B3B:
 | 
				
			||||||
			info->flash_id += FLASH_INTEL320B;
 | 
							info->flash_id += FLASH_INTEL320B;
 | 
				
			||||||
			info->sector_count = 71;
 | 
							info->sector_count = 71;
 | 
				
			||||||
			info->size = 0x00400000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00400000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 4 or 8 MB     */
 | 
							break;				/* => 4 or 8 MB		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F640C3B:
 | 
						case (FPW)INTEL_ID_28F640C3B:
 | 
				
			||||||
			info->flash_id += FLASH_28F640C3B;
 | 
							info->flash_id += FLASH_28F640C3B;
 | 
				
			||||||
			info->sector_count = 135;
 | 
							info->sector_count = 135;
 | 
				
			||||||
			info->size = 0x00800000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00800000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 8 or 16 MB    */
 | 
							break;				/* => 8 or 16 MB	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case (FPW) INTEL_ID_28F640B3B:
 | 
						case (FPW)INTEL_ID_28F640B3B:
 | 
				
			||||||
			info->flash_id += FLASH_INTEL640B;
 | 
							info->flash_id += FLASH_INTEL640B;
 | 
				
			||||||
			info->sector_count = 135;
 | 
							info->sector_count = 135;
 | 
				
			||||||
			info->size = 0x00800000 * (sizeof (FPW) / 2);
 | 
							info->size = 0x00800000 * (sizeof(FPW)/2);
 | 
				
			||||||
			break;			/* => 8 or 16 MB    */
 | 
							break;				/* => 8 or 16 MB	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		default:
 | 
						default:
 | 
				
			||||||
			info->flash_id = FLASH_UNKNOWN;
 | 
							info->flash_id = FLASH_UNKNOWN;
 | 
				
			||||||
			info->sector_count = 0;
 | 
							info->sector_count = 0;
 | 
				
			||||||
			info->size = 0;
 | 
							info->size = 0;
 | 
				
			||||||
			return (0);		/* => no or unknown flash */
 | 
							return (0);			/* => no or unknown flash */
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	flash_get_offsets ((ulong) addr, info);
 | 
						flash_get_offsets((ulong)addr, info);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Put FLASH back in read mode */
 | 
						/* Put FLASH back in read mode */
 | 
				
			||||||
	flash_reset (info);
 | 
						flash_reset(info);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return (info->size);
 | 
						return (info->size);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -388,50 +377,50 @@ ulong flash_get_size (FPWV * addr, flash_info_t * info)
 | 
				
			|||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void flash_sync_real_protect (flash_info_t * info)
 | 
					static void flash_sync_real_protect(flash_info_t *info)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	FPWV *addr = (FPWV *) (info->start[0]);
 | 
					    FPWV *addr = (FPWV *)(info->start[0]);
 | 
				
			||||||
	FPWV *sect;
 | 
					    FPWV *sect;
 | 
				
			||||||
	int i;
 | 
					    int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	switch (info->flash_id & FLASH_TYPEMASK) {
 | 
					    switch (info->flash_id & FLASH_TYPEMASK) {
 | 
				
			||||||
	case FLASH_28F800C3B:
 | 
					    case FLASH_28F800C3B:
 | 
				
			||||||
	case FLASH_28F800C3T:
 | 
					    case FLASH_28F800C3T:
 | 
				
			||||||
	case FLASH_28F160C3B:
 | 
					    case FLASH_28F160C3B:
 | 
				
			||||||
	case FLASH_28F160C3T:
 | 
					    case FLASH_28F160C3T:
 | 
				
			||||||
	case FLASH_28F320C3B:
 | 
					    case FLASH_28F320C3B:
 | 
				
			||||||
	case FLASH_28F320C3T:
 | 
					    case FLASH_28F320C3T:
 | 
				
			||||||
	case FLASH_28F640C3B:
 | 
					    case FLASH_28F640C3B:
 | 
				
			||||||
	case FLASH_28F640C3T:
 | 
					    case FLASH_28F640C3T:
 | 
				
			||||||
		/* check for protected sectors */
 | 
						/* check for protected sectors */
 | 
				
			||||||
		*addr = (FPW) 0x00900090;
 | 
						*addr = (FPW)0x00900090;
 | 
				
			||||||
		for (i = 0; i < info->sector_count; i++) {
 | 
						for (i = 0; i < info->sector_count; i++) {
 | 
				
			||||||
			/* read sector protection at sector address, (A7 .. A0) = 0x02.
 | 
						    /* read sector protection at sector address, (A7 .. A0) = 0x02.
 | 
				
			||||||
			 * D0 = 1 for each device if protected.
 | 
						     * D0 = 1 for each device if protected.
 | 
				
			||||||
			 * If at least one device is protected the sector is marked
 | 
						     * If at least one device is protected the sector is marked
 | 
				
			||||||
			 * protected, but mixed protected and  unprotected devices
 | 
						     * protected, but mixed protected and  unprotected devices
 | 
				
			||||||
			 * within a sector should never happen.
 | 
						     * within a sector should never happen.
 | 
				
			||||||
			 */
 | 
						     */
 | 
				
			||||||
			sect = (FPWV *) (info->start[i]);
 | 
						    sect = (FPWV *)(info->start[i]);
 | 
				
			||||||
			info->protect[i] = (sect[2] & (FPW) (0x00010001)) ? 1 : 0;
 | 
						    info->protect[i] = (sect[2] & (FPW)(0x00010001)) ? 1 : 0;
 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/* Put FLASH back in read mode */
 | 
					 | 
				
			||||||
		flash_reset (info);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	case FLASH_AM640U:
 | 
					 | 
				
			||||||
	default:
 | 
					 | 
				
			||||||
		/* no hardware protect that we support */
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* Put FLASH back in read mode */
 | 
				
			||||||
 | 
						flash_reset(info);
 | 
				
			||||||
 | 
						break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    case FLASH_AM640U:
 | 
				
			||||||
 | 
					    default:
 | 
				
			||||||
 | 
						/* no hardware protect that we support */
 | 
				
			||||||
 | 
						break;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int flash_erase (flash_info_t * info, int s_first, int s_last)
 | 
					int	flash_erase (flash_info_t *info, int s_first, int s_last)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	FPWV *addr;
 | 
						FPWV *addr;
 | 
				
			||||||
	int flag, prot, sect;
 | 
						int flag, prot, sect;
 | 
				
			||||||
@ -467,7 +456,7 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	prot = 0;
 | 
						prot = 0;
 | 
				
			||||||
	for (sect = s_first; sect <= s_last; ++sect) {
 | 
						for (sect=s_first; sect<=s_last; ++sect) {
 | 
				
			||||||
		if (info->protect[sect]) {
 | 
							if (info->protect[sect]) {
 | 
				
			||||||
			prot++;
 | 
								prot++;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@ -475,60 +464,61 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (prot) {
 | 
						if (prot) {
 | 
				
			||||||
		printf ("- Warning: %d protected sectors will not be erased!\n",
 | 
							printf ("- Warning: %d protected sectors will not be erased!\n",
 | 
				
			||||||
				prot);
 | 
								prot);
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		printf ("\n");
 | 
							printf ("\n");
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	start = get_timer (0);
 | 
						start = get_timer(0);
 | 
				
			||||||
	last = start;
 | 
						last  = start;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Start erase on unprotected sectors */
 | 
						/* Start erase on unprotected sectors */
 | 
				
			||||||
	for (sect = s_first; sect <= s_last && rcode == 0; sect++) {
 | 
						for (sect = s_first; sect<=s_last && rcode == 0; sect++) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (info->protect[sect] != 0)	/* protected, skip it */
 | 
							if (info->protect[sect] != 0)	/* protected, skip it */
 | 
				
			||||||
			continue;
 | 
								continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* Disable interrupts which might cause a timeout here */
 | 
							/* Disable interrupts which might cause a timeout here */
 | 
				
			||||||
		flag = disable_interrupts ();
 | 
							flag = disable_interrupts();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		addr = (FPWV *) (info->start[sect]);
 | 
							addr = (FPWV *)(info->start[sect]);
 | 
				
			||||||
		if (intel) {
 | 
							if (intel) {
 | 
				
			||||||
			*addr = (FPW) 0x00500050;	/* clear status register */
 | 
								*addr = (FPW)0x00500050; /* clear status register */
 | 
				
			||||||
			*addr = (FPW) 0x00200020;	/* erase setup */
 | 
								*addr = (FPW)0x00200020; /* erase setup */
 | 
				
			||||||
			*addr = (FPW) 0x00D000D0;	/* erase confirm */
 | 
								*addr = (FPW)0x00D000D0; /* erase confirm */
 | 
				
			||||||
		} else {
 | 
							}
 | 
				
			||||||
 | 
							else {
 | 
				
			||||||
			/* must be AMD style if not Intel */
 | 
								/* must be AMD style if not Intel */
 | 
				
			||||||
			FPWV *base;			/* first address in bank */
 | 
								FPWV *base;		/* first address in bank */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			base = (FPWV *) (info->start[0]);
 | 
								base = (FPWV *)(info->start[0]);
 | 
				
			||||||
			base[0x0555] = (FPW) 0x00AA00AA;	/* unlock */
 | 
								base[0x0555] = (FPW)0x00AA00AA;	/* unlock */
 | 
				
			||||||
			base[0x02AA] = (FPW) 0x00550055;	/* unlock */
 | 
								base[0x02AA] = (FPW)0x00550055;	/* unlock */
 | 
				
			||||||
			base[0x0555] = (FPW) 0x00800080;	/* erase mode */
 | 
								base[0x0555] = (FPW)0x00800080;	/* erase mode */
 | 
				
			||||||
			base[0x0555] = (FPW) 0x00AA00AA;	/* unlock */
 | 
								base[0x0555] = (FPW)0x00AA00AA;	/* unlock */
 | 
				
			||||||
			base[0x02AA] = (FPW) 0x00550055;	/* unlock */
 | 
								base[0x02AA] = (FPW)0x00550055;	/* unlock */
 | 
				
			||||||
			*addr = (FPW) 0x00300030;	/* erase sector */
 | 
								*addr = (FPW)0x00300030;	/* erase sector */
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* re-enable interrupts if necessary */
 | 
							/* re-enable interrupts if necessary */
 | 
				
			||||||
		if (flag)
 | 
							if (flag)
 | 
				
			||||||
			enable_interrupts ();
 | 
								enable_interrupts();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* wait at least 50us for AMD, 80us for Intel.
 | 
							/* wait at least 50us for AMD, 80us for Intel.
 | 
				
			||||||
		 * Let's wait 1 ms.
 | 
							 * Let's wait 1 ms.
 | 
				
			||||||
		 */
 | 
							 */
 | 
				
			||||||
		udelay (1000);
 | 
							udelay (1000);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		while ((*addr & (FPW) 0x00800080) != (FPW) 0x00800080) {
 | 
							while ((*addr & (FPW)0x00800080) != (FPW)0x00800080) {
 | 
				
			||||||
			if ((now = get_timer (start)) > CFG_FLASH_ERASE_TOUT) {
 | 
								if ((now = get_timer(start)) > CFG_FLASH_ERASE_TOUT) {
 | 
				
			||||||
				printf ("Timeout\n");
 | 
									printf ("Timeout\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (intel) {
 | 
									if (intel) {
 | 
				
			||||||
					/* suspend erase    */
 | 
										/* suspend erase	*/
 | 
				
			||||||
					*addr = (FPW) 0x00B000B0;
 | 
										*addr = (FPW)0x00B000B0;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				flash_reset (info);	/* reset to read mode */
 | 
									flash_reset(info);	/* reset to read mode */
 | 
				
			||||||
				rcode = 1;		/* failed */
 | 
									rcode = 1;		/* failed */
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@ -540,7 +530,7 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		flash_reset (info);		/* reset to read mode   */
 | 
							flash_reset(info);	/* reset to read mode	*/
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	printf (" done\n");
 | 
						printf (" done\n");
 | 
				
			||||||
@ -555,48 +545,46 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
int bad_write_buff (flash_info_t *info, uchar *src, ulong addr, ulong cnt)
 | 
					int bad_write_buff (flash_info_t *info, uchar *src, ulong addr, ulong cnt)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	FPW data = 0;	/* 16 or 32 bit word, matches flash bus width */
 | 
					    FPW data = 0; /* 16 or 32 bit word, matches flash bus width on MPC8XX */
 | 
				
			||||||
	int bytes;	/* number of bytes to program in current word */
 | 
					    int bytes;	  /* number of bytes to program in current word		*/
 | 
				
			||||||
	int left;	/* number of bytes left to program            */
 | 
					    int left;	  /* number of bytes left to program			*/
 | 
				
			||||||
	int i, res;
 | 
					    int i, res;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/*    printf("write_buff: src: %8p addr %08lx count: %ld\n", src, addr, cnt); */
 | 
					    for (left = cnt, res = 0;
 | 
				
			||||||
 | 
						 left > 0 && res == 0;
 | 
				
			||||||
 | 
						 addr += sizeof(data), left -= sizeof(data) - bytes) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (left = cnt, res = 0;
 | 
					        bytes = addr & (sizeof(data) - 1);
 | 
				
			||||||
		 left > 0 && res == 0;
 | 
					        addr &= ~(sizeof(data) - 1);
 | 
				
			||||||
		 addr += sizeof (data), left -= sizeof (data) - bytes) {
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		bytes = addr & (sizeof (data) - 1);
 | 
						/* combine source and destination data so can program
 | 
				
			||||||
		addr &= ~(sizeof (data) - 1);
 | 
						 * an entire word of 16 or 32 bits
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
		/* combine source and destination data so can program
 | 
					        for (i = 0; i < sizeof(data); i++) {
 | 
				
			||||||
		 * an entire word of 16 or 32 bits
 | 
					            data <<= 8;
 | 
				
			||||||
		 */
 | 
					            if (i < bytes || i - bytes >= left )
 | 
				
			||||||
		for (i = 0; i < sizeof (data); i++) {
 | 
							data += *((uchar *)addr + i);
 | 
				
			||||||
			data <<= 8;
 | 
						    else
 | 
				
			||||||
			if (i < bytes || i - bytes >= left)
 | 
							data += *src++;
 | 
				
			||||||
				data += *((uchar *) addr + i);
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				data += *src++;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/* write one word to the flash */
 | 
					 | 
				
			||||||
		switch (info->flash_id & FLASH_VENDMASK) {
 | 
					 | 
				
			||||||
		case FLASH_MAN_AMD:
 | 
					 | 
				
			||||||
			res = write_word_amd (info, (FPWV *) addr, data);
 | 
					 | 
				
			||||||
			break;
 | 
					 | 
				
			||||||
		case FLASH_MAN_INTEL:
 | 
					 | 
				
			||||||
			res = write_word_intel (info, (FPWV *) addr, data);
 | 
					 | 
				
			||||||
			break;
 | 
					 | 
				
			||||||
		default:
 | 
					 | 
				
			||||||
			/* unknown flash type, error! */
 | 
					 | 
				
			||||||
			printf ("missing or unknown FLASH type\n");
 | 
					 | 
				
			||||||
			res = 1;	/* not really a timeout, but gives error */
 | 
					 | 
				
			||||||
			break;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return (res);
 | 
						/* write one word to the flash */
 | 
				
			||||||
 | 
						switch (info->flash_id & FLASH_VENDMASK) {
 | 
				
			||||||
 | 
						case FLASH_MAN_AMD:
 | 
				
			||||||
 | 
							res = write_word_amd(info, (FPWV *)addr, data);
 | 
				
			||||||
 | 
							break;
 | 
				
			||||||
 | 
						case FLASH_MAN_INTEL:
 | 
				
			||||||
 | 
							res = write_word_intel(info, (FPWV *)addr, data);
 | 
				
			||||||
 | 
							break;
 | 
				
			||||||
 | 
						default:
 | 
				
			||||||
 | 
							/* unknown flash type, error! */
 | 
				
			||||||
 | 
							printf ("missing or unknown FLASH type\n");
 | 
				
			||||||
 | 
							res = 1;	/* not really a timeout, but gives error */
 | 
				
			||||||
 | 
							break;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return (res);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
@ -610,7 +598,7 @@ int bad_write_buff (flash_info_t *info, uchar *src, ulong addr, ulong cnt)
 | 
				
			|||||||
 * @return	error code
 | 
					 * @return	error code
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int write_buff (flash_info_t * info, uchar * src, ulong addr, ulong cnt)
 | 
					int write_buff (flash_info_t *info, uchar *src, ulong addr, ulong cnt)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	ulong cp, wp;
 | 
						ulong cp, wp;
 | 
				
			||||||
	FPW data;
 | 
						FPW data;
 | 
				
			||||||
@ -624,19 +612,19 @@ int write_buff (flash_info_t * info, uchar * src, ulong addr, ulong cnt)
 | 
				
			|||||||
	 */
 | 
						 */
 | 
				
			||||||
	if ((l = addr - wp) != 0) {
 | 
						if ((l = addr - wp) != 0) {
 | 
				
			||||||
		data = 0;
 | 
							data = 0;
 | 
				
			||||||
		for (i = 0, cp = wp; i < l; ++i, ++cp) {
 | 
							for (i=0, cp=wp; i<l; ++i, ++cp) {
 | 
				
			||||||
			data = (data >> 8) | (*(uchar *) cp << 8);
 | 
								data = (data >> 8) | (*(uchar *)cp << 8);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		for (; i < 2 && cnt > 0; ++i) {
 | 
							for (; i<2 && cnt>0; ++i) {
 | 
				
			||||||
			data = (data >> 8) | (*src++ << 8);
 | 
								data = (data >> 8) | (*src++ << 8);
 | 
				
			||||||
			--cnt;
 | 
								--cnt;
 | 
				
			||||||
			++cp;
 | 
								++cp;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		for (; cnt == 0 && i < 2; ++i, ++cp) {
 | 
							for (; cnt==0 && i<2; ++i, ++cp) {
 | 
				
			||||||
			data = (data >> 8) | (*(uchar *) cp << 8);
 | 
								data = (data >> 8) | (*(uchar *)cp << 8);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((rc = write_word (info, wp, data)) != 0) {
 | 
							if ((rc = write_word(info, wp, data)) != 0) {
 | 
				
			||||||
			return (rc);
 | 
								return (rc);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		wp += 2;
 | 
							wp += 2;
 | 
				
			||||||
@ -647,31 +635,30 @@ int write_buff (flash_info_t * info, uchar * src, ulong addr, ulong cnt)
 | 
				
			|||||||
	 */
 | 
						 */
 | 
				
			||||||
	while (cnt >= 2) {
 | 
						while (cnt >= 2) {
 | 
				
			||||||
		/* data = *((vushort*)src); */
 | 
							/* data = *((vushort*)src); */
 | 
				
			||||||
		data = *((FPW *) src);
 | 
							data = *((FPW*)src);
 | 
				
			||||||
		if ((rc = write_word (info, wp, data)) != 0) {
 | 
							if ((rc = write_word(info, wp, data)) != 0) {
 | 
				
			||||||
			return (rc);
 | 
								return (rc);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		src += sizeof (FPW);
 | 
							src += sizeof(FPW);
 | 
				
			||||||
		wp += sizeof (FPW);
 | 
							wp  += sizeof(FPW);
 | 
				
			||||||
		cnt -= sizeof (FPW);
 | 
							cnt -= sizeof(FPW);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (cnt == 0)
 | 
						if (cnt == 0) return ERR_OK;
 | 
				
			||||||
		return ERR_OK;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/*
 | 
						/*
 | 
				
			||||||
	 * handle unaligned tail bytes
 | 
						 * handle unaligned tail bytes
 | 
				
			||||||
	 */
 | 
						 */
 | 
				
			||||||
	data = 0;
 | 
						data = 0;
 | 
				
			||||||
	for (i = 0, cp = wp; i < 2 && cnt > 0; ++i, ++cp) {
 | 
						for (i=0, cp=wp; i<2 && cnt>0; ++i, ++cp) {
 | 
				
			||||||
		data = (data >> 8) | (*src++ << 8);
 | 
							data = (data >> 8) | (*src++ << 8);
 | 
				
			||||||
		--cnt;
 | 
							--cnt;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	for (; i < 2; ++i, ++cp) {
 | 
						for (; i<2; ++i, ++cp) {
 | 
				
			||||||
		data = (data >> 8) | (*(uchar *) cp << 8);
 | 
							data = (data >> 8) | (*(uchar *)cp << 8);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return write_word (info, wp, data);
 | 
						return write_word(info, wp, data);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -686,45 +673,44 @@ int write_buff (flash_info_t * info, uchar * src, ulong addr, ulong cnt)
 | 
				
			|||||||
 * 1 - write timeout
 | 
					 * 1 - write timeout
 | 
				
			||||||
 * 2 - Flash not erased
 | 
					 * 2 - Flash not erased
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static int write_word_amd (flash_info_t * info, FPWV * dest, FPW data)
 | 
					static int write_word_amd (flash_info_t *info, FPWV *dest, FPW data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	ulong start;
 | 
					    ulong start;
 | 
				
			||||||
	int flag;
 | 
					    int flag;
 | 
				
			||||||
	int res = 0;		/* result, assume success   */
 | 
					    int res = 0;	/* result, assume success	*/
 | 
				
			||||||
	FPWV *base;		/* first address in flash bank  */
 | 
					    FPWV *base;		/* first address in flash bank	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Check if Flash is (sufficiently) erased */
 | 
					    /* Check if Flash is (sufficiently) erased */
 | 
				
			||||||
	if ((*dest & data) != data) {
 | 
					    if ((*dest & data) != data) {
 | 
				
			||||||
		return (2);
 | 
						return (2);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    base = (FPWV *)(info->start[0]);
 | 
				
			||||||
 | 
					    /* Disable interrupts which might cause a timeout here */
 | 
				
			||||||
 | 
					    flag = disable_interrupts();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    base[0x0555] = (FPW)0x00AA00AA;	/* unlock */
 | 
				
			||||||
 | 
					    base[0x02AA] = (FPW)0x00550055;	/* unlock */
 | 
				
			||||||
 | 
					    base[0x0555] = (FPW)0x00A000A0;	/* selects program mode */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    *dest = data;		/* start programming the data	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* re-enable interrupts if necessary */
 | 
				
			||||||
 | 
					    if (flag)
 | 
				
			||||||
 | 
						enable_interrupts();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    start = get_timer (0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* data polling for D7 */
 | 
				
			||||||
 | 
					    while (res == 0 && (*dest & (FPW)0x00800080) != (data & (FPW)0x00800080)) {
 | 
				
			||||||
 | 
						if (get_timer(start) > CFG_FLASH_WRITE_TOUT) {
 | 
				
			||||||
 | 
						    *dest = (FPW)0x00F000F0;	/* reset bank */
 | 
				
			||||||
 | 
						    res = 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return (res);
 | 
				
			||||||
	base = (FPWV *) (info->start[0]);
 | 
					 | 
				
			||||||
	/* Disable interrupts which might cause a timeout here */
 | 
					 | 
				
			||||||
	flag = disable_interrupts ();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	base[0x0555] = (FPW) 0x00AA00AA;	/* unlock */
 | 
					 | 
				
			||||||
	base[0x02AA] = (FPW) 0x00550055;	/* unlock */
 | 
					 | 
				
			||||||
	base[0x0555] = (FPW) 0x00A000A0;	/* selects program mode */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	*dest = data;				/* start programming the data   */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* re-enable interrupts if necessary */
 | 
					 | 
				
			||||||
	if (flag)
 | 
					 | 
				
			||||||
		enable_interrupts ();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	start = get_timer (0);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* data polling for D7 */
 | 
					 | 
				
			||||||
	while (res == 0
 | 
					 | 
				
			||||||
		   && (*dest & (FPW) 0x00800080) != (data & (FPW) 0x00800080)) {
 | 
					 | 
				
			||||||
		if (get_timer (start) > CFG_FLASH_WRITE_TOUT) {
 | 
					 | 
				
			||||||
			*dest = (FPW) 0x00F000F0;	/* reset bank */
 | 
					 | 
				
			||||||
			res = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return (res);
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
@ -737,46 +723,46 @@ static int write_word_amd (flash_info_t * info, FPWV * dest, FPW data)
 | 
				
			|||||||
 * 1 - write timeout
 | 
					 * 1 - write timeout
 | 
				
			||||||
 * 2 - Flash not erased
 | 
					 * 2 - Flash not erased
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static int write_word_intel (flash_info_t * info, FPWV * dest, FPW data)
 | 
					static int write_word_intel (flash_info_t *info, FPWV *dest, FPW data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	ulong start;
 | 
					    ulong start;
 | 
				
			||||||
	int flag;
 | 
					    int flag;
 | 
				
			||||||
	int res = 0;			/* result, assume success   */
 | 
					    int res = 0;	/* result, assume success	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Check if Flash is (sufficiently) erased */
 | 
					    /* Check if Flash is (sufficiently) erased */
 | 
				
			||||||
	if ((*dest & data) != data) {
 | 
					    if ((*dest & data) != data) {
 | 
				
			||||||
		return (2);
 | 
						return (2);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* Disable interrupts which might cause a timeout here */
 | 
				
			||||||
 | 
					    flag = disable_interrupts();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    *dest = (FPW)0x00500050;	/* clear status register	*/
 | 
				
			||||||
 | 
					    *dest = (FPW)0x00FF00FF;	/* make sure in read mode	*/
 | 
				
			||||||
 | 
					    *dest = (FPW)0x00400040;	/* program setup		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    *dest = data;		/* start programming the data	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* re-enable interrupts if necessary */
 | 
				
			||||||
 | 
					    if (flag)
 | 
				
			||||||
 | 
						enable_interrupts();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    start = get_timer (0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    while (res == 0 && (*dest & (FPW)0x00800080) != (FPW)0x00800080) {
 | 
				
			||||||
 | 
						if (get_timer(start) > CFG_FLASH_WRITE_TOUT) {
 | 
				
			||||||
 | 
						    *dest = (FPW)0x00B000B0;	/* Suspend program	*/
 | 
				
			||||||
 | 
						    res = 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Disable interrupts which might cause a timeout here */
 | 
					    if (res == 0 && (*dest & (FPW)0x00100010))
 | 
				
			||||||
	flag = disable_interrupts ();
 | 
						res = 1;	/* write failed, time out error is close enough	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	*dest = (FPW) 0x00500050;	/* clear status register    */
 | 
					    *dest = (FPW)0x00500050;	/* clear status register	*/
 | 
				
			||||||
	*dest = (FPW) 0x00FF00FF;	/* make sure in read mode   */
 | 
					    *dest = (FPW)0x00FF00FF;	/* make sure in read mode	*/
 | 
				
			||||||
	*dest = (FPW) 0x00400040;	/* program setup        */
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	*dest = data;			/* start programming the data   */
 | 
					    return (res);
 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* re-enable interrupts if necessary */
 | 
					 | 
				
			||||||
	if (flag)
 | 
					 | 
				
			||||||
		enable_interrupts ();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	start = get_timer (0);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	while (res == 0 && (*dest & (FPW) 0x00800080) != (FPW) 0x00800080) {
 | 
					 | 
				
			||||||
		if (get_timer (start) > CFG_FLASH_WRITE_TOUT) {
 | 
					 | 
				
			||||||
			*dest = (FPW) 0x00B000B0;	/* Suspend program  */
 | 
					 | 
				
			||||||
			res = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (res == 0 && (*dest & (FPW) 0x00100010))
 | 
					 | 
				
			||||||
		res = 1;	/* write failed, time out error is close enough */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	*dest = (FPW) 0x00500050;	/* clear status register    */
 | 
					 | 
				
			||||||
	*dest = (FPW) 0x00FF00FF;	/* make sure in read mode   */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return (res);
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CFG_FLASH_PROTECTION
 | 
					#ifdef CFG_FLASH_PROTECTION
 | 
				
			||||||
@ -784,8 +770,8 @@ static int write_word_intel (flash_info_t * info, FPWV * dest, FPW data)
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
int flash_real_protect (flash_info_t * info, long sector, int prot)
 | 
					int flash_real_protect (flash_info_t * info, long sector, int prot)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int rcode = 0;				/* assume success */
 | 
						int rcode = 0;		/* assume success */
 | 
				
			||||||
	FPWV *addr;				/* address of sector */
 | 
						FPWV *addr;		/* address of sector */
 | 
				
			||||||
	FPW value;
 | 
						FPW value;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	addr = (FPWV *) (info->start[sector]);
 | 
						addr = (FPWV *) (info->start[sector]);
 | 
				
			||||||
@ -826,7 +812,7 @@ int flash_real_protect (flash_info_t * info, long sector, int prot)
 | 
				
			|||||||
			info->protect[sector] = 1;
 | 
								info->protect[sector] = 1;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if (info->protect[sector] != prot)
 | 
							if (info->protect[sector] != prot)
 | 
				
			||||||
			rcode = 1;			/* failed to protect/unprotect as requested */
 | 
								rcode = 1;	/* failed to protect/unprotect as requested */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* reload all protection bits from hardware for now */
 | 
							/* reload all protection bits from hardware for now */
 | 
				
			||||||
		flash_sync_real_protect (info);
 | 
							flash_sync_real_protect (info);
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
/*
 | 
					/*
 | 
				
			||||||
 * (C) 2002 Kyle Harris <kharris@nexus-tech.net>, Nexus Technologies, Inc.
 | 
					 * (C) 2002 Kyle Harris <kharris@nexus-tech.net>, Nexus Technologies, Inc.
 | 
				
			||||||
 * (C) 2002 Marius Groeger <mgroeger@sysgo.de>, Sysgo GmbH
 | 
					 * (C) 2002 Marius Groeger <mgroeger@sysgo.de>, Sysgo GmbH
 | 
				
			||||||
 * (C) 2003 Robert Schwebel <r.schwebel@pengutronix.de>, Pengutronix 
 | 
					 * (C) 2003 Robert Schwebel <r.schwebel@pengutronix.de>, Pengutronix
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * See file CREDITS for list of people who contributed to this
 | 
					 * See file CREDITS for list of people who contributed to this
 | 
				
			||||||
 * project.
 | 
					 * project.
 | 
				
			||||||
@ -66,7 +66,7 @@ int dram_init (void)
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/** 
 | 
					/**
 | 
				
			||||||
 * logodl_set_led: - switch LEDs on or off
 | 
					 * logodl_set_led: - switch LEDs on or off
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * @param led:   LED to switch (0,1)
 | 
					 * @param led:   LED to switch (0,1)
 | 
				
			||||||
@ -77,15 +77,15 @@ void logodl_set_led(int led, int state)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	switch(led) {
 | 
						switch(led) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case 0: 
 | 
						case 0:
 | 
				
			||||||
		if (state==1) { 
 | 
							if (state==1) {
 | 
				
			||||||
			CFG_LED_A_CR = CFG_LED_A_BIT;
 | 
								CFG_LED_A_CR = CFG_LED_A_BIT;
 | 
				
			||||||
		} else if (state==0) {
 | 
							} else if (state==0) {
 | 
				
			||||||
			CFG_LED_A_SR = CFG_LED_A_BIT;
 | 
								CFG_LED_A_SR = CFG_LED_A_BIT;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case 1: 
 | 
						case 1:
 | 
				
			||||||
		if (state==1) {
 | 
							if (state==1) {
 | 
				
			||||||
			CFG_LED_B_CR = CFG_LED_B_BIT;
 | 
								CFG_LED_B_CR = CFG_LED_B_BIT;
 | 
				
			||||||
		} else if (state==0) {
 | 
							} else if (state==0) {
 | 
				
			||||||
@ -93,7 +93,7 @@ void logodl_set_led(int led, int state)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	
 | 
					
 | 
				
			||||||
	return;
 | 
						return;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -101,9 +101,9 @@ void logodl_set_led(int led, int state)
 | 
				
			|||||||
/**
 | 
					/**
 | 
				
			||||||
 * show_boot_progress: - indicate state of the boot process
 | 
					 * show_boot_progress: - indicate state of the boot process
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * @param status: Status number - see README for details. 
 | 
					 * @param status: Status number - see README for details.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * The LOGOTRONIC does only have 2 LEDs, so we switch them on at the most 
 | 
					 * The LOGOTRONIC does only have 2 LEDs, so we switch them on at the most
 | 
				
			||||||
 * important states (1, 5, 15).
 | 
					 * important states (1, 5, 15).
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -44,11 +44,8 @@ unsigned long flash_init(void)
 | 
				
			|||||||
	int i;
 | 
						int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Init: no FLASHes known */
 | 
						/* Init: no FLASHes known */
 | 
				
			||||||
	for (i = 0; i < CFG_MAX_FLASH_BANKS; ++i) {
 | 
						for (i = 0; i < CFG_MAX_FLASH_BANKS; ++i)
 | 
				
			||||||
		flash_info[i].flash_id = FLASH_UNKNOWN;
 | 
							flash_info[i].flash_id = FLASH_UNKNOWN;
 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Static FLASH Bank configuration here - FIXME XXX */
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	size = flash_get_size((vu_long *) FLASH_BASE0_PRELIM, &flash_info[0]);
 | 
						size = flash_get_size((vu_long *) FLASH_BASE0_PRELIM, &flash_info[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -66,7 +63,22 @@ unsigned long flash_init(void)
 | 
				
			|||||||
	flash_get_offsets(CFG_FLASH_BASE, &flash_info[0]);
 | 
						flash_get_offsets(CFG_FLASH_BASE, &flash_info[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* monitor protection ON by default */
 | 
						/* monitor protection ON by default */
 | 
				
			||||||
	flash_protect(FLAG_PROTECT_SET, CFG_FLASH_BASE, CFG_FLASH_BASE + monitor_flash_len - 1, &flash_info[0]);
 | 
						flash_protect(FLAG_PROTECT_SET,
 | 
				
			||||||
 | 
								CFG_FLASH_BASE, CFG_FLASH_BASE + monitor_flash_len - 1,
 | 
				
			||||||
 | 
								&flash_info[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						flash_protect ( FLAG_PROTECT_SET,
 | 
				
			||||||
 | 
								CFG_ENV_ADDR,
 | 
				
			||||||
 | 
								CFG_ENV_ADDR + CFG_ENV_SIZE - 1,
 | 
				
			||||||
 | 
								&flash_info[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CFG_ENV_ADDR_REDUND
 | 
				
			||||||
 | 
						flash_protect ( FLAG_PROTECT_SET,
 | 
				
			||||||
 | 
								CFG_ENV_ADDR_REDUND,
 | 
				
			||||||
 | 
								CFG_ENV_ADDR_REDUND + CFG_ENV_SIZE_REDUND - 1,
 | 
				
			||||||
 | 
								&flash_info[0]);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	flash_info[0].size = size;
 | 
						flash_info[0].size = size;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -29,6 +29,17 @@
 | 
				
			|||||||
#include <common.h>
 | 
					#include <common.h>
 | 
				
			||||||
#include "mpc8xx.h"
 | 
					#include "mpc8xx.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					/* last value written to the external register; we cannot read back */
 | 
				
			||||||
 | 
					unsigned int last_er_val;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* some sane bit macros */
 | 
					/* some sane bit macros */
 | 
				
			||||||
#define _BD(_b)				(1U << (31-(_b)))
 | 
					#define _BD(_b)				(1U << (31-(_b)))
 | 
				
			||||||
#define _BDR(_l, _h)			(((((1U << (31-(_l))) - 1) << 1) | 1) & ~((1U << (31-(_h))) - 1))
 | 
					#define _BDR(_l, _h)			(((((1U << (31-(_l))) - 1) << 1) | 1) & ~((1U << (31-(_h))) - 1))
 | 
				
			||||||
@ -42,13 +53,11 @@
 | 
				
			|||||||
#define _B(_b)				_BD(_b)
 | 
					#define _B(_b)				_BD(_b)
 | 
				
			||||||
#define _BR(_l, _h)			_BDR(_l, _h)
 | 
					#define _BR(_l, _h)			_BDR(_l, _h)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* ------------------------------------------------------------------------- */
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					 | 
				
			||||||
/* ------------------------------------------------------------------------- */
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define _NOT_USED_	0xFFFFFFFF
 | 
					#define _NOT_USED_	0xFFFFFFFF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* ------------------------------------------------------------------------- */
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CS_0000		0x00000000
 | 
					#define CS_0000		0x00000000
 | 
				
			||||||
#define CS_0001		0x10000000
 | 
					#define CS_0001		0x10000000
 | 
				
			||||||
@ -208,7 +217,11 @@ const uint sdram_table[0x40] = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int checkboard(void)
 | 
					int checkboard(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	printf ("NETVIA\n");
 | 
					#if !defined(CONFIG_NETVIA_VERSION) || CONFIG_NETVIA_VERSION == 1
 | 
				
			||||||
 | 
						printf ("NETVIA v1\n");
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						printf ("NETVIA v2+\n");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	return (0);
 | 
						return (0);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -275,25 +288,6 @@ long int initdram(int board_type)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	udelay(10000);
 | 
						udelay(10000);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* do the ram test */
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
		register unsigned long *rp;
 | 
					 | 
				
			||||||
		register unsigned long v;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/* first fill */
 | 
					 | 
				
			||||||
		for (rp = (unsigned long *)0; rp < (unsigned long *)SDRAM_MAX_SIZE; )
 | 
					 | 
				
			||||||
		    *rp++ = (unsigned long)rp;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/* now check */
 | 
					 | 
				
			||||||
		for (rp = (unsigned long *)0; rp < (unsigned long *)SDRAM_MAX_SIZE; rp++) {
 | 
					 | 
				
			||||||
		    if ((v = *rp) != (unsigned long)rp) {
 | 
					 | 
				
			||||||
			printf("ERROR at 0x%lx (0x%lx)\n", (unsigned long)rp, v);
 | 
					 | 
				
			||||||
			return -1;
 | 
					 | 
				
			||||||
		    }
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return (size);
 | 
						return (size);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -301,74 +295,141 @@ long int initdram(int board_type)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int misc_init_r(void)
 | 
					int misc_init_r(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
						last_er_val = 0xffffffff;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	return(0);
 | 
						return(0);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* ------------------------------------------------------------------------- */
 | 
					/* ------------------------------------------------------------------------- */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GP = general purpose, SP = special purpose (on chip peripheral) */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* bits that can have a special purpose or can be configured as inputs/outputs */
 | 
					/* bits that can have a special purpose or can be configured as inputs/outputs */
 | 
				
			||||||
#define PA_MASK		(_BWR(4, 9) | _BWR(12, 15))
 | 
					 | 
				
			||||||
#define PA_ODR_MASK	(_BW(9) | _BW(12) | _BW(14))
 | 
					 | 
				
			||||||
#define PA_ODR_VAL	0
 | 
					 | 
				
			||||||
#define PA_GP_INMASK	0
 | 
					#define PA_GP_INMASK	0
 | 
				
			||||||
#define PA_GP_OUTMASK	(_BW(5) | _BW(14) | _BW(15))
 | 
					#define PA_GP_OUTMASK	(_BW(5) | _BWR(14, 15))
 | 
				
			||||||
#define PA_SP_OUTMASK	0
 | 
					#define PA_SP_MASK	(_BW(4) | _BWR(6, 13))
 | 
				
			||||||
 | 
					#define PA_ODR_VAL	0
 | 
				
			||||||
#define PA_GP_OUTVAL	_BW(5)
 | 
					#define PA_GP_OUTVAL	_BW(5)
 | 
				
			||||||
#define PA_SP_OUTVAL	0
 | 
					#define PA_SP_DIRVAL	0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PB_MASK		(_BR(16, 19) | _BR(22, 31))
 | 
					#define PB_GP_INMASK	_B(28)
 | 
				
			||||||
#define PB_ODR_MASK	PB_MASK
 | 
					#define PB_GP_OUTMASK	(_BR(16, 19) | _BR(26, 27) | _BR(29, 31))
 | 
				
			||||||
 | 
					#define PB_SP_MASK	_BR(22, 25)
 | 
				
			||||||
#define PB_ODR_VAL	0
 | 
					#define PB_ODR_VAL	0
 | 
				
			||||||
#define PB_GP_INMASK	0
 | 
					#define PB_GP_OUTVAL	(_BR(16, 19) | _BR(26, 27) | _BR(29, 31))
 | 
				
			||||||
#define PB_GP_OUTMASK	(_BR(16, 19) | _BR(26, 27) | _B(31))
 | 
					#define PB_SP_DIRVAL	0
 | 
				
			||||||
#define PB_SP_OUTMASK	_BR(28, 30)
 | 
					
 | 
				
			||||||
#define PB_SP_OUTVAL	_BR(28, 30)
 | 
					#if !defined(CONFIG_NETVIA_VERSION) || CONFIG_NETVIA_VERSION == 1
 | 
				
			||||||
#define PB_GP_OUTVAL	(_BR(16, 19) | _BR(26, 27) | _B(31))
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PC_MASK		_BWR(4, 15)
 | 
					 | 
				
			||||||
#define PC_SO_MASK	(_BWR(6, 11) | _BWR(14, 15))
 | 
					 | 
				
			||||||
#define PC_SO_VAL	0
 | 
					 | 
				
			||||||
#define PC_INT_MASK	PC_MASK
 | 
					 | 
				
			||||||
#define PC_INT_VAL	0
 | 
					 | 
				
			||||||
#define PC_GP_INMASK	(_BWR(5, 7) | _BWR(9, 10) | _BW(13))
 | 
					#define PC_GP_INMASK	(_BWR(5, 7) | _BWR(9, 10) | _BW(13))
 | 
				
			||||||
#define PC_GP_OUTMASK	_BW(12)
 | 
					#define PC_GP_OUTMASK	_BW(12)
 | 
				
			||||||
#define PC_SP_OUTMASK	0
 | 
					#define PC_SP_MASK	(_BW(4) | _BW(8))
 | 
				
			||||||
#define PC_SP_OUTVAL	_BW(12)
 | 
					#define PC_SOVAL	0
 | 
				
			||||||
 | 
					#define PC_INTVAL	0
 | 
				
			||||||
#define PC_GP_OUTVAL	0
 | 
					#define PC_GP_OUTVAL	0
 | 
				
			||||||
 | 
					#define PC_SP_DIRVAL	0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PD_MASK		_BWR(0, 15)
 | 
					 | 
				
			||||||
#define PD_GP_INMASK	0
 | 
					#define PD_GP_INMASK	0
 | 
				
			||||||
#define PD_GP_OUTMASK	_BWR(3, 15)
 | 
					#define PD_GP_OUTMASK	_BWR(3, 15)
 | 
				
			||||||
#define PD_SP_OUTMASK	0
 | 
					#define PD_SP_MASK	0
 | 
				
			||||||
#define PD_GP_OUTVAL	(_BW(3) | _BW(5) | _BW(7) | _BWR(8, 15))
 | 
					#define PD_GP_OUTVAL	(_BW(3) | _BW(5) | _BW(7) | _BWR(8, 15))
 | 
				
			||||||
#define PD_SP_OUTVAL	0
 | 
					#define PD_SP_DIRVAL	0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PC_GP_INMASK	(_BW(5) | _BW(7) | _BWR(9, 11) | _BWR(13, 15))
 | 
				
			||||||
 | 
					#define PC_GP_OUTMASK	(_BW(6) | _BW(12))
 | 
				
			||||||
 | 
					#define PC_SP_MASK	(_BW(4) | _BW(8))
 | 
				
			||||||
 | 
					#define PC_SOVAL	0
 | 
				
			||||||
 | 
					#define PC_INTVAL	_BW(7)
 | 
				
			||||||
 | 
					#define PC_GP_OUTVAL	(_BW(6) | _BW(12))
 | 
				
			||||||
 | 
					#define PC_SP_DIRVAL	0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PD_GP_INMASK	0
 | 
				
			||||||
 | 
					#define PD_GP_OUTMASK	_BWR(3, 15)
 | 
				
			||||||
 | 
					#define PD_SP_MASK	0
 | 
				
			||||||
 | 
					#define PD_GP_OUTVAL	(_BW(3) | _BW(5) | _BW(9) | _BW(11))
 | 
				
			||||||
 | 
					#define PD_SP_DIRVAL	0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#error Unknown NETVIA board version.
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int board_pre_init(void)
 | 
					int board_pre_init(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	register volatile immap_t *immap = (immap_t *) CFG_IMMR;
 | 
						volatile immap_t *immap = (immap_t *) CFG_IMMR;
 | 
				
			||||||
	register volatile iop8xx_t *ioport = &immap->im_ioport;
 | 
						volatile iop8xx_t *ioport = &immap->im_ioport;
 | 
				
			||||||
	register volatile cpm8xx_t *cpm = &immap->im_cpm;
 | 
						volatile cpm8xx_t *cpm = &immap->im_cpm;
 | 
				
			||||||
 | 
						volatile memctl8xx_t *memctl = &immap->im_memctl;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ioport->iop_padat = (ioport->iop_padat & ~PA_MASK)     | PA_SP_OUTVAL | PA_GP_OUTVAL;
 | 
						/* DSP0 chip select */
 | 
				
			||||||
	ioport->iop_paodr = (ioport->iop_paodr & ~PA_ODR_MASK) | PA_ODR_VAL;
 | 
						memctl->memc_or4 = ((0xFFFFFFFFLU & ~(DSP_SIZE - 1)) | OR_CSNT_SAM | OR_BI | OR_ACS_DIV2 | OR_SETA | OR_TRLX);
 | 
				
			||||||
	ioport->iop_padir = (ioport->iop_padir & ~PA_GP_INMASK)| PA_SP_OUTMASK | PA_GP_OUTMASK;
 | 
						memctl->memc_br4 = ((DSP0_BASE & BR_BA_MSK) | BR_PS_16 | BR_V);
 | 
				
			||||||
	ioport->iop_papar = (ioport->iop_papar & ~(PA_GP_INMASK & PA_GP_OUTMASK));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	cpm->cp_pbdat = (ioport->iop_padat & ~PB_MASK)     | PB_SP_OUTVAL | PB_GP_OUTVAL;
 | 
						/* DSP1 chip select */
 | 
				
			||||||
	cpm->cp_pbodr = (ioport->iop_paodr & ~PB_ODR_MASK) | PB_ODR_VAL;
 | 
						memctl->memc_or5 = ((0xFFFFFFFFLU & ~(DSP_SIZE - 1)) | OR_CSNT_SAM | OR_BI | OR_ACS_DIV2 | OR_SETA | OR_TRLX);
 | 
				
			||||||
	cpm->cp_pbdir = (ioport->iop_padir & ~PB_GP_INMASK)| PB_SP_OUTMASK | PB_GP_OUTMASK;
 | 
						memctl->memc_br5 = ((DSP1_BASE & BR_BA_MSK) | BR_PS_16 | BR_V);
 | 
				
			||||||
	cpm->cp_pbpar = (ioport->iop_papar & ~(PB_GP_INMASK & PB_GP_OUTMASK));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ioport->iop_pcdat = (ioport->iop_pcdat & ~PC_MASK)     | PC_SP_OUTVAL | PC_GP_OUTVAL;
 | 
						/* FPGA chip select */
 | 
				
			||||||
	ioport->iop_pcdir = (ioport->iop_pcdir & ~PC_GP_INMASK)| PC_SP_OUTMASK | PC_GP_OUTMASK;
 | 
						memctl->memc_or6 = ((0xFFFFFFFFLU & ~(FPGA_SIZE - 1)) | OR_BI | OR_SCY_1_CLK);
 | 
				
			||||||
	ioport->iop_pcso  = (ioport->iop_pcso  & ~PC_SO_MASK)  | PC_SO_VAL;
 | 
						memctl->memc_br6 = ((FPGA_BASE & BR_BA_MSK) | BR_PS_8 | BR_V);
 | 
				
			||||||
	ioport->iop_pcint = (ioport->iop_pcint & ~PC_INT_MASK) | PC_INT_VAL;
 | 
					 | 
				
			||||||
	ioport->iop_pcpar = (ioport->iop_pcpar & ~(PC_GP_INMASK & PC_GP_OUTMASK));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ioport->iop_pddat = (ioport->iop_pddat & ~PD_MASK)     | PD_SP_OUTVAL | PD_GP_OUTVAL;
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
	ioport->iop_pddir = (ioport->iop_pddir & ~PD_GP_INMASK)| PD_SP_OUTMASK | PD_GP_OUTMASK;
 | 
						/* NAND chip select */
 | 
				
			||||||
	ioport->iop_pdpar = (ioport->iop_pdpar & ~(PD_GP_INMASK & PD_GP_OUTMASK));
 | 
						memctl->memc_or1 = ((0xFFFFFFFFLU & ~(NAND_SIZE - 1)) | OR_CSNT_SAM | OR_BI | OR_SCY_8_CLK | OR_EHTR | OR_TRLX);
 | 
				
			||||||
 | 
						memctl->memc_br1 = ((NAND_BASE & BR_BA_MSK) | BR_PS_8 | BR_V);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* kill this chip select */
 | 
				
			||||||
 | 
						memctl->memc_br2 &= ~BR_V;	/* invalid */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* external reg chip select */
 | 
				
			||||||
 | 
						memctl->memc_or7 = ((0xFFFFFFFFLU & ~(ER_SIZE - 1)) | OR_BI | OR_SCY_4_CLK);
 | 
				
			||||||
 | 
						memctl->memc_br7 = ((ER_BASE & BR_BA_MSK) | BR_PS_32 | BR_V);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ioport->iop_padat	= PA_GP_OUTVAL;
 | 
				
			||||||
 | 
						ioport->iop_paodr	= PA_ODR_VAL;
 | 
				
			||||||
 | 
						ioport->iop_padir	= PA_GP_OUTMASK | PA_SP_DIRVAL;
 | 
				
			||||||
 | 
						ioport->iop_papar	= PA_SP_MASK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						cpm->cp_pbdat		= PB_GP_OUTVAL;
 | 
				
			||||||
 | 
						cpm->cp_pbodr		= PB_ODR_VAL;
 | 
				
			||||||
 | 
						cpm->cp_pbdir		= PB_GP_OUTMASK | PB_SP_DIRVAL;
 | 
				
			||||||
 | 
						cpm->cp_pbpar		= PB_SP_MASK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ioport->iop_pcdat	= PC_GP_OUTVAL;
 | 
				
			||||||
 | 
						ioport->iop_pcdir	= PC_GP_OUTMASK | PC_SP_DIRVAL;
 | 
				
			||||||
 | 
						ioport->iop_pcso	= PC_SOVAL;
 | 
				
			||||||
 | 
						ioport->iop_pcint	= PC_INTVAL;
 | 
				
			||||||
 | 
						ioport->iop_pcpar	= PC_SP_MASK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ioport->iop_pddat	= PD_GP_OUTVAL;
 | 
				
			||||||
 | 
						ioport->iop_pddir	= PD_GP_OUTMASK | PD_SP_DIRVAL;
 | 
				
			||||||
 | 
						ioport->iop_pdpar	= PD_SP_MASK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
						/* external register init */
 | 
				
			||||||
 | 
						*(volatile uint *)ER_BASE = 0xFFFFFFFF;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return 0;
 | 
						return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (CONFIG_COMMANDS & CFG_CMD_NAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <linux/mtd/nand.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					extern void nand_probe(ulong physadr);
 | 
				
			||||||
 | 
					extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void nand_init(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						nand_probe(CFG_NAND_BASE);
 | 
				
			||||||
 | 
						if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
 | 
				
			||||||
 | 
							nand_dev_desc[0].name = "NetVia NAND flash";
 | 
				
			||||||
 | 
							puts("NAND:  ");
 | 
				
			||||||
 | 
							print_size(nand_dev_desc[0].totlen, "\n");
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
				
			|||||||
@ -63,8 +63,8 @@ SECTIONS
 | 
				
			|||||||
    lib_ppc/cache.o		(.text)
 | 
					    lib_ppc/cache.o		(.text)
 | 
				
			||||||
    lib_ppc/time.o		(.text)
 | 
					    lib_ppc/time.o		(.text)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    . = env_offset;
 | 
					    . = DEFINED(env_offset) ? env_offset : .;
 | 
				
			||||||
    common/environment.o	(.ppcenv)
 | 
					    common/environment.o	(.text)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    *(.text)
 | 
					    *(.text)
 | 
				
			||||||
    *(.fixup)
 | 
					    *(.fixup)
 | 
				
			||||||
 | 
				
			|||||||
@ -26,7 +26,7 @@
 | 
				
			|||||||
#include <ppc_asm.tmpl>
 | 
					#include <ppc_asm.tmpl>
 | 
				
			||||||
#include <ppc_defs.h>
 | 
					#include <ppc_defs.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.globl	ull_write
 | 
						.globl	ull_write
 | 
				
			||||||
ull_write:
 | 
					ull_write:
 | 
				
			||||||
	lfd		0,0(r4)
 | 
						lfd		0,0(r4)
 | 
				
			||||||
	stfd	0,0(r3)
 | 
						stfd	0,0(r3)
 | 
				
			||||||
 | 
				
			|||||||
@ -494,14 +494,22 @@ static int scc_init(struct eth_device* dev, bd_t *bis)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(CONFIG_NETVIA)
 | 
					#if defined(CONFIG_NETVIA)
 | 
				
			||||||
#if defined(PB_ENET_PDN)
 | 
					#if defined(PA_ENET_PDN)
 | 
				
			||||||
 | 
					    immr->im_ioport.iop_papar &= ~PA_ENET_PDN;
 | 
				
			||||||
 | 
					    immr->im_ioport.iop_padir |=  PA_ENET_PDN;
 | 
				
			||||||
 | 
					    immr->im_ioport.iop_padat |=  PA_ENET_PDN;
 | 
				
			||||||
 | 
					#elif defined(PB_ENET_PDN)
 | 
				
			||||||
    immr->im_cpm.cp_pbpar &= ~PB_ENET_PDN;
 | 
					    immr->im_cpm.cp_pbpar &= ~PB_ENET_PDN;
 | 
				
			||||||
    immr->im_cpm.cp_pbdir |=  PB_ENET_PDN;
 | 
					    immr->im_cpm.cp_pbdir |=  PB_ENET_PDN;
 | 
				
			||||||
    immr->im_cpm.cp_pbdat |=  PB_ENET_PDN;
 | 
					    immr->im_cpm.cp_pbdat |=  PB_ENET_PDN;
 | 
				
			||||||
#elif defined(PC_ENET_PDN)
 | 
					#elif defined(PC_ENET_PDN)
 | 
				
			||||||
    immr->im_cpm.cp_pcpar &= ~PC_ENET_PDN;
 | 
					    immr->im_ioport.iop_pcpar &= ~PC_ENET_PDN;
 | 
				
			||||||
    immr->im_cpm.cp_pcdir |=  PC_ENET_PDN;
 | 
					    immr->im_ioport.iop_pcdir |=  PC_ENET_PDN;
 | 
				
			||||||
    immr->im_cpm.cp_pcdat |=  PC_ENET_PDN;
 | 
					    immr->im_ioport.iop_pcdat |=  PC_ENET_PDN;
 | 
				
			||||||
 | 
					#elif defined(PD_ENET_PDN)
 | 
				
			||||||
 | 
					    immr->im_ioport.iop_pdpar &= ~PD_ENET_PDN;
 | 
				
			||||||
 | 
					    immr->im_ioport.iop_pddir |=  PD_ENET_PDN;
 | 
				
			||||||
 | 
					    immr->im_ioport.iop_pddat |=  PD_ENET_PDN;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -37,6 +37,7 @@ OBJS	= 3c589.o 5701rls.o ali512x.o \
 | 
				
			|||||||
	  pci.o pci_auto.o pci_indirect.o \
 | 
						  pci.o pci_auto.o pci_indirect.o \
 | 
				
			||||||
	  pcnet.o plb2800_eth.o \
 | 
						  pcnet.o plb2800_eth.o \
 | 
				
			||||||
	  s3c24x0_i2c.o sed13806.o serial.o \
 | 
						  s3c24x0_i2c.o sed13806.o serial.o \
 | 
				
			||||||
 | 
						  serial_max3100.o \
 | 
				
			||||||
	  smc91111.o smiLynxEM.o              sym53c8xx.o \
 | 
						  smc91111.o smiLynxEM.o              sym53c8xx.o \
 | 
				
			||||||
	  ti_pci1410a.o tigon3.o w83c553f.o \
 | 
						  ti_pci1410a.o tigon3.o w83c553f.o \
 | 
				
			||||||
	  status_led.o
 | 
						  status_led.o
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										301
									
								
								drivers/serial_max3100.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										301
									
								
								drivers/serial_max3100.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,301 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * (C) Copyright 2003
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Pantelis Antoniou <panto@intracom.gr>
 | 
				
			||||||
 | 
					 * Intracom S.A.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * See file CREDITS for list of people who contributed to this
 | 
				
			||||||
 | 
					 * project.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 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
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <common.h>
 | 
				
			||||||
 | 
					#include <watchdog.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CONFIG_MAX3100_SERIAL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* convienient macros */
 | 
				
			||||||
 | 
					#define MAX3100_SPI_RXD() (MAX3100_SPI_RXD_PORT & MAX3100_SPI_RXD_BIT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_SPI_TXD(x) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							if (x) \
 | 
				
			||||||
 | 
								MAX3100_SPI_TXD_PORT |=  MAX3100_SPI_TXD_BIT; \
 | 
				
			||||||
 | 
							else \
 | 
				
			||||||
 | 
								MAX3100_SPI_TXD_PORT &= ~MAX3100_SPI_TXD_BIT; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_SPI_CLK(x) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							if (x) \
 | 
				
			||||||
 | 
								MAX3100_SPI_CLK_PORT |=  MAX3100_SPI_CLK_BIT; \
 | 
				
			||||||
 | 
							else \
 | 
				
			||||||
 | 
								MAX3100_SPI_CLK_PORT &= ~MAX3100_SPI_CLK_BIT; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_SPI_CLK_TOGGLE() (MAX3100_SPI_CLK_PORT ^= MAX3100_SPI_CLK_BIT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_CS(x) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							if (x) \
 | 
				
			||||||
 | 
								MAX3100_CS_PORT |=  MAX3100_CS_BIT; \
 | 
				
			||||||
 | 
							else \
 | 
				
			||||||
 | 
								MAX3100_CS_PORT &= ~MAX3100_CS_BIT; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* MAX3100 definitions */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_WC	(3 << 14)		/* write configuration */
 | 
				
			||||||
 | 
					#define MAX3100_RC	(1 << 14)		/* read  configuration */
 | 
				
			||||||
 | 
					#define MAX3100_WD	(2 << 14)		/* write data          */
 | 
				
			||||||
 | 
					#define MAX3100_RD	(0 << 14)		/* read  data          */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* configuration register bits */
 | 
				
			||||||
 | 
					#define MAX3100_FEN	(1 << 13)		/* FIFO enable           */
 | 
				
			||||||
 | 
					#define MAX3100_SHDN    (1 << 12)		/* shutdown bit          */
 | 
				
			||||||
 | 
					#define MAX3100_TM	(1 << 11)		/* T bit irq mask        */
 | 
				
			||||||
 | 
					#define MAX3100_RM	(1 << 10)		/* R bit irq mask        */
 | 
				
			||||||
 | 
					#define MAX3100_PM	(1 <<  9)		/* P bit irq mask        */
 | 
				
			||||||
 | 
					#define MAX3100_RAM	(1 <<  8)		/* mask for RA/FE bit    */
 | 
				
			||||||
 | 
					#define MAX3100_IR	(1 <<  7)		/* IRDA timing mode      */
 | 
				
			||||||
 | 
					#define MAX3100_ST	(1 <<  6)		/* transmit stop bit     */
 | 
				
			||||||
 | 
					#define MAX3100_PE	(1 <<  5)		/* parity enable bit     */
 | 
				
			||||||
 | 
					#define MAX3100_L	(1 <<  4)		/* Length bit            */
 | 
				
			||||||
 | 
					#define MAX3100_B_MASK	(0x000F)		/* baud rate bits mask   */
 | 
				
			||||||
 | 
					#define MAX3100_B(x)	((x) & 0x000F)	/* baud rate select bits */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* data register bits (write) */
 | 
				
			||||||
 | 
					#define MAX3100_TE	(1 << 10)		/* transmit enable bit (active low)        */
 | 
				
			||||||
 | 
					#define MAX3100_RTS	(1 <<  9)		/* request-to-send bit (inverted ~RTS pin) */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* data register bits (read) */
 | 
				
			||||||
 | 
					#define MAX3100_RA	(1 << 10)		/* receiver activity when in shutdown mode */
 | 
				
			||||||
 | 
					#define MAX3100_FE	(1 << 10)		/* framing error when in normal mode       */
 | 
				
			||||||
 | 
					#define MAX3100_CTS	(1 <<  9)		/* clear-to-send bit (inverted ~CTS pin)   */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* data register bits (both directions) */
 | 
				
			||||||
 | 
					#define MAX3100_R 	(1 << 15)		/* receive bit    */
 | 
				
			||||||
 | 
					#define MAX3100_T	(1 << 14)		/* transmit bit   */
 | 
				
			||||||
 | 
					#define MAX3100_P	(1 <<  8)		/* parity bit     */
 | 
				
			||||||
 | 
					#define MAX3100_D_MASK	0x00FF                  /* data bits mask */
 | 
				
			||||||
 | 
					#define MAX3100_D(x)	((x) & 0x00FF)		/* data bits      */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* these definitions are valid only for fOSC = 3.6864MHz */
 | 
				
			||||||
 | 
					#define MAX3100_B_230400        MAX3100_B(0)
 | 
				
			||||||
 | 
					#define MAX3100_B_115200        MAX3100_B(1)
 | 
				
			||||||
 | 
					#define MAX3100_B_57600         MAX3100_B(2)
 | 
				
			||||||
 | 
					#define MAX3100_B_38400         MAX3100_B(9)
 | 
				
			||||||
 | 
					#define MAX3100_B_19200         MAX3100_B(10)
 | 
				
			||||||
 | 
					#define MAX3100_B_9600          MAX3100_B(11)
 | 
				
			||||||
 | 
					#define MAX3100_B_4800          MAX3100_B(12)
 | 
				
			||||||
 | 
					#define MAX3100_B_2400          MAX3100_B(13)
 | 
				
			||||||
 | 
					#define MAX3100_B_1200          MAX3100_B(14)
 | 
				
			||||||
 | 
					#define MAX3100_B_600           MAX3100_B(15)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline unsigned int max3100_transfer(unsigned int val)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int rx;
 | 
				
			||||||
 | 
						int b;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						MAX3100_SPI_CLK(0);
 | 
				
			||||||
 | 
						MAX3100_CS(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						rx = 0; b = 16;
 | 
				
			||||||
 | 
						while (--b >= 0) {
 | 
				
			||||||
 | 
							MAX3100_SPI_TXD(val & 0x8000);
 | 
				
			||||||
 | 
							val <<= 1;
 | 
				
			||||||
 | 
							MAX3100_SPI_CLK_TOGGLE();
 | 
				
			||||||
 | 
							udelay(1);
 | 
				
			||||||
 | 
							rx <<= 1;
 | 
				
			||||||
 | 
							if (MAX3100_SPI_RXD())
 | 
				
			||||||
 | 
								rx |= 1;
 | 
				
			||||||
 | 
							MAX3100_SPI_CLK_TOGGLE();
 | 
				
			||||||
 | 
							udelay(1);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						MAX3100_SPI_CLK(1);
 | 
				
			||||||
 | 
						MAX3100_CS(1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return rx;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* must be power of 2 */
 | 
				
			||||||
 | 
					#define RXFIFO_SZ	16
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int rxfifo_cnt;
 | 
				
			||||||
 | 
					static int rxfifo_in;
 | 
				
			||||||
 | 
					static int rxfifo_out;
 | 
				
			||||||
 | 
					static unsigned char rxfifo_buf[16];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void max3100_putc(int c)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int rx;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						while (((rx = max3100_transfer(MAX3100_RC)) & MAX3100_T) == 0)
 | 
				
			||||||
 | 
							WATCHDOG_RESET();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						rx = max3100_transfer(MAX3100_WD | (c & 0xff));
 | 
				
			||||||
 | 
						if ((rx & MAX3100_RD) != 0 && rxfifo_cnt < RXFIFO_SZ) {
 | 
				
			||||||
 | 
							rxfifo_cnt++;
 | 
				
			||||||
 | 
							rxfifo_buf[rxfifo_in++] = rx & 0xff;
 | 
				
			||||||
 | 
							rxfifo_in &= RXFIFO_SZ - 1;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int max3100_getc(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						int c;
 | 
				
			||||||
 | 
						unsigned int rx;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						while (rxfifo_cnt == 0) {
 | 
				
			||||||
 | 
							rx = max3100_transfer(MAX3100_RD);
 | 
				
			||||||
 | 
							if ((rx & MAX3100_R) != 0) {
 | 
				
			||||||
 | 
								do {
 | 
				
			||||||
 | 
									rxfifo_cnt++;
 | 
				
			||||||
 | 
									rxfifo_buf[rxfifo_in++] = rx & 0xff;
 | 
				
			||||||
 | 
									rxfifo_in &= RXFIFO_SZ - 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (rxfifo_cnt >= RXFIFO_SZ)
 | 
				
			||||||
 | 
										break;
 | 
				
			||||||
 | 
								} while (((rx = max3100_transfer(MAX3100_RD)) & MAX3100_R) != 0);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							WATCHDOG_RESET();
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						rxfifo_cnt--;
 | 
				
			||||||
 | 
						c = rxfifo_buf[rxfifo_out++];
 | 
				
			||||||
 | 
						rxfifo_out &= RXFIFO_SZ - 1;
 | 
				
			||||||
 | 
						return c;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int max3100_tstc(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int rx;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (rxfifo_cnt > 0)
 | 
				
			||||||
 | 
							return 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						rx = max3100_transfer(MAX3100_RD);
 | 
				
			||||||
 | 
						if ((rx & MAX3100_R) == 0)
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						do {
 | 
				
			||||||
 | 
							rxfifo_cnt++;
 | 
				
			||||||
 | 
							rxfifo_buf[rxfifo_in++] = rx & 0xff;
 | 
				
			||||||
 | 
							rxfifo_in &= RXFIFO_SZ - 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (rxfifo_cnt >= RXFIFO_SZ)
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
						} while (((rx = max3100_transfer(MAX3100_RD)) & MAX3100_R) != 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return 1;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int serial_init(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int wconf, rconf;
 | 
				
			||||||
 | 
						int i;
 | 
				
			||||||
 | 
						DECLARE_GLOBAL_DATA_PTR;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						wconf = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* Set baud rate */
 | 
				
			||||||
 | 
						switch (gd->baudrate) {
 | 
				
			||||||
 | 
							case 1200:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_1200;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 2400:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_2400;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 4800:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_4800;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 9600:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_9600;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 19200:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_19200;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 38400:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_38400;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 57600:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_57600;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							default:
 | 
				
			||||||
 | 
							case 115200:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_115200;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							case 230400:
 | 
				
			||||||
 | 
								wconf = MAX3100_B_230400;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* try for 10ms, with a 100us gap */
 | 
				
			||||||
 | 
						for (i = 0; i < 10000; i += 100) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							max3100_transfer(MAX3100_WC | wconf);
 | 
				
			||||||
 | 
							rconf = max3100_transfer(MAX3100_RC) & 0x3fff;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (rconf == wconf)
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							udelay(100);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						rxfifo_in = rxfifo_out = rxfifo_cnt = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return (0);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void serial_putc(const char c)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (c == '\n')
 | 
				
			||||||
 | 
							max3100_putc('\r');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						max3100_putc(c);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void serial_puts(const char *s)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						while (*s)
 | 
				
			||||||
 | 
							serial_putc (*s++);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int serial_getc(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return max3100_getc();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int serial_tstc(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return max3100_tstc();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* XXX WTF? */
 | 
				
			||||||
 | 
					void serial_setbrg(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
@ -1191,7 +1191,12 @@ typedef struct scc_enet {
 | 
				
			|||||||
#define PA_ENET_RCLK	((ushort)0x0200)	/* PA  6 */
 | 
					#define PA_ENET_RCLK	((ushort)0x0200)	/* PA  6 */
 | 
				
			||||||
#define PA_ENET_TCLK	((ushort)0x0800)	/* PA  4 */
 | 
					#define PA_ENET_TCLK	((ushort)0x0800)	/* PA  4 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PB_ENET_PDN	((ushort)0x4000)	/* PB 17 */
 | 
					#if !defined(CONFIG_NETVIA_VERSION) || CONFIG_NETVIA_VERSION == 1
 | 
				
			||||||
 | 
					# define PB_ENET_PDN	((ushort)0x4000)	/* PB 17 */
 | 
				
			||||||
 | 
					#elif CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					# define PC_ENET_PDN	((ushort)0x0008)	/* PC 12 */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PB_ENET_TENA	((ushort)0x2000)	/* PB 18 */
 | 
					#define PB_ENET_TENA	((ushort)0x2000)	/* PB 18 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PC_ENET_CLSN	((ushort)0x0040)	/* PC  9 */
 | 
					#define PC_ENET_CLSN	((ushort)0x0040)	/* PC  9 */
 | 
				
			||||||
 | 
				
			|||||||
@ -38,9 +38,15 @@
 | 
				
			|||||||
#define CONFIG_NETVIA		1	/* ...on a NetVia board		*/
 | 
					#define CONFIG_NETVIA		1	/* ...on a NetVia board		*/
 | 
				
			||||||
#undef  CONFIG_NETVIA_PLL_CLOCK		/* PLL or fixed crystal clock	*/
 | 
					#undef  CONFIG_NETVIA_PLL_CLOCK		/* PLL or fixed crystal clock	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if !defined(CONFIG_NETVIA_VERSION) || CONFIG_NETVIA_VERSION == 1
 | 
				
			||||||
#define	CONFIG_8xx_CONS_SMC1	1	/* Console is on SMC1		*/
 | 
					#define	CONFIG_8xx_CONS_SMC1	1	/* Console is on SMC1		*/
 | 
				
			||||||
#undef	CONFIG_8xx_CONS_SMC2
 | 
					#undef	CONFIG_8xx_CONS_SMC2
 | 
				
			||||||
#undef	CONFIG_8xx_CONS_NONE
 | 
					#undef	CONFIG_8xx_CONS_NONE
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define CONFIG_8xx_CONS_NONE
 | 
				
			||||||
 | 
					#define CONFIG_MAX3100_SERIAL
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_BAUDRATE		115200	/* console baudrate = 115kbps	*/
 | 
					#define CONFIG_BAUDRATE		115200	/* console baudrate = 115kbps	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CONFIG_NETVIA_PLL_CLOCK
 | 
					#ifdef CONFIG_NETVIA_PLL_CLOCK
 | 
				
			||||||
@ -76,17 +82,28 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#define	CONFIG_STATUS_LED	1	/* Status LED enabled		*/
 | 
					#define	CONFIG_STATUS_LED	1	/* Status LED enabled		*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					#define CONFIG_BOARD_SPECIFIC_LED	/* version has board specific leds */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef	CONFIG_CAN_DRIVER		/* CAN Driver support disabled	*/
 | 
					#undef	CONFIG_CAN_DRIVER		/* CAN Driver support disabled	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_BOOTP_MASK	(CONFIG_BOOTP_DEFAULT | CONFIG_BOOTP_BOOTFILESIZE)
 | 
					#define CONFIG_BOOTP_MASK		(CONFIG_BOOTP_DEFAULT | CONFIG_BOOTP_BOOTFILESIZE | CONFIG_BOOTP_NISDOMAIN)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef CONFIG_MAC_PARTITION
 | 
					#undef CONFIG_MAC_PARTITION
 | 
				
			||||||
#undef CONFIG_DOS_PARTITION
 | 
					#undef CONFIG_DOS_PARTITION
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define	CONFIG_RTC_MPC8xx		/* use internal RTC of MPC8xx	*/
 | 
					#define	CONFIG_RTC_MPC8xx		/* use internal RTC of MPC8xx	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_COMMANDS	      ( CONFIG_CMD_DFL	| \
 | 
					#define CONFIG_COMMANDS_BASE  ( CONFIG_CMD_DFL	| \
 | 
				
			||||||
				CFG_CMD_DHCP	)
 | 
									CFG_CMD_DHCP	| \
 | 
				
			||||||
 | 
									CFG_CMD_PING )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					#define CONFIG_COMMANDS		(CONFIG_COMMANDS_BASE | CFG_CMD_NAND)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define CONFIG_COMMANDS		CONFIG_COMMANDS_BASE
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_BOARD_PRE_INIT
 | 
					#define CONFIG_BOARD_PRE_INIT
 | 
				
			||||||
#define CONFIG_MISC_INIT_R
 | 
					#define CONFIG_MISC_INIT_R
 | 
				
			||||||
@ -168,10 +185,16 @@
 | 
				
			|||||||
#define CFG_FLASH_WRITE_TOUT	500	/* Timeout for Flash Write (in ms)	*/
 | 
					#define CFG_FLASH_WRITE_TOUT	500	/* Timeout for Flash Write (in ms)	*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define	CFG_ENV_IS_IN_FLASH	1
 | 
					#define	CFG_ENV_IS_IN_FLASH	1
 | 
				
			||||||
#define	CFG_ENV_OFFSET		0x8000	/*   Offset   of Environment Sector	*/
 | 
					 | 
				
			||||||
#define	CFG_ENV_SIZE		0x1000	/* Total Size of Environment Sector	*/
 | 
					 | 
				
			||||||
#define CFG_ENV_SECT_SIZE	0x10000
 | 
					#define CFG_ENV_SECT_SIZE	0x10000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define	CFG_ENV_ADDR		(CFG_FLASH_BASE + 0x60000)
 | 
				
			||||||
 | 
					#define CFG_ENV_OFFSET		0
 | 
				
			||||||
 | 
					#define	CFG_ENV_SIZE		0x4000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CFG_ENV_ADDR_REDUND	(CFG_FLASH_BASE + 0x70000)
 | 
				
			||||||
 | 
					#define CFG_ENV_OFFSET_REDUND	0
 | 
				
			||||||
 | 
					#define CFG_ENV_SIZE_REDUND	CFG_ENV_SIZE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*-----------------------------------------------------------------------
 | 
					/*-----------------------------------------------------------------------
 | 
				
			||||||
 * Cache Configuration
 | 
					 * Cache Configuration
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@ -276,22 +299,6 @@
 | 
				
			|||||||
#define CFG_OR0_PRELIM	(CFG_PRELIM_OR_AM | CFG_OR_TIMING_FLASH)
 | 
					#define CFG_OR0_PRELIM	(CFG_PRELIM_OR_AM | CFG_OR_TIMING_FLASH)
 | 
				
			||||||
#define CFG_BR0_PRELIM	((FLASH_BASE0_PRELIM & BR_BA_MSK) | BR_PS_8 | BR_V )
 | 
					#define CFG_BR0_PRELIM	((FLASH_BASE0_PRELIM & BR_BA_MSK) | BR_PS_8 | BR_V )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					 | 
				
			||||||
 * BR1/2 and OR1/2 (4MByte Flash Bank x 2)
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
#define FLASH0_SIZE	0x00400000	/* 4MByte */
 | 
					 | 
				
			||||||
#define FLASH0_BASE	0xF0000000
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define CFG_OR1_PRELIM	((0xFFFFFFFFLU & ~(FLASH0_SIZE - 1)) | OR_CSNT_SAM | OR_BI | OR_SCY_5_CLK | OR_TRLX)
 | 
					 | 
				
			||||||
#define CFG_BR1_PRELIM	((FLASH0_BASE & BR_BA_MSK) | BR_PS_32 | BR_V)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define FLASH1_SIZE	0x00400000
 | 
					 | 
				
			||||||
#define FLASH1_BASE	0xF0400000
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define CFG_OR2_PRELIM	((0xFFFFFFFFLU & ~(FLASH1_SIZE - 1)) | OR_CSNT_SAM | OR_BI | OR_SCY_5_CLK | OR_TRLX)
 | 
					 | 
				
			||||||
#define CFG_BR2_PRELIM	((FLASH1_BASE & BR_BA_MSK) | BR_PS_32 | BR_V)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * BR3 and OR3 (SDRAM)
 | 
					 * BR3 and OR3 (SDRAM)
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
@ -305,16 +312,6 @@
 | 
				
			|||||||
#define CFG_OR3_PRELIM	((0xFFFFFFFFLU & ~(SDRAM_MAX_SIZE - 1)) | CFG_OR_TIMING_SDRAM)
 | 
					#define CFG_OR3_PRELIM	((0xFFFFFFFFLU & ~(SDRAM_MAX_SIZE - 1)) | CFG_OR_TIMING_SDRAM)
 | 
				
			||||||
#define CFG_BR3_PRELIM	((SDRAM_BASE3_PRELIM & BR_BA_MSK) | BR_MS_UPMA | BR_PS_32 | BR_V)
 | 
					#define CFG_BR3_PRELIM	((SDRAM_BASE3_PRELIM & BR_BA_MSK) | BR_MS_UPMA | BR_PS_32 | BR_V)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					 | 
				
			||||||
 * BR6 (External register)
 | 
					 | 
				
			||||||
 * 16 bit port size - leds are at high 8 bits
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
#define EXTREG_BASE			0x30000000	/* external register				*/
 | 
					 | 
				
			||||||
#define EXTREG_SIZE			0x00010000	/* max 64K							*/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define CFG_OR6_PRELIM		((0xFFFFFFFFLU & ~(EXTREG_SIZE - 1)) | OR_CSNT_SAM | OR_BI | OR_SCY_15_CLK | OR_TRLX)
 | 
					 | 
				
			||||||
#define CFG_BR6_PRELIM		((EXTREG_BASE & BR_BA_MSK) | BR_PS_32 | BR_V)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Memory Periodic Timer Prescaler
 | 
					 * Memory Periodic Timer Prescaler
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@ -347,4 +344,183 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#define CONFIG_ARTOS			/* include ARTOS support */
 | 
					#define CONFIG_ARTOS			/* include ARTOS support */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define DSP_SIZE	0x00010000	/* 64K */
 | 
				
			||||||
 | 
					#define FPGA_SIZE	0x00010000	/* 64K */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define DSP0_BASE	0xF1000000
 | 
				
			||||||
 | 
					#define DSP1_BASE	(DSP0_BASE + DSP_SIZE)
 | 
				
			||||||
 | 
					#define FPGA_BASE	(DSP1_BASE + DSP_SIZE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define ER_SIZE		0x00010000	/* 64K */
 | 
				
			||||||
 | 
					#define ER_BASE		(FPGA_BASE + FPGA_SIZE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_SIZE	0x00010000	/* 64K */
 | 
				
			||||||
 | 
					#define NAND_BASE	(ER_BASE + ER_SIZE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define STATUS_LED_BIT		0x00000001		/* bit 31 */
 | 
				
			||||||
 | 
					#define STATUS_LED_PERIOD	(CFG_HZ / 2)
 | 
				
			||||||
 | 
					#define STATUS_LED_STATE	STATUS_LED_BLINKING
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define STATUS_LED_BIT1		0x00000002		/* bit 30 */
 | 
				
			||||||
 | 
					#define STATUS_LED_PERIOD1	(CFG_HZ / 2)
 | 
				
			||||||
 | 
					#define STATUS_LED_STATE1	STATUS_LED_OFF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define STATUS_LED_ACTIVE	0		/* LED on for bit == 0	*/
 | 
				
			||||||
 | 
					#define STATUS_LED_BOOT		0		/* LED 0 used for boot status */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*****************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* NAND */
 | 
				
			||||||
 | 
					#define CFG_NAND_BASE			NAND_BASE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CONFIG_MTD_NAND_ECC_JFFS2	1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CFG_MAX_NAND_DEVICE		1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SECTORSIZE		512
 | 
				
			||||||
 | 
					#define ADDR_COLUMN		1
 | 
				
			||||||
 | 
					#define ADDR_PAGE		2
 | 
				
			||||||
 | 
					#define ADDR_COLUMN_PAGE	3
 | 
				
			||||||
 | 
					#define NAND_ChipID_UNKNOWN 	0x00
 | 
				
			||||||
 | 
					#define NAND_MAX_FLOORS		1
 | 
				
			||||||
 | 
					#define NAND_MAX_CHIPS		1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_DISABLE_CE(nand) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat) |=  0x0040; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_ENABLE_CE(nand) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat) &= ~0x0040; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_CTL_CLRALE(nandptr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat) &= ~0x0100; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_CTL_SETALE(nandptr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat) |=  0x0100; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_CTL_CLRCLE(nandptr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat) &= ~0x0080; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_CTL_SETCLE(nandptr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat) |=  0x0080; \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAND_WAIT_READY(nand) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							while ((((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pcdat & 0x100) == 0) \
 | 
				
			||||||
 | 
								; \
 | 
				
			||||||
 | 
						} while (0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define WRITE_NAND_COMMAND(d, adr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							*(volatile unsigned char *)((unsigned long)(adr)) = (unsigned char)(d); \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define WRITE_NAND_ADDRESS(d, adr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							*(volatile unsigned char *)((unsigned long)(adr)) = (unsigned char)(d); \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define WRITE_NAND(d, adr) \
 | 
				
			||||||
 | 
						do { \
 | 
				
			||||||
 | 
							*(volatile unsigned char *)((unsigned long)(adr)) = (unsigned char)(d); \
 | 
				
			||||||
 | 
						} while(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define READ_NAND(adr) \
 | 
				
			||||||
 | 
						((unsigned char)(*(volatile unsigned char *)(unsigned long)(adr)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*****************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __ASSEMBLY__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(CONFIG_NETVIA_VERSION) && CONFIG_NETVIA_VERSION >= 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* LEDs */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* last value written to the external register; we cannot read back */
 | 
				
			||||||
 | 
					extern unsigned int last_er_val;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* led_id_t is unsigned long mask */
 | 
				
			||||||
 | 
					typedef unsigned int led_id_t;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline void __led_init(led_id_t mask, int state)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int new_er_val;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (state)
 | 
				
			||||||
 | 
							new_er_val = last_er_val & ~mask;
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							new_er_val = last_er_val |  mask;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						*(volatile unsigned int *)ER_BASE = new_er_val;
 | 
				
			||||||
 | 
						last_er_val = new_er_val;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline void __led_toggle(led_id_t mask)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int new_er_val;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						new_er_val = last_er_val ^ mask;
 | 
				
			||||||
 | 
						*(volatile unsigned int *)ER_BASE = new_er_val;
 | 
				
			||||||
 | 
						last_er_val = new_er_val;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline void __led_set(led_id_t mask, int state)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int new_er_val;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (state)
 | 
				
			||||||
 | 
							new_er_val = last_er_val & ~mask;
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							new_er_val = last_er_val |  mask;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						*(volatile unsigned int *)ER_BASE = new_er_val;
 | 
				
			||||||
 | 
						last_er_val = new_er_val;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* MAX3100 console */
 | 
				
			||||||
 | 
					#define MAX3100_SPI_RXD_PORT	(((volatile immap_t *)CFG_IMMR)->im_cpm.cp_pbdat)
 | 
				
			||||||
 | 
					#define MAX3100_SPI_RXD_BIT	0x00000008
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_SPI_TXD_PORT	(((volatile immap_t *)CFG_IMMR)->im_cpm.cp_pbdat)
 | 
				
			||||||
 | 
					#define MAX3100_SPI_TXD_BIT	0x00000004
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_SPI_CLK_PORT	(((volatile immap_t *)CFG_IMMR)->im_cpm.cp_pbdat)
 | 
				
			||||||
 | 
					#define MAX3100_SPI_CLK_BIT	0x00000002
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MAX3100_CS_PORT		(((volatile immap_t *)CFG_IMMR)->im_ioport.iop_pddat)
 | 
				
			||||||
 | 
					#define MAX3100_CS_BIT		0x0010
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif	/* __CONFIG_H */
 | 
					#endif	/* __CONFIG_H */
 | 
				
			||||||
 | 
				
			|||||||
@ -63,17 +63,17 @@
 | 
				
			|||||||
#define CONFIG_BAUDRATE		19200
 | 
					#define CONFIG_BAUDRATE		19200
 | 
				
			||||||
#undef  CONFIG_MISC_INIT_R		/* not used yet                     */
 | 
					#undef  CONFIG_MISC_INIT_R		/* not used yet                     */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_COMMANDS		(CONFIG_CMD_DFL & ~CFG_CMD_NET)
 | 
					#define CONFIG_COMMANDS (CFG_CMD_BDI|CFG_CMD_LOADB|CFG_CMD_IMI|CFG_CMD_FLASH|CFG_CMD_MEMORY|CFG_CMD_NET|CFG_CMD_ENV|CFG_CMD_RUN|CFG_CMD_ASKENV|CFG_CMD_ECHO|CFG_CMD_DHCP|CFG_CMD_CACHE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
 | 
					/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
 | 
				
			||||||
#include <cmd_confdefs.h>
 | 
					#include <cmd_confdefs.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_BOOTDELAY	3
 | 
					#define CONFIG_BOOTDELAY	3
 | 
				
			||||||
#define CONFIG_BOOTARGS		"console=ttyS0,19200 ip=dhcp root=/dev/nfs, ether=0,0x08000000,eth0"
 | 
					#define CONFIG_BOOTARGS		"console=ttyS0,19200 ip=192.168.1.10,192.168.1.5,,255,255,255,0,csb root=/dev/nfs, ether=0,0x08000000,eth0"
 | 
				
			||||||
#define CONFIG_ETHADDR		FF:FF:FF:FF:FF:FF
 | 
					#define CONFIG_ETHADDR		FF:FF:FF:FF:FF:FF
 | 
				
			||||||
#define CONFIG_NETMASK		255.255.255.0
 | 
					#define CONFIG_NETMASK		255.255.255.0
 | 
				
			||||||
#define CONFIG_IPADDR		192.168.1.56
 | 
					#define CONFIG_IPADDR		192.168.1.56
 | 
				
			||||||
#define CONFIG_SERVERIP		192.168.1.2
 | 
					#define CONFIG_SERVERIP		192.168.1.5
 | 
				
			||||||
#define CONFIG_BOOTCOMMAND	"bootm 0x40000"
 | 
					#define CONFIG_BOOTCOMMAND	"bootm 0x40000"
 | 
				
			||||||
#define CONFIG_SHOW_BOOT_PROGRESS
 | 
					#define CONFIG_SHOW_BOOT_PROGRESS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -125,6 +125,13 @@
 | 
				
			|||||||
                                                /* valid baudrates */
 | 
					                                                /* valid baudrates */
 | 
				
			||||||
#define CFG_BAUDRATE_TABLE      { 9600, 19200, 38400, 57600, 115200 }
 | 
					#define CFG_BAUDRATE_TABLE      { 9600, 19200, 38400, 57600, 115200 }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Network chip
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CONFIG_DRIVER_CS8900	1
 | 
				
			||||||
 | 
					#define CS8900_BUS32		1
 | 
				
			||||||
 | 
					#define CS8900_BASE		0x08000000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Stack sizes
 | 
					 * Stack sizes
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
@ -151,24 +158,275 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#define CFG_FLASH_BASE          PHYS_FLASH_1
 | 
					#define CFG_FLASH_BASE          PHYS_FLASH_1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# if 0
 | 
				
			||||||
 | 
					/* FIXME: switch to _documented_ registers */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * GPIO settings
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * GP15 == nCS1      is 1
 | 
				
			||||||
 | 
					 * GP24 == SFRM      is 1
 | 
				
			||||||
 | 
					 * GP25 == TXD       is 1
 | 
				
			||||||
 | 
					 * GP33 == nCS5      is 1
 | 
				
			||||||
 | 
					 * GP39 == FFTXD     is 1
 | 
				
			||||||
 | 
					 * GP41 == RTS       is 1
 | 
				
			||||||
 | 
					 * GP47 == TXD       is 1
 | 
				
			||||||
 | 
					 * GP49 == nPWE      is 1
 | 
				
			||||||
 | 
					 * GP62 == LED_B     is 1
 | 
				
			||||||
 | 
					 * GP63 == TDM_OE    is 1
 | 
				
			||||||
 | 
					 * GP78 == nCS2      is 1
 | 
				
			||||||
 | 
					 * GP79 == nCS3      is 1
 | 
				
			||||||
 | 
					 * GP80 == nCS4      is 1
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_GPSR0_VAL       0x03008000
 | 
				
			||||||
 | 
					#define CFG_GPSR1_VAL       0xC0028282
 | 
				
			||||||
 | 
					#define CFG_GPSR2_VAL       0x0001C000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GP02 == DON_RST   is 0
 | 
				
			||||||
 | 
					 * GP23 == SCLK      is 0
 | 
				
			||||||
 | 
					 * GP45 == USB_ACT   is 0
 | 
				
			||||||
 | 
					 * GP60 == PLLEN     is 0
 | 
				
			||||||
 | 
					 * GP61 == LED_A     is 0
 | 
				
			||||||
 | 
					 * GP73 == SWUPD_LED is 0
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_GPCR0_VAL       0x00800004
 | 
				
			||||||
 | 
					#define CFG_GPCR1_VAL       0x30002000
 | 
				
			||||||
 | 
					#define CFG_GPCR2_VAL       0x00000100
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GP00 == DON_READY is input
 | 
				
			||||||
 | 
					 * GP01 == DON_OK    is input
 | 
				
			||||||
 | 
					 * GP02 == DON_RST   is output
 | 
				
			||||||
 | 
					 * GP03 == RESET_IND is input
 | 
				
			||||||
 | 
					 * GP07 == RES11     is input
 | 
				
			||||||
 | 
					 * GP09 == RES12     is input
 | 
				
			||||||
 | 
					 * GP11 == SWUPDATE  is input
 | 
				
			||||||
 | 
					 * GP14 == nPOWEROK  is input
 | 
				
			||||||
 | 
					 * GP15 == nCS1      is output
 | 
				
			||||||
 | 
					 * GP17 == RES22     is input
 | 
				
			||||||
 | 
					 * GP18 == RDY       is input
 | 
				
			||||||
 | 
					 * GP23 == SCLK      is output
 | 
				
			||||||
 | 
					 * GP24 == SFRM      is output
 | 
				
			||||||
 | 
					 * GP25 == TXD       is output
 | 
				
			||||||
 | 
					 * GP26 == RXD       is input
 | 
				
			||||||
 | 
					 * GP32 == RES21     is input
 | 
				
			||||||
 | 
					 * GP33 == nCS5      is output
 | 
				
			||||||
 | 
					 * GP34 == FFRXD     is input
 | 
				
			||||||
 | 
					 * GP35 == CTS       is input
 | 
				
			||||||
 | 
					 * GP39 == FFTXD     is output
 | 
				
			||||||
 | 
					 * GP41 == RTS       is output
 | 
				
			||||||
 | 
					 * GP42 == USB_OK    is input
 | 
				
			||||||
 | 
					 * GP45 == USB_ACT   is output
 | 
				
			||||||
 | 
					 * GP46 == RXD       is input
 | 
				
			||||||
 | 
					 * GP47 == TXD       is output
 | 
				
			||||||
 | 
					 * GP49 == nPWE      is output
 | 
				
			||||||
 | 
					 * GP58 == nCPUBUSINT is input
 | 
				
			||||||
 | 
					 * GP59 == LANINT    is input
 | 
				
			||||||
 | 
					 * GP60 == PLLEN     is output
 | 
				
			||||||
 | 
					 * GP61 == LED_A     is output
 | 
				
			||||||
 | 
					 * GP62 == LED_B     is output
 | 
				
			||||||
 | 
					 * GP63 == TDM_OE    is output
 | 
				
			||||||
 | 
					 * GP64 == nDSPINT   is input
 | 
				
			||||||
 | 
					 * GP65 == STRAP0    is input
 | 
				
			||||||
 | 
					 * GP67 == STRAP1    is input
 | 
				
			||||||
 | 
					 * GP69 == STRAP2    is input
 | 
				
			||||||
 | 
					 * GP70 == STRAP3    is input
 | 
				
			||||||
 | 
					 * GP71 == STRAP4    is input
 | 
				
			||||||
 | 
					 * GP73 == SWUPD_LED is output
 | 
				
			||||||
 | 
					 * GP78 == nCS2      is output
 | 
				
			||||||
 | 
					 * GP79 == nCS3      is output
 | 
				
			||||||
 | 
					 * GP80 == nCS4      is output
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_GPDR0_VAL       0x03808004
 | 
				
			||||||
 | 
					#define CFG_GPDR1_VAL       0xF002A282
 | 
				
			||||||
 | 
					#define CFG_GPDR2_VAL       0x0001C200
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GP15 == nCS1  is AF10
 | 
				
			||||||
 | 
					 * GP18 == RDY   is AF01
 | 
				
			||||||
 | 
					 * GP23 == SCLK  is AF10
 | 
				
			||||||
 | 
					 * GP24 == SFRM  is AF10
 | 
				
			||||||
 | 
					 * GP25 == TXD   is AF10
 | 
				
			||||||
 | 
					 * GP26 == RXD   is AF01
 | 
				
			||||||
 | 
					 * GP33 == nCS5  is AF10
 | 
				
			||||||
 | 
					 * GP34 == FFRXD is AF01
 | 
				
			||||||
 | 
					 * GP35 == CTS   is AF01
 | 
				
			||||||
 | 
					 * GP39 == FFTXD is AF10
 | 
				
			||||||
 | 
					 * GP41 == RTS   is AF10
 | 
				
			||||||
 | 
					 * GP46 == RXD   is AF10
 | 
				
			||||||
 | 
					 * GP47 == TXD   is AF01
 | 
				
			||||||
 | 
					 * GP49 == nPWE  is AF10
 | 
				
			||||||
 | 
					 * GP78 == nCS2  is AF10
 | 
				
			||||||
 | 
					 * GP79 == nCS3  is AF10
 | 
				
			||||||
 | 
					 * GP80 == nCS4  is AF10
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_GAFR0_L_VAL     0x80000000
 | 
				
			||||||
 | 
					#define CFG_GAFR0_U_VAL     0x001A8010
 | 
				
			||||||
 | 
					#define CFG_GAFR1_L_VAL     0x60088058
 | 
				
			||||||
 | 
					#define CFG_GAFR1_U_VAL     0x00000008
 | 
				
			||||||
 | 
					#define CFG_GAFR2_L_VAL     0xA0000000
 | 
				
			||||||
 | 
					#define CFG_GAFR2_U_VAL     0x00000002
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* FIXME: set GPIO_RER/FER */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* RDH = 1
 | 
				
			||||||
 | 
					 * PH  = 1
 | 
				
			||||||
 | 
					 * VFS = 1
 | 
				
			||||||
 | 
					 * BFS = 1
 | 
				
			||||||
 | 
					 * SSS = 1
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_PSSR_VAL		0x37
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Memory settings
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This is the configuration for nCS0/1 -> flash banks
 | 
				
			||||||
 | 
					 * configuration for nCS1:
 | 
				
			||||||
 | 
					 * [31]    0    - Slower Device
 | 
				
			||||||
 | 
					 * [30:28] 010  - CS deselect to CS time: 2*(2*MemClk) = 40 ns
 | 
				
			||||||
 | 
					 * [27:24] 0101 - Address to data valid in bursts: (5+1)*MemClk = 60 ns
 | 
				
			||||||
 | 
					 * [23:20] 1011 - " for first access: (11+2)*MemClk = 130 ns
 | 
				
			||||||
 | 
					 * [19]    1    - 16 Bit bus width
 | 
				
			||||||
 | 
					 * [18:16] 000  - nonburst RAM or FLASH
 | 
				
			||||||
 | 
					 * configuration for nCS0:
 | 
				
			||||||
 | 
					 * [15]    0    - Slower Device
 | 
				
			||||||
 | 
					 * [14:12] 010  - CS deselect to CS time: 2*(2*MemClk) = 40 ns
 | 
				
			||||||
 | 
					 * [11:08] 0101 - Address to data valid in bursts: (5+1)*MemClk = 60 ns
 | 
				
			||||||
 | 
					 * [07:04] 1011 - " for first access: (11+2)*MemClk = 130 ns
 | 
				
			||||||
 | 
					 * [03]    1    - 16 Bit bus width
 | 
				
			||||||
 | 
					 * [02:00] 000  - nonburst RAM or FLASH
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_MSC0_VAL		0x25b825b8 /* flash banks                   */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* This is the configuration for nCS2/3 -> TDM-Switch, DSP
 | 
				
			||||||
 | 
					 * configuration for nCS3: DSP
 | 
				
			||||||
 | 
					 * [31]    0    - Slower Device
 | 
				
			||||||
 | 
					 * [30:28] 001  - RRR3: CS deselect to CS time: 1*(2*MemClk) = 20 ns
 | 
				
			||||||
 | 
					 * [27:24] 0010 - RDN3: Address to data valid in bursts: (2+1)*MemClk = 30 ns
 | 
				
			||||||
 | 
					 * [23:20] 0011 - RDF3: Address for first access: (3+1)*MemClk = 40 ns
 | 
				
			||||||
 | 
					 * [19]    1    - 16 Bit bus width
 | 
				
			||||||
 | 
					 * [18:16] 100  - variable latency I/O
 | 
				
			||||||
 | 
					 * configuration for nCS2: TDM-Switch
 | 
				
			||||||
 | 
					 * [15]    0    - Slower Device
 | 
				
			||||||
 | 
					 * [14:12] 101  - RRR2: CS deselect to CS time: 5*(2*MemClk) = 100 ns
 | 
				
			||||||
 | 
					 * [11:08] 1001 - RDN2: Address to data valid in bursts: (9+1)*MemClk = 100 ns
 | 
				
			||||||
 | 
					 * [07:04] 0011 - RDF2: Address for first access: (3+1)*MemClk = 40 ns
 | 
				
			||||||
 | 
					 * [03]    1    - 16 Bit bus width
 | 
				
			||||||
 | 
					 * [02:00] 100  - variable latency I/O
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_MSC1_VAL		0x123C593C /* TDM switch, DSP               */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* This is the configuration for nCS4/5 -> ExtBus, LAN Controller
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * configuration for nCS5: LAN Controller
 | 
				
			||||||
 | 
					 * [31]    0    - Slower Device
 | 
				
			||||||
 | 
					 * [30:28] 001  - RRR5: CS deselect to CS time: 1*(2*MemClk) = 20 ns
 | 
				
			||||||
 | 
					 * [27:24] 0010 - RDN5: Address to data valid in bursts: (2+1)*MemClk = 30 ns
 | 
				
			||||||
 | 
					 * [23:20] 0011 - RDF5: Address for first access: (3+1)*MemClk = 40 ns
 | 
				
			||||||
 | 
					 * [19]    1    - 16 Bit bus width
 | 
				
			||||||
 | 
					 * [18:16] 100  - variable latency I/O
 | 
				
			||||||
 | 
					 * configuration for nCS4: ExtBus
 | 
				
			||||||
 | 
					 * [15]    0    - Slower Device
 | 
				
			||||||
 | 
					 * [14:12] 110  - RRR4: CS deselect to CS time: 6*(2*MemClk) = 120 ns
 | 
				
			||||||
 | 
					 * [11:08] 1100 - RDN4: Address to data valid in bursts: (12+1)*MemClk = 130 ns
 | 
				
			||||||
 | 
					 * [07:04] 1101 - RDF4: Address for first access: 13->(15+1)*MemClk = 160 ns
 | 
				
			||||||
 | 
					 * [03]    1    - 16 Bit bus width
 | 
				
			||||||
 | 
					 * [02:00] 100  - variable latency I/O
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_MSC2_VAL		0x123C6CDC /* extra bus, LAN controller     */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* MDCNFG: SDRAM Configuration Register
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * [31:29]   000 - reserved
 | 
				
			||||||
 | 
					 * [28]      0	 - no SA1111 compatiblity mode
 | 
				
			||||||
 | 
					 * [27]      0   - latch return data with return clock
 | 
				
			||||||
 | 
					 * [26]      0   - alternate addressing for pair 2/3
 | 
				
			||||||
 | 
					 * [25:24]   00  - timings
 | 
				
			||||||
 | 
					 * [23]      0   - internal banks in lower partition 2/3 (not used)
 | 
				
			||||||
 | 
					 * [22:21]   00  - row address bits for partition 2/3 (not used)
 | 
				
			||||||
 | 
					 * [20:19]   00  - column address bits for partition 2/3 (not used)
 | 
				
			||||||
 | 
					 * [18]      0   - SDRAM partition 2/3 width is 32 bit
 | 
				
			||||||
 | 
					 * [17]      0   - SDRAM partition 3 disabled
 | 
				
			||||||
 | 
					 * [16]      0   - SDRAM partition 2 disabled
 | 
				
			||||||
 | 
					 * [15:13]   000 - reserved
 | 
				
			||||||
 | 
					 * [12]      1	 - SA1111 compatiblity mode
 | 
				
			||||||
 | 
					 * [11]      1   - latch return data with return clock
 | 
				
			||||||
 | 
					 * [10]      0   - no alternate addressing for pair 0/1
 | 
				
			||||||
 | 
					 * [09:08]   01  - tRP=2*MemClk CL=2 tRCD=2*MemClk tRAS=5*MemClk tRC=8*MemClk
 | 
				
			||||||
 | 
					 * [7]       1   - 4 internal banks in lower partition pair
 | 
				
			||||||
 | 
					 * [06:05]   10  - 13 row address bits for partition 0/1
 | 
				
			||||||
 | 
					 * [04:03]   01  - 9 column address bits for partition 0/1
 | 
				
			||||||
 | 
					 * [02]      0   - SDRAM partition 0/1 width is 32 bit
 | 
				
			||||||
 | 
					 * [01]      0   - disable SDRAM partition 1
 | 
				
			||||||
 | 
					 * [00]      1   - enable  SDRAM partition 0
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/* use the configuration above but disable partition 0 */
 | 
				
			||||||
 | 
					#define CFG_MDCNFG_VAL		0x000019c8
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* MDREFR: SDRAM Refresh Control Register
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * [32:26] 0     - reserved
 | 
				
			||||||
 | 
					 * [25]    0     - K2FREE: not free running
 | 
				
			||||||
 | 
					 * [24]    0     - K1FREE: not free running
 | 
				
			||||||
 | 
					 * [23]    1     - K0FREE: not free running
 | 
				
			||||||
 | 
					 * [22]    0     - SLFRSH: self refresh disabled
 | 
				
			||||||
 | 
					 * [21]    0     - reserved
 | 
				
			||||||
 | 
					 * [20]    0     - APD: no auto power down
 | 
				
			||||||
 | 
					 * [19]    0     - K2DB2: SDCLK2 is MemClk
 | 
				
			||||||
 | 
					 * [18]    0     - K2RUN: disable SDCLK2
 | 
				
			||||||
 | 
					 * [17]    0     - K1DB2: SDCLK1 is MemClk
 | 
				
			||||||
 | 
					 * [16]    1     - K1RUN: enable SDCLK1
 | 
				
			||||||
 | 
					 * [15]    1     - E1PIN: SDRAM clock enable
 | 
				
			||||||
 | 
					 * [14]    1     - K0DB2: SDCLK0 is MemClk
 | 
				
			||||||
 | 
					 * [13]    0     - K0RUN: disable SDCLK0
 | 
				
			||||||
 | 
					 * [12]    1     - E0PIN: disable SDCKE0
 | 
				
			||||||
 | 
					 * [11:00] 000000011000 - (64ms/8192)*MemClkFreq/32 = 24
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_MDREFR_VAL		0x0081D018
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* MDMRS: Mode Register Set Configuration Register
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * [31]      0       - reserved
 | 
				
			||||||
 | 
					 * [30:23]   00000000- MDMRS2: SDRAM2/3 MRS Value. (not used)
 | 
				
			||||||
 | 
					 * [22:20]   000     - MDCL2:  SDRAM2/3 Cas Latency.  (not used)
 | 
				
			||||||
 | 
					 * [19]      0       - MDADD2: SDRAM2/3 burst Type. Fixed to sequential.  (not used)
 | 
				
			||||||
 | 
					 * [18:16]   010     - MDBL2:  SDRAM2/3 burst Length. Fixed to 4.  (not used)
 | 
				
			||||||
 | 
					 * [15]      0       - reserved
 | 
				
			||||||
 | 
					 * [14:07]   00000000- MDMRS0: SDRAM0/1 MRS Value.
 | 
				
			||||||
 | 
					 * [06:04]   010     - MDCL0:  SDRAM0/1 Cas Latency.
 | 
				
			||||||
 | 
					 * [03]      0       - MDADD0: SDRAM0/1 burst Type. Fixed to sequential.
 | 
				
			||||||
 | 
					 * [02:00]   010     - MDBL0:  SDRAM0/1 burst Length. Fixed to 4.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_MDMRS_VAL		0x00020022
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * PCMCIA and CF Interfaces
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CFG_MECR_VAL		0x00000000
 | 
				
			||||||
 | 
					#define CFG_MCMEM0_VAL		0x00000000
 | 
				
			||||||
 | 
					#define CFG_MCMEM1_VAL		0x00000000
 | 
				
			||||||
 | 
					#define CFG_MCATT0_VAL		0x00000000
 | 
				
			||||||
 | 
					#define CFG_MCATT1_VAL		0x00000000
 | 
				
			||||||
 | 
					#define CFG_MCIO0_VAL		0x00000000
 | 
				
			||||||
 | 
					#define CFG_MCIO1_VAL		0x00000000
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * GPIO settings
 | 
					 * GPIO settings
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define CFG_GPSR0_VAL       0xFFFFFFFF
 | 
					#define CFG_GPSR0_VAL		0xFFFFFFFF
 | 
				
			||||||
#define CFG_GPSR1_VAL       0xFFFFFFFF
 | 
					#define CFG_GPSR1_VAL		0xFFFFFFFF
 | 
				
			||||||
#define CFG_GPSR2_VAL       0xFFFFFFFF
 | 
					#define CFG_GPSR2_VAL		0xFFFFFFFF
 | 
				
			||||||
#define CFG_GPCR0_VAL       0x08022080
 | 
					#define CFG_GPCR0_VAL		0x08022080
 | 
				
			||||||
#define CFG_GPCR1_VAL       0x00000000
 | 
					#define CFG_GPCR1_VAL		0x00000000
 | 
				
			||||||
#define CFG_GPCR2_VAL       0x00000000
 | 
					#define CFG_GPCR2_VAL		0x00000000
 | 
				
			||||||
#define CFG_GPDR0_VAL       0xCD82A878
 | 
					#define CFG_GPDR0_VAL		0xCD82A878
 | 
				
			||||||
#define CFG_GPDR1_VAL       0xFCFFAB80
 | 
					#define CFG_GPDR1_VAL		0xFCFFAB80
 | 
				
			||||||
#define CFG_GPDR2_VAL       0x0001FFFF
 | 
					#define CFG_GPDR2_VAL		0x0001FFFF
 | 
				
			||||||
#define CFG_GAFR0_L_VAL     0x80000000
 | 
					#define CFG_GAFR0_L_VAL		0x80000000
 | 
				
			||||||
#define CFG_GAFR0_U_VAL     0xA5254010
 | 
					#define CFG_GAFR0_U_VAL		0xA5254010
 | 
				
			||||||
#define CFG_GAFR1_L_VAL     0x599A9550
 | 
					#define CFG_GAFR1_L_VAL		0x599A9550
 | 
				
			||||||
#define CFG_GAFR1_U_VAL     0xAAA5AAAA
 | 
					#define CFG_GAFR1_U_VAL		0xAAA5AAAA
 | 
				
			||||||
#define CFG_GAFR2_L_VAL     0xAAAAAAAA
 | 
					#define CFG_GAFR2_L_VAL		0xAAAAAAAA
 | 
				
			||||||
#define CFG_GAFR2_U_VAL     0x00000002
 | 
					#define CFG_GAFR2_U_VAL		0x00000002
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* FIXME: set GPIO_RER/FER */
 | 
					/* FIXME: set GPIO_RER/FER */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -177,12 +435,13 @@
 | 
				
			|||||||
/*
 | 
					/*
 | 
				
			||||||
 * Memory settings
 | 
					 * Memory settings
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define CFG_MSC0_VAL        0x2EF025D0
 | 
					
 | 
				
			||||||
#define CFG_MSC1_VAL        0x00003F64
 | 
					#define CFG_MSC0_VAL            0x2ef15af0
 | 
				
			||||||
#define CFG_MSC2_VAL        0x00000000
 | 
					#define CFG_MSC1_VAL            0x00003ff4
 | 
				
			||||||
#define CFG_MDCNFG_VAL      0x09a909a9
 | 
					#define CFG_MSC2_VAL            0x7ff07ff0
 | 
				
			||||||
#define CFG_MDREFR_VAL      0x03ca0030
 | 
					#define CFG_MDCNFG_VAL          0x09a909a9
 | 
				
			||||||
#define CFG_MDMRS_VAL       0x00220022
 | 
					#define CFG_MDREFR_VAL          0x038ff030
 | 
				
			||||||
 | 
					#define CFG_MDMRS_VAL           0x00220022
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * PCMCIA and CF Interfaces
 | 
					 * PCMCIA and CF Interfaces
 | 
				
			||||||
 | 
				
			|||||||
@ -30,8 +30,6 @@
 | 
				
			|||||||
#ifndef __CONFIG_H
 | 
					#ifndef __CONFIG_H
 | 
				
			||||||
#define __CONFIG_H
 | 
					#define __CONFIG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define DEBUG 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * If we are developing, we might want to start U-Boot from ram
 | 
					 * If we are developing, we might want to start U-Boot from ram
 | 
				
			||||||
 * so we MUST NOT initialize critical regs like mem-timing ...
 | 
					 * so we MUST NOT initialize critical regs like mem-timing ...
 | 
				
			||||||
@ -62,7 +60,7 @@
 | 
				
			|||||||
#define CONFIG_BAUDRATE		19200
 | 
					#define CONFIG_BAUDRATE		19200
 | 
				
			||||||
#define CONFIG_MISC_INIT_R	1	/* we have a misc_init_r() function */
 | 
					#define CONFIG_MISC_INIT_R	1	/* we have a misc_init_r() function */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_COMMANDS (CFG_CMD_BDI|CFG_CMD_LOADB|CFG_CMD_IMI|CFG_CMD_FLASH|CFG_CMD_MEMORY|CFG_CMD_NET|CFG_CMD_ENV|CFG_CMD_RUN|CFG_CMD_ASKENV|CFG_CMD_ECHO|CFG_CMD_I2C|CFG_CMD_DHCP)
 | 
					#define CONFIG_COMMANDS (CFG_CMD_BDI|CFG_CMD_LOADB|CFG_CMD_IMI|CFG_CMD_FLASH|CFG_CMD_MEMORY|CFG_CMD_NET|CFG_CMD_ENV|CFG_CMD_RUN|CFG_CMD_ASKENV|CFG_CMD_ECHO|CFG_CMD_I2C|CFG_CMD_DHCP|CFG_CMD_CACHE)
 | 
				
			||||||
/* CONFIG_CMD_DFL|CFG_CMD_I2C|CFG_CMD_EEPROM|CFG_CMD_NET|CFG_CMD_JFFS2|CFG_CMD_DHCP) */
 | 
					/* CONFIG_CMD_DFL|CFG_CMD_I2C|CFG_CMD_EEPROM|CFG_CMD_NET|CFG_CMD_JFFS2|CFG_CMD_DHCP) */
 | 
				
			||||||
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any)   */
 | 
					/* this must be included AFTER the definition of CONFIG_COMMANDS (if any)   */
 | 
				
			||||||
#include <cmd_confdefs.h>
 | 
					#include <cmd_confdefs.h>
 | 
				
			||||||
 | 
				
			|||||||
@ -58,8 +58,7 @@
 | 
				
			|||||||
#define CONFIG_ENV_OVERWRITE
 | 
					#define CONFIG_ENV_OVERWRITE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_BAUDRATE		19200
 | 
					#define CONFIG_BAUDRATE		19200
 | 
				
			||||||
/*#define CONFIG_MISC_INIT_R	1	/ * we have a misc_init_r() function */
 | 
					#undef CONFIG_MISC_INIT_R		/* FIXME: misc_init_r() missing     */
 | 
				
			||||||
#undef CONFIG_MISC_INIT_R		/* FIXME                            */
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CONFIG_COMMANDS (CFG_CMD_FLASH|CFG_CMD_MEMORY|CFG_CMD_ENV|CFG_CMD_RUN|CFG_CMD_ASKENV|CFG_CMD_ECHO)
 | 
					#define CONFIG_COMMANDS (CFG_CMD_FLASH|CFG_CMD_MEMORY|CFG_CMD_ENV|CFG_CMD_RUN|CFG_CMD_ASKENV|CFG_CMD_ECHO)
 | 
				
			||||||
/* CONFIG_CMD_DFL|CFG_CMD_I2C|CFG_CMD_EEPROM|CFG_CMD_NET|CFG_CMD_JFFS2|CFG_CMD_DHCP) */
 | 
					/* CONFIG_CMD_DFL|CFG_CMD_I2C|CFG_CMD_EEPROM|CFG_CMD_NET|CFG_CMD_JFFS2|CFG_CMD_DHCP) */
 | 
				
			||||||
@ -120,12 +119,14 @@
 | 
				
			|||||||
/*
 | 
					/*
 | 
				
			||||||
 * SMSC91C111 Network Card
 | 
					 * SMSC91C111 Network Card
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
/*#define CONFIG_DRIVER_SMC91111		1	*/
 | 
					#if 0
 | 
				
			||||||
/*#define CONFIG_SMC91111_BASE		0x10000000 / * chip select 4         */
 | 
					#define CONFIG_DRIVER_SMC91111		1
 | 
				
			||||||
/*#undef  CONFIG_SMC_USE_32_BIT		           / * 16 bit bus access     */
 | 
					#define CONFIG_SMC91111_BASE		0x10000000 /* chip select 4         */
 | 
				
			||||||
/*#undef  CONFIG_SMC_91111_EXT_PHY		   / * we use internal phy   */
 | 
					#undef  CONFIG_SMC_USE_32_BIT		           /* 16 bit bus access     */
 | 
				
			||||||
/*#undef  CONFIG_SHOW_ACTIVITY	*/
 | 
					#undef  CONFIG_SMC_91111_EXT_PHY		   /* we use internal phy   */
 | 
				
			||||||
/*#define CONFIG_NET_RETRY_COUNT		10	   / * # of retries          */
 | 
					#undef  CONFIG_SHOW_ACTIVITY
 | 
				
			||||||
 | 
					#define CONFIG_NET_RETRY_COUNT		10	   /* # of retries          */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Stack sizes
 | 
					 * Stack sizes
 | 
				
			||||||
 | 
				
			|||||||
@ -236,6 +236,8 @@ void status_led_set  (int led, int state);
 | 
				
			|||||||
/*****  NetVia   ********************************************************/
 | 
					/*****  NetVia   ********************************************************/
 | 
				
			||||||
#elif defined(CONFIG_NETVIA)
 | 
					#elif defined(CONFIG_NETVIA)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if !defined(CONFIG_NETVIA_VERSION) || CONFIG_NETVIA_VERSION == 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define STATUS_LED_PAR		im_ioport.iop_pdpar
 | 
					#define STATUS_LED_PAR		im_ioport.iop_pdpar
 | 
				
			||||||
#define STATUS_LED_DIR		im_ioport.iop_pddir
 | 
					#define STATUS_LED_DIR		im_ioport.iop_pddir
 | 
				
			||||||
#undef  STATUS_LED_ODR
 | 
					#undef  STATUS_LED_ODR
 | 
				
			||||||
@ -252,6 +254,7 @@ void status_led_set  (int led, int state);
 | 
				
			|||||||
# define STATUS_LED_ACTIVE	0		/* LED on for bit == 0	*/
 | 
					# define STATUS_LED_ACTIVE	0		/* LED on for bit == 0	*/
 | 
				
			||||||
# define STATUS_LED_BOOT	0		/* LED 0 used for boot status */
 | 
					# define STATUS_LED_BOOT	0		/* LED 0 used for boot status */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*****  CMI   ********************************************************/
 | 
					/*****  CMI   ********************************************************/
 | 
				
			||||||
#elif defined(CONFIG_CMI)
 | 
					#elif defined(CONFIG_CMI)
 | 
				
			||||||
 | 
				
			|||||||
@ -24,6 +24,6 @@
 | 
				
			|||||||
#ifndef	__VERSION_H__
 | 
					#ifndef	__VERSION_H__
 | 
				
			||||||
#define	__VERSION_H__
 | 
					#define	__VERSION_H__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define	U_BOOT_VERSION	"U-Boot 0.3.2"
 | 
					#define	U_BOOT_VERSION	"U-Boot 0.4.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif	/* __VERSION_H__ */
 | 
					#endif	/* __VERSION_H__ */
 | 
				
			||||||
 | 
				
			|||||||
@ -45,7 +45,7 @@
 | 
				
			|||||||
#define RTC_CONTROL_C 			0x0C
 | 
					#define RTC_CONTROL_C 			0x0C
 | 
				
			||||||
#define RTC_CONTROL_D			0x0D
 | 
					#define RTC_CONTROL_D			0x0D
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define RTC_CA_UIP			0x80 
 | 
					#define RTC_CA_UIP			0x80
 | 
				
			||||||
#define RTC_CB_DM			0x04
 | 
					#define RTC_CB_DM			0x04
 | 
				
			||||||
#define RTC_CB_24_12			0x02
 | 
					#define RTC_CB_24_12			0x02
 | 
				
			||||||
#define RTC_CB_SET			0x80
 | 
					#define RTC_CB_SET			0x80
 | 
				
			||||||
@ -55,10 +55,10 @@
 | 
				
			|||||||
static uchar rtc_read (uchar reg)
 | 
					static uchar rtc_read (uchar reg)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	uchar val;
 | 
						uchar val;
 | 
				
			||||||
    
 | 
					
 | 
				
			||||||
    	*(volatile unsigned char*)(RTC_PORT_ADDR) = reg;
 | 
					    	*(volatile unsigned char*)(RTC_PORT_ADDR) = reg;
 | 
				
			||||||
	__asm__ __volatile__ ("sync");
 | 
						__asm__ __volatile__ ("sync");
 | 
				
			||||||
	
 | 
					
 | 
				
			||||||
	val = *(volatile unsigned char*)(RTC_PORT_DATA);
 | 
						val = *(volatile unsigned char*)(RTC_PORT_DATA);
 | 
				
			||||||
	return (val);
 | 
						return (val);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -95,7 +95,7 @@ void rtc_get (struct rtc_time *tmp)
 | 
				
			|||||||
	/* check if rtc is available for access */
 | 
						/* check if rtc is available for access */
 | 
				
			||||||
	while( rtc_read(RTC_CONTROL_A) & RTC_CA_UIP)
 | 
						while( rtc_read(RTC_CONTROL_A) & RTC_CA_UIP)
 | 
				
			||||||
		;
 | 
							;
 | 
				
			||||||
    	
 | 
					
 | 
				
			||||||
	sec  = rtc_read(RTC_SECONDS);
 | 
						sec  = rtc_read(RTC_SECONDS);
 | 
				
			||||||
	min  = rtc_read(RTC_MINUTES);
 | 
						min  = rtc_read(RTC_MINUTES);
 | 
				
			||||||
	hour = rtc_read(RTC_HOURS);
 | 
						hour = rtc_read(RTC_HOURS);
 | 
				
			||||||
@ -183,11 +183,11 @@ void rtc_set (struct rtc_time *tmp)
 | 
				
			|||||||
		min  = tmp->tm_min;
 | 
							min  = tmp->tm_min;
 | 
				
			||||||
		sec  = tmp->tm_sec;
 | 
							sec  = tmp->tm_sec;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	
 | 
					
 | 
				
			||||||
	/* disables the RTC to update the regs */
 | 
						/* disables the RTC to update the regs */
 | 
				
			||||||
	save_ctrl_b = rtc_read(RTC_CONTROL_B);
 | 
						save_ctrl_b = rtc_read(RTC_CONTROL_B);
 | 
				
			||||||
	save_ctrl_b |= RTC_CB_SET;
 | 
						save_ctrl_b |= RTC_CB_SET;
 | 
				
			||||||
	rtc_write(RTC_CONTROL_B, save_ctrl_b); 
 | 
						rtc_write(RTC_CONTROL_B, save_ctrl_b);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	rtc_write (RTC_YEAR, year);
 | 
						rtc_write (RTC_YEAR, year);
 | 
				
			||||||
	rtc_write (RTC_MONTH, mon);
 | 
						rtc_write (RTC_MONTH, mon);
 | 
				
			||||||
@ -199,24 +199,24 @@ void rtc_set (struct rtc_time *tmp)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	/* enables the RTC to update the regs */
 | 
						/* enables the RTC to update the regs */
 | 
				
			||||||
	save_ctrl_b &= ~RTC_CB_SET;
 | 
						save_ctrl_b &= ~RTC_CB_SET;
 | 
				
			||||||
	rtc_write(RTC_CONTROL_B, save_ctrl_b); 
 | 
						rtc_write(RTC_CONTROL_B, save_ctrl_b);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void rtc_reset (void)
 | 
					void rtc_reset (void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct rtc_time tmp;
 | 
						struct rtc_time tmp;
 | 
				
			||||||
	uchar ctrl_rg;
 | 
						uchar ctrl_rg;
 | 
				
			||||||
    
 | 
					
 | 
				
			||||||
	ctrl_rg = RTC_CB_SET;
 | 
						ctrl_rg = RTC_CB_SET;
 | 
				
			||||||
	rtc_write(RTC_CONTROL_B,ctrl_rg); 
 | 
						rtc_write(RTC_CONTROL_B,ctrl_rg);
 | 
				
			||||||
    
 | 
					
 | 
				
			||||||
	tmp.tm_year = 1970 % 100;
 | 
						tmp.tm_year = 1970 % 100;
 | 
				
			||||||
	tmp.tm_mon = 1;
 | 
						tmp.tm_mon = 1;
 | 
				
			||||||
	tmp.tm_mday= 1;
 | 
						tmp.tm_mday= 1;
 | 
				
			||||||
	tmp.tm_hour = 0;
 | 
						tmp.tm_hour = 0;
 | 
				
			||||||
	tmp.tm_min = 0;
 | 
						tmp.tm_min = 0;
 | 
				
			||||||
	tmp.tm_sec = 0;
 | 
						tmp.tm_sec = 0;
 | 
				
			||||||
				    
 | 
					
 | 
				
			||||||
#ifdef RTC_DEBUG
 | 
					#ifdef RTC_DEBUG
 | 
				
			||||||
        printf ( "RTC:   %4d-%02d-%02d %2d:%02d:%02d UTC\n",
 | 
					        printf ( "RTC:   %4d-%02d-%02d %2d:%02d:%02d UTC\n",
 | 
				
			||||||
    		    tmp.tm_year, tmp.tm_mon, tmp.tm_mday,
 | 
					    		    tmp.tm_year, tmp.tm_mon, tmp.tm_mday,
 | 
				
			||||||
@ -224,15 +224,15 @@ void rtc_reset (void)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctrl_rg = RTC_CB_SET | RTC_CB_24_12 | RTC_CB_DM;
 | 
						ctrl_rg = RTC_CB_SET | RTC_CB_24_12 | RTC_CB_DM;
 | 
				
			||||||
	rtc_write(RTC_CONTROL_B,ctrl_rg); 
 | 
						rtc_write(RTC_CONTROL_B,ctrl_rg);
 | 
				
			||||||
    	rtc_set(&tmp);
 | 
					    	rtc_set(&tmp);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	rtc_write(RTC_HOURS_ALARM, 0),
 | 
						rtc_write(RTC_HOURS_ALARM, 0),
 | 
				
			||||||
	rtc_write(RTC_MINUTES_ALARM, 0),	
 | 
						rtc_write(RTC_MINUTES_ALARM, 0),
 | 
				
			||||||
	rtc_write(RTC_SECONDS_ALARM, 0);
 | 
						rtc_write(RTC_SECONDS_ALARM, 0);
 | 
				
			||||||
					
 | 
					
 | 
				
			||||||
	ctrl_rg = RTC_CB_24_12 | RTC_CB_DM;
 | 
						ctrl_rg = RTC_CB_24_12 | RTC_CB_DM;
 | 
				
			||||||
	rtc_write(RTC_CONTROL_B,ctrl_rg); 
 | 
						rtc_write(RTC_CONTROL_B,ctrl_rg);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif  /* (CONFIG_RTC_DS12887) && (CONFIG_COMMANDS & CFG_CMD_DATE) */
 | 
					#endif  /* (CONFIG_RTC_DS12887) && (CONFIG_COMMANDS & CFG_CMD_DATE) */
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user