]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
bridge: mdb: start delete timer for temp static entries
authorSatish Ashok <sashok@cumulusnetworks.com>
Mon, 6 Jul 2015 12:53:35 +0000 (05:53 -0700)
committerLuis Henriques <luis.henriques@canonical.com>
Mon, 10 Aug 2015 16:10:16 +0000 (17:10 +0100)
commit f7e2965db17dd3b60f05fad88e7afc79ea75b48f upstream.

Start the delete timer when adding temp static entries so they can expire.

Signed-off-by: Satish Ashok <sashok@cumulusnetworks.com>
Signed-off-by: Nikolay Aleksandrov <nikolay@cumulusnetworks.com>
Fixes: ccb1c31a7a87 ("bridge: add flags to distinguish permanent mdb entires")
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Luis Henriques <luis.henriques@canonical.com>
net/bridge/br_mdb.c

index d8b1833a363e78817d788ca721b19c2ae7212480..21927405cf4ea1db9739489d1b7c10f59ec5c5cb 100644 (file)
@@ -322,6 +322,7 @@ static int br_mdb_add_group(struct net_bridge *br, struct net_bridge_port *port,
        struct net_bridge_port_group *p;
        struct net_bridge_port_group __rcu **pp;
        struct net_bridge_mdb_htable *mdb;
+       unsigned long now = jiffies;
        int err;
 
        mdb = mlock_dereference(br->mdb, br);
@@ -346,6 +347,8 @@ static int br_mdb_add_group(struct net_bridge *br, struct net_bridge_port *port,
        if (unlikely(!p))
                return -ENOMEM;
        rcu_assign_pointer(*pp, p);
+       if (state == MDB_TEMPORARY)
+               mod_timer(&p->timer, now + br->multicast_membership_interval);
 
        br_mdb_notify(br->dev, port, group, RTM_NEWMDB);
        return 0;