diff options
author | Eric Dumazet <[email protected]> | 2012-10-08 21:38:50 +0200 |
---|---|---|
committer | David S. Miller <[email protected]> | 2012-10-08 15:40:43 -0400 |
commit | 863472454ce50d4ef0929c6aa738cc5d64b84679 (patch) | |
tree | 10a938801074b41e53c8237c92390e745b47a521 /lib/mpi/mpi-inline.h | |
parent | 48cc32d38a52d0b68f91a171a8d00531edc6a46e (diff) |
ipv6: gro: fix PV6_GRO_CB(skb)->proto problem
It seems IPV6_GRO_CB(skb)->proto can be destroyed in skb_gro_receive()
if a new skb is allocated (to serve as an anchor for frag_list)
We copy NAPI_GRO_CB() only (not the IPV6 specific part) in :
*NAPI_GRO_CB(nskb) = *NAPI_GRO_CB(p);
So we leave IPV6_GRO_CB(nskb)->proto to 0 (fresh skb allocation) instead
of IPPROTO_TCP (6)
ipv6_gro_complete() isnt able to call ops->gro_complete()
[ tcp6_gro_complete() ]
Fix this by moving proto in NAPI_GRO_CB() and getting rid of
IPV6_GRO_CB
Signed-off-by: Eric Dumazet <[email protected]>
Cc: Herbert Xu <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'lib/mpi/mpi-inline.h')
0 files changed, 0 insertions, 0 deletions