When a netdev is member in a bridge it's possible for the user to
specify whether the FDB should be populated with entries pointing to the
device.
Add the set_br_learning() method, which configures learning.
Acked-by: Jiri Pirko <jiri(a)mellanox.com>
Signed-off-by: Ido Schimmel <idosch(a)mellanox.com>
---
v1->v2:
* No change.
---
lnst/Controller/Machine.py | 4 ++++
lnst/Controller/Task.py | 3 +++
lnst/Slave/BridgeTool.py | 15 +++++++++++++++
lnst/Slave/NetTestSlave.py | 9 +++++++++
4 files changed, 31 insertions(+)
diff --git a/lnst/Controller/Machine.py b/lnst/Controller/Machine.py
index 755a2dd..4de0a35 100644
--- a/lnst/Controller/Machine.py
+++ b/lnst/Controller/Machine.py
@@ -788,6 +788,10 @@ class Interface(object):
def get_br_fdbs(self):
return self._machine._rpc_call_x(self._netns, "get_br_fdbs", self._id)
+ def set_br_learning(self, br_learning_info):
+ self._machine._rpc_call_x(self._netns, "set_br_learning", self._id,
+ br_learning_info)
+
def set_speed(self, speed):
self._machine._rpc_call_x(self._netns, "set_speed", self._id, speed)
diff --git a/lnst/Controller/Task.py b/lnst/Controller/Task.py
index 40f531b..46a885f 100644
--- a/lnst/Controller/Task.py
+++ b/lnst/Controller/Task.py
@@ -566,6 +566,9 @@ class InterfaceAPI(object):
def get_br_fdbs(self):
return self._if.get_br_fdbs()
+ def set_br_learning(_self, on=True, self=False, master=False):
+ _self._if.set_br_learning({"on": on, "self": self,
"master": master})
+
def set_speed(self, speed):
return self._if.set_speed(speed)
diff --git a/lnst/Slave/BridgeTool.py b/lnst/Slave/BridgeTool.py
index b17d246..fba630e 100644
--- a/lnst/Slave/BridgeTool.py
+++ b/lnst/Slave/BridgeTool.py
@@ -87,3 +87,18 @@ class BridgeTool:
"self": self, "master": master,
"offload": offload}
br_fdb_info_list.append(br_fdb_info)
return br_fdb_info_list
+
+ def _set_link(self, attr, br_link_info):
+ cmd = "bridge link set dev %s %s" % (self._dev_name, attr)
+ if br_link_info["on"]:
+ cmd += " on"
+ else:
+ cmd += " off"
+ if br_link_info["self"]:
+ cmd += " self"
+ if br_link_info["master"]:
+ cmd += " master"
+ exec_cmd(cmd)
+
+ def set_learning(self, br_learning_info):
+ return self._set_link("learning", br_learning_info)
diff --git a/lnst/Slave/NetTestSlave.py b/lnst/Slave/NetTestSlave.py
index 5569f07..327d34f 100644
--- a/lnst/Slave/NetTestSlave.py
+++ b/lnst/Slave/NetTestSlave.py
@@ -745,6 +745,15 @@ class SlaveMethods:
brt = BridgeTool(dev.get_name())
return brt.get_fdbs()
+ def set_br_learning(self, if_id, br_learning_info):
+ dev = self._if_manager.get_mapped_device(if_id)
+ if not dev:
+ logging.error("Device with id '%s' not found." % if_id)
+ return False
+ brt = BridgeTool(dev.get_name())
+ brt.set_learning(br_learning_info)
+ return True
+
def set_speed(self, if_id, speed):
dev = self._if_manager.get_mapped_device(if_id)
if dev is not None:
--
2.4.10
Show replies by date