aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/bridge/br_fdb.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/net/bridge/br_fdb.c b/net/bridge/br_fdb.c
index 88485cc74dc3..70bd0bf04099 100644
--- a/net/bridge/br_fdb.c
+++ b/net/bridge/br_fdb.c
@@ -320,8 +320,7 @@ static inline struct net_bridge_fdb_entry *fdb_find(struct hlist_head *head,
320 320
321static struct net_bridge_fdb_entry *fdb_create(struct hlist_head *head, 321static struct net_bridge_fdb_entry *fdb_create(struct hlist_head *head,
322 struct net_bridge_port *source, 322 struct net_bridge_port *source,
323 const unsigned char *addr, 323 const unsigned char *addr)
324 int is_local)
325{ 324{
326 struct net_bridge_fdb_entry *fdb; 325 struct net_bridge_fdb_entry *fdb;
327 326
@@ -329,10 +328,9 @@ static struct net_bridge_fdb_entry *fdb_create(struct hlist_head *head,
329 if (fdb) { 328 if (fdb) {
330 memcpy(fdb->addr.addr, addr, ETH_ALEN); 329 memcpy(fdb->addr.addr, addr, ETH_ALEN);
331 fdb->dst = source; 330 fdb->dst = source;
332 fdb->is_local = is_local; 331 fdb->is_local = 0;
333 fdb->is_static = is_local; 332 fdb->is_static = 0;
334 fdb->ageing_timer = jiffies; 333 fdb->ageing_timer = jiffies;
335
336 hlist_add_head_rcu(&fdb->hlist, head); 334 hlist_add_head_rcu(&fdb->hlist, head);
337 } 335 }
338 return fdb; 336 return fdb;
@@ -360,12 +358,15 @@ static int fdb_insert(struct net_bridge *br, struct net_bridge_port *source,
360 fdb_delete(fdb); 358 fdb_delete(fdb);
361 } 359 }
362 360
363 if (!fdb_create(head, source, addr, 1)) 361 fdb = fdb_create(head, source, addr);
362 if (!fdb)
364 return -ENOMEM; 363 return -ENOMEM;
365 364
365 fdb->is_local = fdb->is_static = 1;
366 return 0; 366 return 0;
367} 367}
368 368
369/* Add entry for local address of interface */
369int br_fdb_insert(struct net_bridge *br, struct net_bridge_port *source, 370int br_fdb_insert(struct net_bridge *br, struct net_bridge_port *source,
370 const unsigned char *addr) 371 const unsigned char *addr)
371{ 372{
@@ -407,8 +408,9 @@ void br_fdb_update(struct net_bridge *br, struct net_bridge_port *source,
407 } 408 }
408 } else { 409 } else {
409 spin_lock(&br->hash_lock); 410 spin_lock(&br->hash_lock);
410 if (!fdb_find(head, addr)) 411 if (likely(!fdb_find(head, addr)))
411 fdb_create(head, source, addr, 0); 412 fdb_create(head, source, addr);
413
412 /* else we lose race and someone else inserts 414 /* else we lose race and someone else inserts
413 * it first, don't bother updating 415 * it first, don't bother updating
414 */ 416 */