From 691d4b9f4f4479edb4c3c63c7dbf5c5fa1ce0979 Mon Sep 17 00:00:00 2001 From: Aubrey Li Date: Fri, 20 Apr 2007 01:40:19 +0200 Subject: [NET]: Fix UDP checksum issue in net poll mode. In net poll mode, the current checksum function doesn't consider the kind of packet which is padded to reach a specific minimum length. I believe that's the problem causing my test case failed. The following patch fixed this issue. Signed-off-by: Aubrey Li Signed-off-by: David S. Miller Signed-off-by: Adrian Bunk --- net/core/netpoll.c | 7 +++++++ 1 file changed, 7 insertions(+) (limited to 'net') diff --git a/net/core/netpoll.c b/net/core/netpoll.c index ea51f8d02eb8..62753d3afc72 100644 --- a/net/core/netpoll.c +++ b/net/core/netpoll.c @@ -485,6 +485,13 @@ int __netpoll_rx(struct sk_buff *skb) if (skb->len < len || len < iph->ihl*4) goto out; + /* + * Our transport medium may have padded the buffer out. + * Now We trim to the true length of the frame. + */ + if (pskb_trim_rcsum(skb, len)) + goto out; + if (iph->protocol != IPPROTO_UDP) goto out; -- cgit v1.2.3