diff options
Diffstat (limited to 'board/atmel/at91sam9263ek')
| -rw-r--r-- | board/atmel/at91sam9263ek/at91sam9263ek.c | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/board/atmel/at91sam9263ek/at91sam9263ek.c b/board/atmel/at91sam9263ek/at91sam9263ek.c index 660c47344..0b7065b71 100644 --- a/board/atmel/at91sam9263ek/at91sam9263ek.c +++ b/board/atmel/at91sam9263ek/at91sam9263ek.c @@ -91,6 +91,8 @@ static void at91sam9263ek_nand_hw_init(void)  #ifdef CONFIG_MACB  static void at91sam9263ek_macb_hw_init(void)  { +	unsigned long rstc; +  	/* Enable clock */  	at91_sys_write(AT91_PMC_PCER, 1 << AT91SAM9263_ID_EMAC); @@ -108,6 +110,8 @@ static void at91sam9263ek_macb_hw_init(void)  	       pin_to_mask(AT91_PIN_PE26),  	       pin_to_controller(AT91_PIN_PE0) + PIO_PUDR); +	rstc = at91_sys_read(AT91_RSTC_MR) & AT91_RSTC_ERSTL; +  	/* Need to reset PHY -> 500ms reset */  	at91_sys_write(AT91_RSTC_MR, AT91_RSTC_KEY |  				     (AT91_RSTC_ERSTL & (0x0D << 8)) | @@ -120,7 +124,7 @@ static void at91sam9263ek_macb_hw_init(void)  	/* Restore NRST value */  	at91_sys_write(AT91_RSTC_MR, AT91_RSTC_KEY | -				     (AT91_RSTC_ERSTL & (0x0 << 8)) | +				     (rstc) |  				     AT91_RSTC_URSTEN);  	/* Re-enable pull-up */ |