br_port_get() renamed to br_port_get_rtnl() to make clear RTNL is held.
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
 {
        struct net_bridge_port *p;
 
-       p = br_port_get(dev);
+       p = br_port_get_rtnl(dev);
        if (!p || p->br != br)
                return -EINVAL;
 
 
 
        idx = 0;
        for_each_netdev(net, dev) {
-               struct net_bridge_port *port = br_port_get(dev);
+               struct net_bridge_port *port = br_port_get_rtnl(dev);
 
                /* not a bridge port */
                if (!port || idx < cb->args[0])
        if (!dev)
                return -ENODEV;
 
-       p = br_port_get(dev);
+       p = br_port_get_rtnl(dev);
        if (!p)
                return -EINVAL;
 
 
        int err;
 
        /* not a port of a bridge */
-       if (!br_port_exists(dev))
+       p = br_port_get_rtnl(dev);
+       if (!p)
                return NOTIFY_DONE;
 
-       p = br_port_get(dev);
        br = p->br;
 
        switch (event) {
 
        return br_port_exists(dev) ? port : NULL;
 }
 
-static inline struct net_bridge_port *br_port_get(struct net_device *dev)
+static inline struct net_bridge_port *br_port_get_rtnl(struct net_device *dev)
 {
-       return br_port_exists(dev) ? dev->rx_handler_data : NULL;
+       return br_port_exists(dev) ?
+               rtnl_dereference(dev->rx_handler_data) : NULL;
 }
 
 struct br_cpu_netstats {