bridge: Fix incorrect judgment of promisc
authorToshiaki Makita <makita.toshiaki@lab.ntt.co.jp>
Thu, 5 Jun 2014 11:53:32 +0000 (20:53 +0900)
committerDavid S. Miller <davem@davemloft.net>
Thu, 5 Jun 2014 22:20:31 +0000 (15:20 -0700)
br_manage_promisc() incorrectly expects br_auto_port() to return only 0
or 1, while it actually returns flags, i.e., a subset of BR_AUTO_MASK.

Signed-off-by: Toshiaki Makita <makita.toshiaki@lab.ntt.co.jp>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/bridge/br_if.c

index a08d2b8ebba63358979d517ee993d7ed3895ef41..3eca3fdf8fe1c7563150f735991e66380c4312ca 100644 (file)
@@ -153,7 +153,8 @@ void br_manage_promisc(struct net_bridge *br)
                         * This lets us disable promiscuous mode and write
                         * this config to hw.
                         */
-                       if (br->auto_cnt <= br_auto_port(p))
+                       if (br->auto_cnt == 0 ||
+                           (br->auto_cnt == 1 && br_auto_port(p)))
                                br_port_clear_promisc(p);
                        else
                                br_port_set_promisc(p);