diff options
author | Christian Breunig <christian@breunig.cc> | 2023-10-22 19:01:49 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-10-22 19:01:49 +0200 |
commit | 4595bca31a6f507ecb1567807f36b42bb6fe0e38 (patch) | |
tree | 8ae649a44bb4232fd643607f2d2160c63c4b5816 /python/vyos/ifconfig | |
parent | c53a8b2a837ef39cb16e69f94b9954053355382e (diff) | |
parent | ddbcc96d216cb23ee9e46a05e777a0872cf6a51e (diff) | |
download | vyos-1x-4595bca31a6f507ecb1567807f36b42bb6fe0e38.tar.gz vyos-1x-4595bca31a6f507ecb1567807f36b42bb6fe0e38.zip |
Merge pull request #2393 from vyos/mergify/bp/sagitta/pr-2277
bonding: T5254: Fixed changing ethernet when it is a bond member (backport #2277)
Diffstat (limited to 'python/vyos/ifconfig')
-rw-r--r-- | python/vyos/ifconfig/bond.py | 13 | ||||
-rw-r--r-- | python/vyos/ifconfig/ethernet.py | 34 |
2 files changed, 47 insertions, 0 deletions
diff --git a/python/vyos/ifconfig/bond.py b/python/vyos/ifconfig/bond.py index d1d7d48c4..45e6e4c16 100644 --- a/python/vyos/ifconfig/bond.py +++ b/python/vyos/ifconfig/bond.py @@ -92,6 +92,19 @@ class BondIf(Interface): } }} + @staticmethod + def get_inherit_bond_options() -> list: + """ + Returns list of option + which are inherited from bond interface to member interfaces + :return: List of interface options + :rtype: list + """ + options = [ + 'mtu' + ] + return options + def remove(self): """ Remove interface from operating system. Removing the interface diff --git a/python/vyos/ifconfig/ethernet.py b/python/vyos/ifconfig/ethernet.py index 24ce3a803..96e5f513b 100644 --- a/python/vyos/ifconfig/ethernet.py +++ b/python/vyos/ifconfig/ethernet.py @@ -71,6 +71,40 @@ class EthernetIf(Interface): }, }} + @staticmethod + def get_bond_member_allowed_options() -> list: + """ + Return list of options which are allowed for changing, + when interface is a bond member + :return: List of interface options + :rtype: list + """ + bond_allowed_sections = [ + 'description', + 'disable', + 'disable_flow_control', + 'disable_link_detect', + 'duplex', + 'eapol.ca_certificate', + 'eapol.certificate', + 'eapol.passphrase', + 'mirror.egress', + 'mirror.ingress', + 'offload.gro', + 'offload.gso', + 'offload.lro', + 'offload.rfs', + 'offload.rps', + 'offload.sg', + 'offload.tso', + 'redirect', + 'ring_buffer.rx', + 'ring_buffer.tx', + 'speed', + 'hw_id' + ] + return bond_allowed_sections + def __init__(self, ifname, **kargs): super().__init__(ifname, **kargs) self.ethtool = Ethtool(ifname) |