]> git.ipfire.org Git - thirdparty/iproute2.git/commit
iplink_bridge: Add no_linklocal_learn option support
authorIdo Schimmel <idosch@nvidia.com>
Sat, 1 Oct 2022 14:35:51 +0000 (17:35 +0300)
committerDavid Ahern <dsahern@kernel.org>
Mon, 3 Oct 2022 14:38:38 +0000 (08:38 -0600)
commitc74a8bc9cf5d6b6c9d8c64d5a80c5740165f315a
tree440800f08a2d0f0a2ab04acd6415e54866d9dacc
parent6781fcee427bebc7a8cc7c29834339ca60e6232a
iplink_bridge: Add no_linklocal_learn option support

Kernel commit 70e4272b4c81 ("net: bridge: add no_linklocal_learn bool
option") added the no_linklocal_learn bridge option that can be set via
sysfs or netlink.

Add iproute2 support, allowing it to query and set the option via
netlink.

The option is useful, for example, in scenarios where we want the bridge
to be able to refresh dynamic FDB entries that were added by user space
and are pointing to locked bridge ports, but do not want the bridge to
populate its FDB from EAPOL frames used for authentication.

Example:

 $ ip -j -d link show dev br0 | jq ".[][\"linkinfo\"][\"info_data\"][\"no_linklocal_learn\"]"
 0
 $ cat /sys/class/net/br0/bridge/no_linklocal_learn
 0

 # ip link set dev br0 type bridge no_linklocal_learn 1

 $ ip -j -d link show dev br0 | jq ".[][\"linkinfo\"][\"info_data\"][\"no_linklocal_learn\"]"
 1
 $ cat /sys/class/net/br0/bridge/no_linklocal_learn
 1

 # ip link set dev br0 type bridge no_linklocal_learn 0

 $ ip -j -d link show dev br0 | jq ".[][\"linkinfo\"][\"info_data\"][\"no_linklocal_learn\"]"
 0
 $ cat /sys/class/net/br0/bridge/no_linklocal_learn
 0

Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: David Ahern <dsahern@kernel.org>
ip/iplink_bridge.c
man/man8/ip-link.8.in