From: Helmut Buchsbaum <helmut.buchsb...@gmail.com>
Date: Mon, 29 Aug 2016 15:57:25 +0200

> diff --git a/drivers/net/ethernet/cadence/macb.c 
> b/drivers/net/ethernet/cadence/macb.c
> index 89c0cfa..de2f791 100644
> --- a/drivers/net/ethernet/cadence/macb.c
> +++ b/drivers/net/ethernet/cadence/macb.c
> @@ -1323,6 +1323,19 @@ dma_error:
>       return 0;
>  }
>  
> +static inline void macb_clear_csum(struct sk_buff *skb)
> +{
> +     /* no change for packets without checksum offloading */
> +     if (skb->ip_summed != CHECKSUM_PARTIAL)
> +             return;
> +
> +     /* initialize checksum field
> +      * This is required - at least for Zynq, which otherwise calculates
> +      * wrong UDP header checksums for UDP packets with UDP data len <=2
> +      */
> +     *(__sum16 *)(skb->head + skb->csum_start + skb->csum_offset) = 0;
> +}
> +

It is not valid to blindly modify the SKB contents, you must make sure that no
other references to this SKB's data exist.

You do this via skb_cow_head(skb, 0), which may fail.

See for example drivers/net/ethernet/broadcom/tg3.c's tg3_start_xmit()

Reply via email to