]> git.itanic.dy.fi Git - linux-stable/commitdiff
bridging: fix rx_handlers return code
authorCristian Bercaru <B43982@freescale.com>
Fri, 8 Mar 2013 07:03:38 +0000 (07:03 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 20 Mar 2013 19:58:54 +0000 (12:58 -0700)
[ Upstream commit 3bc1b1add7a8484cc4a261c3e128dbe1528ce01f ]

The frames for which rx_handlers return RX_HANDLER_CONSUMED are no longer
counted as dropped. They are counted as successfully received by
'netif_receive_skb'.

This allows network interface drivers to correctly update their RX-OK and
RX-DRP counters based on the result of 'netif_receive_skb'.

Signed-off-by: Cristian Bercaru <B43982@freescale.com>
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/core/dev.c

index 465f1f62766e94d5dfad503d2b603942c9ec429b..ed1f0ca49c9d2d881e6e0b8edeac88720247c4c6 100644 (file)
@@ -3165,6 +3165,7 @@ static int __netif_receive_skb(struct sk_buff *skb)
                }
                switch (rx_handler(&skb)) {
                case RX_HANDLER_CONSUMED:
+                       ret = NET_RX_SUCCESS;
                        goto out;
                case RX_HANDLER_ANOTHER:
                        goto another_round;