X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=system-linux.c;h=6dc9acd82db704573a54a4ca53cd43ee722e7a1b;hp=0ba729e826fc584a652bbb55a81eafbe5d8297ef;hb=3653d721dad44c5a63790a3fd67e819dfb1dc428;hpb=5990d1126fd33665e106508ebcbadfbb2d703d8e diff --git a/system-linux.c b/system-linux.c index 0ba729e..6dc9acd 100644 --- a/system-linux.c +++ b/system-linux.c @@ -791,6 +791,7 @@ sec_to_jiffies(int val) int system_bridge_addbr(struct device *bridge, struct bridge_config *cfg) { + char buf[64]; unsigned long args[4] = {}; if (ioctl(sock_ioctl, SIOCBRADDBR, bridge->ifname) < 0) @@ -810,6 +811,10 @@ int system_bridge_addbr(struct device *bridge, struct bridge_config *cfg) system_set_dev_sysctl("/sys/devices/virtual/net/%s/bridge/multicast_querier", bridge->ifname, cfg->multicast_querier ? "1" : "0"); + snprintf(buf, sizeof(buf), "%i", cfg->hash_max); + system_set_dev_sysctl("/sys/devices/virtual/net/%s/bridge/hash_max", + bridge->ifname, buf); + args[0] = BRCTL_SET_BRIDGE_PRIORITY; args[1] = cfg->priority; system_bridge_if(bridge->ifname, NULL, SIOCDEVPRIVATE, &args);