diff options
Diffstat (limited to 'drivers/net/ethernet/renesas/sh_eth.c')
| -rw-r--r-- | drivers/net/ethernet/renesas/sh_eth.c | 53 | 
1 files changed, 32 insertions, 21 deletions
| diff --git a/drivers/net/ethernet/renesas/sh_eth.c b/drivers/net/ethernet/renesas/sh_eth.c index b4479b5aaee4..e29fe8dbd226 100644 --- a/drivers/net/ethernet/renesas/sh_eth.c +++ b/drivers/net/ethernet/renesas/sh_eth.c @@ -380,8 +380,9 @@ static struct sh_eth_cpu_data sh_eth_my_cpu_data = {  	.eesipr_value	= 0x01ff009f,  	.tx_check	= EESR_FTC | EESR_CND | EESR_DLC | EESR_CD | EESR_RTO, -	.eesr_err_check	= EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE | -			  EESR_RFRMER | EESR_TFE | EESR_TDE | EESR_ECI, +	.eesr_err_check	= EESR_TWB | EESR_TABT | EESR_RABT | EESR_RFE | +			  EESR_RDE | EESR_RFRMER | EESR_TFE | EESR_TDE | +			  EESR_ECI,  	.tx_error_check	= EESR_TWB | EESR_TABT | EESR_TDE | EESR_TFE,  	.apr		= 1, @@ -427,8 +428,9 @@ static struct sh_eth_cpu_data sh_eth_my_cpu_data = {  	.eesipr_value	= DMAC_M_RFRMER | DMAC_M_ECI | 0x01ff009f,  	.tx_check	= EESR_FTC | EESR_CND | EESR_DLC | EESR_CD | EESR_RTO, -	.eesr_err_check	= EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE | -			  EESR_RFRMER | EESR_TFE | EESR_TDE | EESR_ECI, +	.eesr_err_check	= EESR_TWB | EESR_TABT | EESR_RABT | EESR_RFE | +			  EESR_RDE | EESR_RFRMER | EESR_TFE | EESR_TDE | +			  EESR_ECI,  	.tx_error_check	= EESR_TWB | EESR_TABT | EESR_TDE | EESR_TFE,  	.apr		= 1, @@ -478,8 +480,9 @@ static struct sh_eth_cpu_data sh_eth_my_cpu_data = {  	.rmcr_value	= 0x00000001,  	.tx_check	= EESR_FTC | EESR_CND | EESR_DLC | EESR_CD | EESR_RTO, -	.eesr_err_check	= EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE | -			  EESR_RFRMER | EESR_TFE | EESR_TDE | EESR_ECI, +	.eesr_err_check	= EESR_TWB | EESR_TABT | EESR_RABT | EESR_RFE | +			  EESR_RDE | EESR_RFRMER | EESR_TFE | EESR_TDE | +			  EESR_ECI,  	.tx_error_check	= EESR_TWB | EESR_TABT | EESR_TDE | EESR_TFE,  	.apr		= 1, @@ -592,9 +595,9 @@ static struct sh_eth_cpu_data sh_eth_my_cpu_data_giga = {  	.eesipr_value	= DMAC_M_RFRMER | DMAC_M_ECI | 0x003fffff,  	.tx_check	= EESR_TC1 | EESR_FTC, -	.eesr_err_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_RABT | \ -			  EESR_RDE | EESR_RFRMER | EESR_TFE | EESR_TDE | \ -			  EESR_ECI, +	.eesr_err_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_RABT | +			  EESR_RFE | EESR_RDE | EESR_RFRMER | EESR_TFE | +			  EESR_TDE | EESR_ECI,  	.tx_error_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_TDE | \  			  EESR_TFE,  	.fdr_value	= 0x0000072f, @@ -674,9 +677,9 @@ static struct sh_eth_cpu_data sh_eth_my_cpu_data = {  	.eesipr_value	= DMAC_M_RFRMER | DMAC_M_ECI | 0x003fffff,  	.tx_check	= EESR_TC1 | EESR_FTC, -	.eesr_err_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_RABT | \ -			  EESR_RDE | EESR_RFRMER | EESR_TFE | EESR_TDE | \ -			  EESR_ECI, +	.eesr_err_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_RABT | +			  EESR_RFE | EESR_RDE | EESR_RFRMER | EESR_TFE | +			  EESR_TDE | EESR_ECI,  	.tx_error_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_TDE | \  			  EESR_TFE, @@ -811,9 +814,9 @@ static struct sh_eth_cpu_data sh_eth_my_cpu_data = {  	.eesipr_value	= DMAC_M_RFRMER | DMAC_M_ECI | 0x003fffff,  	.tx_check	= EESR_TC1 | EESR_FTC, -	.eesr_err_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_RABT | \ -			  EESR_RDE | EESR_RFRMER | EESR_TFE | EESR_TDE | \ -			  EESR_ECI, +	.eesr_err_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_RABT | +			  EESR_RFE | EESR_RDE | EESR_RFRMER | EESR_TFE | +			  EESR_TDE | EESR_ECI,  	.tx_error_check	= EESR_TWB1 | EESR_TWB | EESR_TABT | EESR_TDE | \  			  EESR_TFE, @@ -1401,16 +1404,23 @@ static int sh_eth_rx(struct net_device *ndev, u32 intr_status)  		desc_status = edmac_to_cpu(mdp, rxdesc->status);  		pkt_len = rxdesc->frame_length; -#if defined(CONFIG_ARCH_R8A7740) -		desc_status >>= 16; -#endif -  		if (--boguscnt < 0)  			break;  		if (!(desc_status & RDFEND))  			ndev->stats.rx_length_errors++; +#if defined(CONFIG_ARCH_R8A7740) +		/* +		 * In case of almost all GETHER/ETHERs, the Receive Frame State +		 * (RFS) bits in the Receive Descriptor 0 are from bit 9 to +		 * bit 0. However, in case of the R8A7740's GETHER, the RFS +		 * bits are from bit 25 to bit 16. So, the driver needs right +		 * shifting by 16. +		 */ +		desc_status >>= 16; +#endif +  		if (desc_status & (RD_RFS1 | RD_RFS2 | RD_RFS3 | RD_RFS4 |  				   RD_RFS5 | RD_RFS6 | RD_RFS10)) {  			ndev->stats.rx_errors++; @@ -1542,11 +1552,12 @@ static void sh_eth_error(struct net_device *ndev, int intr_status)  ignore_link:  	if (intr_status & EESR_TWB) { -		/* Write buck end. unused write back interrupt */ -		if (intr_status & EESR_TABT)	/* Transmit Abort int */ +		/* Unused write back interrupt */ +		if (intr_status & EESR_TABT) {	/* Transmit Abort int */  			ndev->stats.tx_aborted_errors++;  			if (netif_msg_tx_err(mdp))  				dev_err(&ndev->dev, "Transmit Abort\n"); +		}  	}  	if (intr_status & EESR_RABT) { | 

