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:
Doug Berger 2019-12-17 16:51:10 -08:00 committed by David S. Miller
parent dd8e911b7f
commit 8101553978
2 changed files with 8 additions and 13 deletions

View File

@ -521,7 +521,7 @@ static int bcmgenet_set_rx_csum(struct net_device *dev,
/* enable rx checksumming */ /* enable rx checksumming */
if (rx_csum_en) if (rx_csum_en)
rbuf_chk_ctrl |= RBUF_RXCHK_EN; rbuf_chk_ctrl |= RBUF_RXCHK_EN | RBUF_L3_PARSE_DIS;
else else
rbuf_chk_ctrl &= ~RBUF_RXCHK_EN; rbuf_chk_ctrl &= ~RBUF_RXCHK_EN;
priv->desc_rxchk_en = rx_csum_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 bytes_processed = 0;
unsigned int p_index, mask; unsigned int p_index, mask;
unsigned int discards; unsigned int discards;
unsigned int chksum_ok = 0;
/* Clear status before servicing to reduce spurious interrupts */ /* Clear status before servicing to reduce spurious interrupts */
if (ring->index == DESC_INDEX) { 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); dmadesc_get_length_status(priv, cb->bd_addr);
} else { } else {
struct status_64 *status; struct status_64 *status;
__be16 rx_csum;
status = (struct status_64 *)skb->data; status = (struct status_64 *)skb->data;
dma_length_status = status->length_status; 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 /* 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; goto next;
} /* error packet */ } /* error packet */
chksum_ok = (dma_flag & priv->dma_rx_chk_bit) &&
priv->desc_rxchk_en;
skb_put(skb, len); skb_put(skb, len);
if (priv->desc_64b_en) { if (priv->desc_64b_en) {
skb_pull(skb, 64); skb_pull(skb, 64);
len -= 64; len -= 64;
} }
if (likely(chksum_ok))
skb->ip_summed = CHECKSUM_UNNECESSARY;
/* remove hardware 2bytes added for IP alignment */ /* remove hardware 2bytes added for IP alignment */
skb_pull(skb, 2); skb_pull(skb, 2);
len -= 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)) { if (GENET_IS_V5(priv) || GENET_IS_V4(priv)) {
bcmgenet_dma_regs = bcmgenet_dma_regs_v3plus; bcmgenet_dma_regs = bcmgenet_dma_regs_v3plus;
genet_dma_ring_regs = genet_dma_ring_regs_v4; genet_dma_ring_regs = genet_dma_ring_regs_v4;
priv->dma_rx_chk_bit = DMA_RX_CHK_V3PLUS;
} else if (GENET_IS_V3(priv)) { } else if (GENET_IS_V3(priv)) {
bcmgenet_dma_regs = bcmgenet_dma_regs_v3plus; bcmgenet_dma_regs = bcmgenet_dma_regs_v3plus;
genet_dma_ring_regs = genet_dma_ring_regs_v123; genet_dma_ring_regs = genet_dma_ring_regs_v123;
priv->dma_rx_chk_bit = DMA_RX_CHK_V3PLUS;
} else if (GENET_IS_V2(priv)) { } else if (GENET_IS_V2(priv)) {
bcmgenet_dma_regs = bcmgenet_dma_regs_v2; bcmgenet_dma_regs = bcmgenet_dma_regs_v2;
genet_dma_ring_regs = genet_dma_ring_regs_v123; genet_dma_ring_regs = genet_dma_ring_regs_v123;
priv->dma_rx_chk_bit = DMA_RX_CHK_V12;
} else if (GENET_IS_V1(priv)) { } else if (GENET_IS_V1(priv)) {
bcmgenet_dma_regs = bcmgenet_dma_regs_v1; bcmgenet_dma_regs = bcmgenet_dma_regs_v1;
genet_dma_ring_regs = genet_dma_ring_regs_v123; genet_dma_ring_regs = genet_dma_ring_regs_v123;
priv->dma_rx_chk_bit = DMA_RX_CHK_V12;
} }
/* enum genet_version starts at 1 */ /* enum genet_version starts at 1 */

View File

@ -251,6 +251,7 @@ struct bcmgenet_mib_counters {
#define RBUF_CHK_CTRL 0x14 #define RBUF_CHK_CTRL 0x14
#define RBUF_RXCHK_EN (1 << 0) #define RBUF_RXCHK_EN (1 << 0)
#define RBUF_SKIP_FCS (1 << 4) #define RBUF_SKIP_FCS (1 << 4)
#define RBUF_L3_PARSE_DIS (1 << 5)
#define RBUF_ENERGY_CTRL 0x9c #define RBUF_ENERGY_CTRL 0x9c
#define RBUF_EEE_EN (1 << 0) #define RBUF_EEE_EN (1 << 0)
@ -663,7 +664,6 @@ struct bcmgenet_priv {
bool desc_rxchk_en; bool desc_rxchk_en;
bool crc_fwd_en; bool crc_fwd_en;
unsigned int dma_rx_chk_bit;
u32 dma_max_burst_length; u32 dma_max_burst_length;
u32 msg_enable; u32 msg_enable;