|
@@ -24,13 +24,13 @@ const u8 br_group_address[ETH_ALEN] = { 0x01, 0x80, 0xc2, 0x00, 0x00, 0x00 };
|
|
|
|
|
|
static void br_pass_frame_up(struct net_bridge *br, struct sk_buff *skb)
|
|
|
{
|
|
|
- struct net_device *indev;
|
|
|
+ struct net_device *indev, *brdev = br->dev;
|
|
|
|
|
|
- br->statistics.rx_packets++;
|
|
|
- br->statistics.rx_bytes += skb->len;
|
|
|
+ brdev->stats.rx_packets++;
|
|
|
+ brdev->stats.rx_bytes += skb->len;
|
|
|
|
|
|
indev = skb->dev;
|
|
|
- skb->dev = br->dev;
|
|
|
+ skb->dev = brdev;
|
|
|
|
|
|
NF_HOOK(PF_BRIDGE, NF_BR_LOCAL_IN, skb, indev, NULL,
|
|
|
netif_receive_skb);
|
|
@@ -64,7 +64,7 @@ int br_handle_frame_finish(struct sk_buff *skb)
|
|
|
dst = NULL;
|
|
|
|
|
|
if (is_multicast_ether_addr(dest)) {
|
|
|
- br->statistics.multicast++;
|
|
|
+ br->dev->stats.multicast++;
|
|
|
skb2 = skb;
|
|
|
} else if ((dst = __br_fdb_get(br, dest)) && dst->is_local) {
|
|
|
skb2 = skb;
|