mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-01-11 17:10:13 +00:00
Here is a batman-adv bugfix:
- fix duplicate MAC address check, by Matthias Schiffer -----BEGIN PGP SIGNATURE----- iQJKBAABCgA0FiEE1ilQI7G+y+fdhnrfoSvjmEKSnqEFAmgdxEYWHHN3QHNpbW9u d3VuZGVybGljaC5kZQAKCRChK+OYQpKeoSG7D/9UpiHwuCb3FCT9hZVNbRX6XChV DSv8lYedVflwYgIZCqcKlg4/svygmnNNYy4XOJeLw7kjeegGmdQsol0TouZGkqTB pNxKnporVTxwA4FDSaRwVxwF1UOlelAzcMRxAk5tpIkGPl1wBFLx7dFzWWuU7wvT c0mtkJlV0kag0OZJEZqY5fYmQNHmYde9rsTpdP44ie7SPqGHpby6MYjqfGl0ztxy 70XCMgp9ByRsCnL45UQYua17gYavKWalCsAYCikQc/+nZGkgymAaIFv5elFrou9N Dbw+k9X2ipw3v2atAUP40Bw6dvdIkTRaEpAyO5oDGM1//kqwAfUQazS+IWFYE50v eN2KRGSNJH/J2RHY0ODRomcFDotHykR8aESbkePJHc5ZFgM9E6vAzy+BPrFJaROX nRO/XmWXeVwyl9CrxoEtA0UusIEr3OQBMi2p5cV7vbcPHSPzQRuA2iKah0ZFsmB0 pGyaeEh60lO2r84lYsO04bA9q8eyZkNHUxd3pZnCpy4iAzEmgKaD7RAIygwHtRim UezzP8BO7m6dlox16/eJ2Bev2EmA3m3w/rkyFU2jrE9xv8tTkjIYs04zTifs8+F7 hAU+2WM/P0z+lCVEZzTaguEjFK4UrmnmSZxF1B4mh5AVQL5q4R5np4ncTiBdGJCl uS34escHTXWW4gHttQ== =kqur -----END PGP SIGNATURE----- Merge tag 'batadv-net-pullrequest-20250509' of git://git.open-mesh.org/linux-merge Simon Wunderlich says: ==================== Here is a batman-adv bugfix: - fix duplicate MAC address check, by Matthias Schiffer * tag 'batadv-net-pullrequest-20250509' of git://git.open-mesh.org/linux-merge: batman-adv: fix duplicate MAC address check ==================== Link: https://patch.msgid.link/20250509090240.107796-1-sw@simonwunderlich.de Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
commit
4d64321c4f
@ -506,28 +506,32 @@ batadv_hardif_is_iface_up(const struct batadv_hard_iface *hard_iface)
|
||||
return false;
|
||||
}
|
||||
|
||||
static void batadv_check_known_mac_addr(const struct net_device *net_dev)
|
||||
static void batadv_check_known_mac_addr(const struct batadv_hard_iface *hard_iface)
|
||||
{
|
||||
const struct batadv_hard_iface *hard_iface;
|
||||
const struct net_device *mesh_iface = hard_iface->mesh_iface;
|
||||
const struct batadv_hard_iface *tmp_hard_iface;
|
||||
|
||||
rcu_read_lock();
|
||||
list_for_each_entry_rcu(hard_iface, &batadv_hardif_list, list) {
|
||||
if (hard_iface->if_status != BATADV_IF_ACTIVE &&
|
||||
hard_iface->if_status != BATADV_IF_TO_BE_ACTIVATED)
|
||||
if (!mesh_iface)
|
||||
return;
|
||||
|
||||
list_for_each_entry(tmp_hard_iface, &batadv_hardif_list, list) {
|
||||
if (tmp_hard_iface == hard_iface)
|
||||
continue;
|
||||
|
||||
if (hard_iface->net_dev == net_dev)
|
||||
if (tmp_hard_iface->mesh_iface != mesh_iface)
|
||||
continue;
|
||||
|
||||
if (!batadv_compare_eth(hard_iface->net_dev->dev_addr,
|
||||
net_dev->dev_addr))
|
||||
if (tmp_hard_iface->if_status == BATADV_IF_NOT_IN_USE)
|
||||
continue;
|
||||
|
||||
if (!batadv_compare_eth(tmp_hard_iface->net_dev->dev_addr,
|
||||
hard_iface->net_dev->dev_addr))
|
||||
continue;
|
||||
|
||||
pr_warn("The newly added mac address (%pM) already exists on: %s\n",
|
||||
net_dev->dev_addr, hard_iface->net_dev->name);
|
||||
hard_iface->net_dev->dev_addr, tmp_hard_iface->net_dev->name);
|
||||
pr_warn("It is strongly recommended to keep mac addresses unique to avoid problems!\n");
|
||||
}
|
||||
rcu_read_unlock();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -763,6 +767,8 @@ int batadv_hardif_enable_interface(struct batadv_hard_iface *hard_iface,
|
||||
hard_iface->net_dev->name, hardif_mtu,
|
||||
required_mtu);
|
||||
|
||||
batadv_check_known_mac_addr(hard_iface);
|
||||
|
||||
if (batadv_hardif_is_iface_up(hard_iface))
|
||||
batadv_hardif_activate_interface(hard_iface);
|
||||
else
|
||||
@ -901,7 +907,6 @@ batadv_hardif_add_interface(struct net_device *net_dev)
|
||||
|
||||
batadv_v_hardif_init(hard_iface);
|
||||
|
||||
batadv_check_known_mac_addr(hard_iface->net_dev);
|
||||
kref_get(&hard_iface->refcount);
|
||||
list_add_tail_rcu(&hard_iface->list, &batadv_hardif_list);
|
||||
batadv_hardif_generation++;
|
||||
@ -988,7 +993,7 @@ static int batadv_hard_if_event(struct notifier_block *this,
|
||||
if (hard_iface->if_status == BATADV_IF_NOT_IN_USE)
|
||||
goto hardif_put;
|
||||
|
||||
batadv_check_known_mac_addr(hard_iface->net_dev);
|
||||
batadv_check_known_mac_addr(hard_iface);
|
||||
|
||||
bat_priv = netdev_priv(hard_iface->mesh_iface);
|
||||
bat_priv->algo_ops->iface.update_mac(hard_iface);
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user