Actions
Bug #164
closedLocal translation table update on a bat0 MAC change
Start date:
09/05/2012
Due date:
% Done:
0%
Estimated time:
Description
Using batman-adv 2012.3.0
When I change the MAC addresse of bat0, the local translation table is not well updated.
root@openwrt:/# batctl tl Locally retrieved addresses (from bat0) announced via TT (TTVN: 184): * 26:aa:aa:aa:aa:aa [.P...] * xx:xx:xx:xx:xx:xx [.....] * xx:xx:xx:xx:xx:xx [.....] root@openwrt:/# ifconfig bat0 hw ether 36:aa:aa:aa:aa:aa root@openwrt:/# batctl tl Locally retrieved addresses (from bat0) announced via TT (TTVN: 186): * 26:aa:aa:aa:aa:aa [.P...] * 36:aa:aa:aa:aa:aa [.....] * xx:xx:xx:xx:xx:xx [.....] * xx:xx:xx:xx:xx:xx [.....]
--> The addesse 26:aa:aa:aa:aa:aa is not deleted because tagged as NoPurge.
--> The addesse 36:aa:aa:aa:aa:aa is not tagged as NoPurge.
static int batadv_interface_set_mac_addr(struct net_device *dev, void *p) { struct batadv_priv *bat_priv = netdev_priv(dev); struct sockaddr *addr = p; if (!is_valid_ether_addr(addr->sa_data)) return -EADDRNOTAVAIL; /* only modify transtable if it has been initialized before */ if (atomic_read(&bat_priv->mesh_state) == BATADV_MESH_ACTIVE) { batadv_tt_local_remove(bat_priv, dev->dev_addr, "mac address changed", false); batadv_tt_local_add(dev, addr->sa_data, BATADV_NULL_IFINDEX); } memcpy(dev->dev_addr, addr->sa_data, ETH_ALEN); dev->addr_assign_type &= ~NET_ADDR_RANDOM; return 0; }
I think the addesse 36:aa:aa:aa:aa:aa is not tagged as NoPurged because the function batadv_tt_local_add is called before the update of mac addresse memcpy(dev->dev_addr, addr->sa_data, ETH_ALEN);
I'm right ?
Thanks.
Files
Actions