diff options
Diffstat (limited to 'board/atmel/at91rm9200dk/flash.c')
| -rw-r--r-- | board/atmel/at91rm9200dk/flash.c | 10 | 
1 files changed, 6 insertions, 4 deletions
| diff --git a/board/atmel/at91rm9200dk/flash.c b/board/atmel/at91rm9200dk/flash.c index 902c3c41c..be2274362 100644 --- a/board/atmel/at91rm9200dk/flash.c +++ b/board/atmel/at91rm9200dk/flash.c @@ -285,6 +285,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 */ @@ -325,7 +326,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 */ -		reset_timer_masked (); +		start = get_timer(0);  		if (info->protect[sect] == 0) {	/* not protected */  			volatile u16 *addr = (volatile u16 *) (info->start[sect]); @@ -345,7 +346,7 @@ int flash_erase (flash_info_t * info, int s_first, int s_last)  				result = *addr;  				/* check timeout */ -				if (get_timer_masked () > CONFIG_SYS_FLASH_ERASE_TOUT) { +				if (get_timer(start) > CONFIG_SYS_FLASH_ERASE_TOUT) {  					MEM_FLASH_ADDR1 = CMD_READ_ARRAY;  					chip1 = TMO;  					break; @@ -400,6 +401,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 @@ -425,7 +427,7 @@ static int write_word (flash_info_t * info, ulong dest, ulong data)  	*addr = data;  	/* arm simple, non interrupt dependent timer */ -	reset_timer_masked (); +	start = get_timer(0);  	/* wait until flash is ready */  	chip1 = 0; @@ -433,7 +435,7 @@ static int write_word (flash_info_t * info, ulong dest, ulong data)  		result = *addr;  		/* check timeout */ -		if (get_timer_masked () > CONFIG_SYS_FLASH_ERASE_TOUT) { +		if (get_timer(start) > CONFIG_SYS_FLASH_ERASE_TOUT) {  			chip1 = ERR | TMO;  			break;  		} |