diff options
-rw-r--r-- | device.h | 1 | ||||
-rw-r--r-- | system-linux.c | 8 | ||||
-rw-r--r-- | wireless.c | 2 |
3 files changed, 11 insertions, 0 deletions
@@ -244,6 +244,7 @@ struct device { bool wireless; bool wireless_ap; bool wireless_isolate; + bool bpdu_filter; struct interface *config_iface; diff --git a/system-linux.c b/system-linux.c index 85942a5..355bf69 100644 --- a/system-linux.c +++ b/system-linux.c @@ -404,6 +404,11 @@ static void system_bridge_set_hairpin_mode(struct device *dev, const char *val) system_set_dev_sysctl("/sys/class/net/%s/brport/hairpin_mode", dev->ifname, val); } +static void system_bridge_set_bpdu_filter(struct device *dev, const char *val) +{ + system_set_dev_sysctl("/sys/class/net/%s/brport/bpdu_filter", dev->ifname, val); +} + static void system_bridge_set_isolated(struct device *dev, const char *val) { system_set_dev_sysctl("/sys/class/net/%s/brport/isolated", dev->ifname, val); @@ -893,6 +898,9 @@ retry: dev->settings.isolate) system_bridge_set_isolated(dev, "1"); + if (dev->bpdu_filter) + system_bridge_set_bpdu_filter(dev, dev->bpdu_filter ? "1" : "0"); + return ret; } @@ -332,6 +332,7 @@ static void wireless_interface_handle_link(struct wireless_interface *vif, const dev->wireless_isolate = vif->isolate; dev->wireless = true; dev->wireless_ap = vif->ap_mode; + dev->bpdu_filter = dev->wireless_ap && ifname == vif->ifname; } } @@ -362,6 +363,7 @@ static void wireless_vlan_handle_link(struct wireless_vlan *vlan, bool up) dev->wireless_isolate = vlan->isolate; dev->wireless = true; dev->wireless_ap = true; + dev->bpdu_filter = true; } } |