net: bcmgenet: use CHECKSUM_COMPLETE for NETIF_F_RXCSUM
This commit updates the Rx checksum offload behavior of the driver to use the more generic CHECKSUM_COMPLETE method that supports all protocols over the CHECKSUM_UNNECESSARY method that only applies to some protocols known by the hardware. This behavior is perceived to be superior. Signed-off-by: Doug Berger <opendmb@gmail.com> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
dd8e911b7f
commit
8101553978
@ -521,7 +521,7 @@ static int bcmgenet_set_rx_csum(struct net_device *dev,
|
||||
|
||||
/* enable rx checksumming */
|
||||
if (rx_csum_en)
|
||||
rbuf_chk_ctrl |= RBUF_RXCHK_EN;
|
||||
rbuf_chk_ctrl |= RBUF_RXCHK_EN | RBUF_L3_PARSE_DIS;
|
||||
else
|
||||
rbuf_chk_ctrl &= ~RBUF_RXCHK_EN;
|
||||
priv->desc_rxchk_en = rx_csum_en;
|
||||
@ -1739,7 +1739,6 @@ static unsigned int bcmgenet_desc_rx(struct bcmgenet_rx_ring *ring,
|
||||
unsigned int bytes_processed = 0;
|
||||
unsigned int p_index, mask;
|
||||
unsigned int discards;
|
||||
unsigned int chksum_ok = 0;
|
||||
|
||||
/* Clear status before servicing to reduce spurious interrupts */
|
||||
if (ring->index == DESC_INDEX) {
|
||||
@ -1790,9 +1789,15 @@ static unsigned int bcmgenet_desc_rx(struct bcmgenet_rx_ring *ring,
|
||||
dmadesc_get_length_status(priv, cb->bd_addr);
|
||||
} else {
|
||||
struct status_64 *status;
|
||||
__be16 rx_csum;
|
||||
|
||||
status = (struct status_64 *)skb->data;
|
||||
dma_length_status = status->length_status;
|
||||
rx_csum = (__force __be16)(status->rx_csum & 0xffff);
|
||||
if (priv->desc_rxchk_en) {
|
||||
skb->csum = (__force __wsum)ntohs(rx_csum);
|
||||
skb->ip_summed = CHECKSUM_COMPLETE;
|
||||
}
|
||||
}
|
||||
|
||||
/* DMA flags and length are still valid no matter how
|
||||
@ -1835,18 +1840,12 @@ static unsigned int bcmgenet_desc_rx(struct bcmgenet_rx_ring *ring,
|
||||
goto next;
|
||||
} /* error packet */
|
||||
|
||||
chksum_ok = (dma_flag & priv->dma_rx_chk_bit) &&
|
||||
priv->desc_rxchk_en;
|
||||
|
||||
skb_put(skb, len);
|
||||
if (priv->desc_64b_en) {
|
||||
skb_pull(skb, 64);
|
||||
len -= 64;
|
||||
}
|
||||
|
||||
if (likely(chksum_ok))
|
||||
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
||||
|
||||
/* remove hardware 2bytes added for IP alignment */
|
||||
skb_pull(skb, 2);
|
||||
len -= 2;
|
||||
@ -3322,19 +3321,15 @@ static void bcmgenet_set_hw_params(struct bcmgenet_priv *priv)
|
||||
if (GENET_IS_V5(priv) || GENET_IS_V4(priv)) {
|
||||
bcmgenet_dma_regs = bcmgenet_dma_regs_v3plus;
|
||||
genet_dma_ring_regs = genet_dma_ring_regs_v4;
|
||||
priv->dma_rx_chk_bit = DMA_RX_CHK_V3PLUS;
|
||||
} else if (GENET_IS_V3(priv)) {
|
||||
bcmgenet_dma_regs = bcmgenet_dma_regs_v3plus;
|
||||
genet_dma_ring_regs = genet_dma_ring_regs_v123;
|
||||
priv->dma_rx_chk_bit = DMA_RX_CHK_V3PLUS;
|
||||
} else if (GENET_IS_V2(priv)) {
|
||||
bcmgenet_dma_regs = bcmgenet_dma_regs_v2;
|
||||
genet_dma_ring_regs = genet_dma_ring_regs_v123;
|
||||
priv->dma_rx_chk_bit = DMA_RX_CHK_V12;
|
||||
} else if (GENET_IS_V1(priv)) {
|
||||
bcmgenet_dma_regs = bcmgenet_dma_regs_v1;
|
||||
genet_dma_ring_regs = genet_dma_ring_regs_v123;
|
||||
priv->dma_rx_chk_bit = DMA_RX_CHK_V12;
|
||||
}
|
||||
|
||||
/* enum genet_version starts at 1 */
|
||||
|
@ -251,6 +251,7 @@ struct bcmgenet_mib_counters {
|
||||
#define RBUF_CHK_CTRL 0x14
|
||||
#define RBUF_RXCHK_EN (1 << 0)
|
||||
#define RBUF_SKIP_FCS (1 << 4)
|
||||
#define RBUF_L3_PARSE_DIS (1 << 5)
|
||||
|
||||
#define RBUF_ENERGY_CTRL 0x9c
|
||||
#define RBUF_EEE_EN (1 << 0)
|
||||
@ -663,7 +664,6 @@ struct bcmgenet_priv {
|
||||
bool desc_rxchk_en;
|
||||
bool crc_fwd_en;
|
||||
|
||||
unsigned int dma_rx_chk_bit;
|
||||
u32 dma_max_burst_length;
|
||||
|
||||
u32 msg_enable;
|
||||
|
Loading…
x
Reference in New Issue
Block a user