diff options
author | Jamal Hadi Salim <jhs@mojatatu.com> | 2014-07-10 07:01:58 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-07-10 15:37:33 -0400 |
commit | 5d5eacb34c9e1fdc0a47b885d832eaa4de860dc7 (patch) | |
tree | 880d3849c474c2d307928b99d22f9a4354e1387a /net | |
parent | 69b4b7a4148e94a3fe7f06f72ee70113a6c61837 (diff) |
bridge: fdb dumping takes a filter device
Dumping a bridge fdb dumps every fdb entry
held. With this change we are going to filter
on selected bridge port.
Signed-off-by: Jamal Hadi Salim <jhs@mojatatu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/bridge/br_fdb.c | 5 | ||||
-rw-r--r-- | net/bridge/br_private.h | 2 | ||||
-rw-r--r-- | net/core/rtnetlink.c | 9 |
3 files changed, 12 insertions, 4 deletions
diff --git a/net/bridge/br_fdb.c b/net/bridge/br_fdb.c index 7be33667a839..6edecd11ecf0 100644 --- a/net/bridge/br_fdb.c +++ b/net/bridge/br_fdb.c | |||
@@ -676,6 +676,7 @@ errout: | |||
676 | int br_fdb_dump(struct sk_buff *skb, | 676 | int br_fdb_dump(struct sk_buff *skb, |
677 | struct netlink_callback *cb, | 677 | struct netlink_callback *cb, |
678 | struct net_device *dev, | 678 | struct net_device *dev, |
679 | struct net_device *filter_dev, | ||
679 | int idx) | 680 | int idx) |
680 | { | 681 | { |
681 | struct net_bridge *br = netdev_priv(dev); | 682 | struct net_bridge *br = netdev_priv(dev); |
@@ -691,6 +692,10 @@ int br_fdb_dump(struct sk_buff *skb, | |||
691 | if (idx < cb->args[0]) | 692 | if (idx < cb->args[0]) |
692 | goto skip; | 693 | goto skip; |
693 | 694 | ||
695 | if (filter_dev && (!f->dst || !f->dst->dev || | ||
696 | f->dst->dev != filter_dev)) | ||
697 | goto skip; | ||
698 | |||
694 | if (fdb_fill_info(skb, br, f, | 699 | if (fdb_fill_info(skb, br, f, |
695 | NETLINK_CB(cb->skb).portid, | 700 | NETLINK_CB(cb->skb).portid, |
696 | cb->nlh->nlmsg_seq, | 701 | cb->nlh->nlmsg_seq, |
diff --git a/net/bridge/br_private.h b/net/bridge/br_private.h index 23caf5b0309e..62a7fa2e3569 100644 --- a/net/bridge/br_private.h +++ b/net/bridge/br_private.h | |||
@@ -399,7 +399,7 @@ int br_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], | |||
399 | int br_fdb_add(struct ndmsg *nlh, struct nlattr *tb[], struct net_device *dev, | 399 | int br_fdb_add(struct ndmsg *nlh, struct nlattr *tb[], struct net_device *dev, |
400 | const unsigned char *addr, u16 nlh_flags); | 400 | const unsigned char *addr, u16 nlh_flags); |
401 | int br_fdb_dump(struct sk_buff *skb, struct netlink_callback *cb, | 401 | int br_fdb_dump(struct sk_buff *skb, struct netlink_callback *cb, |
402 | struct net_device *dev, int idx); | 402 | struct net_device *dev, struct net_device *fdev, int idx); |
403 | int br_fdb_sync_static(struct net_bridge *br, struct net_bridge_port *p); | 403 | int br_fdb_sync_static(struct net_bridge *br, struct net_bridge_port *p); |
404 | void br_fdb_unsync_static(struct net_bridge *br, struct net_bridge_port *p); | 404 | void br_fdb_unsync_static(struct net_bridge *br, struct net_bridge_port *p); |
405 | 405 | ||
diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c index 27acaf7ff6d7..90a906e7ac26 100644 --- a/net/core/rtnetlink.c +++ b/net/core/rtnetlink.c | |||
@@ -2517,6 +2517,7 @@ skip: | |||
2517 | int ndo_dflt_fdb_dump(struct sk_buff *skb, | 2517 | int ndo_dflt_fdb_dump(struct sk_buff *skb, |
2518 | struct netlink_callback *cb, | 2518 | struct netlink_callback *cb, |
2519 | struct net_device *dev, | 2519 | struct net_device *dev, |
2520 | struct net_device *filter_dev, | ||
2520 | int idx) | 2521 | int idx) |
2521 | { | 2522 | { |
2522 | int err; | 2523 | int err; |
@@ -2547,13 +2548,15 @@ static int rtnl_fdb_dump(struct sk_buff *skb, struct netlink_callback *cb) | |||
2547 | br_dev = netdev_master_upper_dev_get(dev); | 2548 | br_dev = netdev_master_upper_dev_get(dev); |
2548 | ops = br_dev->netdev_ops; | 2549 | ops = br_dev->netdev_ops; |
2549 | if (ops->ndo_fdb_dump) | 2550 | if (ops->ndo_fdb_dump) |
2550 | idx = ops->ndo_fdb_dump(skb, cb, dev, idx); | 2551 | idx = ops->ndo_fdb_dump(skb, cb, dev, NULL, |
2552 | idx); | ||
2551 | } | 2553 | } |
2552 | 2554 | ||
2553 | if (dev->netdev_ops->ndo_fdb_dump) | 2555 | if (dev->netdev_ops->ndo_fdb_dump) |
2554 | idx = dev->netdev_ops->ndo_fdb_dump(skb, cb, dev, idx); | 2556 | idx = dev->netdev_ops->ndo_fdb_dump(skb, cb, dev, NULL, |
2557 | idx); | ||
2555 | else | 2558 | else |
2556 | idx = ndo_dflt_fdb_dump(skb, cb, dev, idx); | 2559 | idx = ndo_dflt_fdb_dump(skb, cb, dev, NULL, idx); |
2557 | } | 2560 | } |
2558 | rcu_read_unlock(); | 2561 | rcu_read_unlock(); |
2559 | 2562 | ||