X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=bridge.c;h=ce22b754f4d3f9512da2bb9f7ac1f1d7de964e56;hp=3edfeaac4abf741dee2940e608cad0500c4c74c6;hb=9af0e57ce2c76db2ce49ea9fbfb5766da6000ec6;hpb=98ca67469da70accd710b14c28e77be2126170a8 diff --git a/bridge.c b/bridge.c index 3edfeaa..ce22b75 100644 --- a/bridge.c +++ b/bridge.c @@ -344,7 +344,11 @@ bridge_create_member(struct bridge_state *bst, struct device *dev, bool hotplug) strcpy(bm->name, dev->ifname); bm->dev.dev = dev; vlist_add(&bst->members, &bm->node, bm->name); - if (hotplug) + // Need to look up the bridge member again as the above + // created pointer will be freed in case the bridge member + // already existed + bm = vlist_find(&bst->members, dev->ifname, bm, node); + if (hotplug && bm) bm->node.version = -1; return bm; @@ -492,7 +496,7 @@ bridge_apply_settings(struct bridge_state *bst, struct blob_attr **tb) /* defaults */ cfg->stp = false; cfg->forward_delay = 2; - cfg->igmp_snoop = false; + cfg->igmp_snoop = true; cfg->bridge_empty = false; cfg->priority = 0x7FFF;