OSDN Git Service

bridge: Extend br_fill_ifinfo to return MPR status
authorHoratiu Vultur <horatiu.vultur@microchip.com>
Thu, 2 Jul 2020 08:13:07 +0000 (10:13 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 2 Jul 2020 21:19:15 +0000 (14:19 -0700)
This patch extends the function br_fill_ifinfo to return also the MRP
status for each instance on a bridge. It also adds a new filter
RTEXT_FILTER_MRP to return the MRP status only when this is set, not to
interfer with the vlans. The MRP status is return only on the bridge
interfaces.

Signed-off-by: Horatiu Vultur <horatiu.vultur@microchip.com>
Acked-by: Nikolay Aleksandrov <nikolay@cumulusnetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/uapi/linux/rtnetlink.h
net/bridge/br_netlink.c

index 879e649..9b814c9 100644 (file)
@@ -778,6 +778,7 @@ enum {
 #define RTEXT_FILTER_BRVLAN    (1 << 1)
 #define RTEXT_FILTER_BRVLAN_COMPRESSED (1 << 2)
 #define        RTEXT_FILTER_SKIP_STATS (1 << 3)
+#define RTEXT_FILTER_MRP       (1 << 4)
 
 /* End of information exported to user level */
 
index 240e260..c532fa6 100644 (file)
@@ -453,6 +453,28 @@ static int br_fill_ifinfo(struct sk_buff *skb,
                rcu_read_unlock();
                if (err)
                        goto nla_put_failure;
+
+               nla_nest_end(skb, af);
+       }
+
+       if (filter_mask & RTEXT_FILTER_MRP) {
+               struct nlattr *af;
+               int err;
+
+               if (!br_mrp_enabled(br) || port)
+                       goto done;
+
+               af = nla_nest_start_noflag(skb, IFLA_AF_SPEC);
+               if (!af)
+                       goto nla_put_failure;
+
+               rcu_read_lock();
+               err = br_mrp_fill_info(skb, br);
+               rcu_read_unlock();
+
+               if (err)
+                       goto nla_put_failure;
+
                nla_nest_end(skb, af);
        }
 
@@ -516,7 +538,8 @@ int br_getlink(struct sk_buff *skb, u32 pid, u32 seq,
        struct net_bridge_port *port = br_port_get_rtnl(dev);
 
        if (!port && !(filter_mask & RTEXT_FILTER_BRVLAN) &&
-           !(filter_mask & RTEXT_FILTER_BRVLAN_COMPRESSED))
+           !(filter_mask & RTEXT_FILTER_BRVLAN_COMPRESSED) &&
+           !(filter_mask & RTEXT_FILTER_MRP))
                return 0;
 
        return br_fill_ifinfo(skb, port, pid, seq, RTM_NEWLINK, nlflags,