diff options
Diffstat (limited to 'board/cobra5272/flash.c')
| -rw-r--r-- | board/cobra5272/flash.c | 10 | 
1 files changed, 6 insertions, 4 deletions
| diff --git a/board/cobra5272/flash.c b/board/cobra5272/flash.c index 33c936120..e8f02eb81 100644 --- a/board/cobra5272/flash.c +++ b/board/cobra5272/flash.c @@ -147,6 +147,7 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)  	int iflag, cflag, prot, sect;  	int rc = ERR_OK;  	int chip1; +	ulong start;  	/* first look for protection bits */ @@ -190,7 +191,7 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)  		printf ("Erasing sector %2d ... ", sect);  		/* arm simple, non interrupt dependent timer */ -		set_timer (0); +		start = get_timer(0);  		if (info->protect[sect] == 0) {	/* not protected */  			volatile u16 *addr = @@ -211,7 +212,7 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)  				result = *addr;  				/* check timeout */ -				if (get_timer (0) > CONFIG_SYS_FLASH_ERASE_TOUT) { +				if (get_timer(start) > CONFIG_SYS_FLASH_ERASE_TOUT) {  					MEM_FLASH_ADDR1 = CMD_READ_ARRAY;  					chip1 = TMO;  					break; @@ -264,6 +265,7 @@ static int write_word (flash_info_t * info, ulong dest, ulong data)  	int rc = ERR_OK;  	int cflag, iflag;  	int chip1; +	ulong start;  	/*  	 * Check if Flash is (sufficiently) erased @@ -291,7 +293,7 @@ static int write_word (flash_info_t * info, ulong dest, ulong data)  	*addr = data;  	/* arm simple, non interrupt dependent timer */ -	set_timer (0); +	start = get_timer(0);  	/* wait until flash is ready */  	chip1 = 0; @@ -299,7 +301,7 @@ static int write_word (flash_info_t * info, ulong dest, ulong data)  		result = *addr;  		/* check timeout */ -		if (get_timer (0) > CONFIG_SYS_FLASH_ERASE_TOUT) { +		if (get_timer(start) > CONFIG_SYS_FLASH_ERASE_TOUT) {  			chip1 = ERR | TMO;  			break;  		} |