Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 5d09e534 authored by Narender Kumar's avatar Narender Kumar Committed by David S. Miller
Browse files

netxen : fix BOND_MODE_TLB/ALB mode.



o Along with netdev->perm_addr, mac address will be
  maintained in device private structure.

o Device limitation: We need to set mac address when ever
  interface comes up.

In ALB/TAL mode, bonding driver calls set_mac for all slave with bond mac address.
But bonding driver set netdev->dev_addr field to its original value,
after enslaving interfaces.

When ever active slave changes, it swap dev_addr of inactive slave with active.
Yet it doesn't notify driver about change in netdev->dev_addr.

As netxen driver need to set mac addr when ever interface comes up,
it can't rely on netdev->dev_addr field. Specially in case of bonding mode ALB/TLB.

Signed-off-by: default avatarNarender Kumar <narender.kumar@qlogic.com>
Signed-off-by: default avatarAmit Kumar Salecha <amit.salecha@qlogic.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a7483b0a
Loading
Loading
Loading
Loading
+2 −0
Original line number Original line Diff line number Diff line
@@ -1163,6 +1163,8 @@ struct netxen_adapter {
	u32 int_vec_bit;
	u32 int_vec_bit;
	u32 heartbit;
	u32 heartbit;


	u8 mac_addr[ETH_ALEN];

	struct netxen_adapter_stats stats;
	struct netxen_adapter_stats stats;


	struct netxen_recv_context recv_ctx;
	struct netxen_recv_context recv_ctx;
+3 −3
Original line number Original line Diff line number Diff line
@@ -463,7 +463,7 @@ netxen_nic_enable_mcast_filter(struct netxen_adapter *adapter)
{
{
	u32	val = 0;
	u32	val = 0;
	u16 port = adapter->physical_port;
	u16 port = adapter->physical_port;
	u8 *addr = adapter->netdev->dev_addr;
	u8 *addr = adapter->mac_addr;


	if (adapter->mc_enabled)
	if (adapter->mc_enabled)
		return 0;
		return 0;
@@ -492,7 +492,7 @@ netxen_nic_disable_mcast_filter(struct netxen_adapter *adapter)
{
{
	u32	val = 0;
	u32	val = 0;
	u16 port = adapter->physical_port;
	u16 port = adapter->physical_port;
	u8 *addr = adapter->netdev->dev_addr;
	u8 *addr = adapter->mac_addr;


	if (!adapter->mc_enabled)
	if (!adapter->mc_enabled)
		return 0;
		return 0;
@@ -687,7 +687,7 @@ void netxen_p3_nic_set_multi(struct net_device *netdev)


	list_splice_tail_init(&adapter->mac_list, &del_list);
	list_splice_tail_init(&adapter->mac_list, &del_list);


	nx_p3_nic_add_mac(adapter, netdev->dev_addr, &del_list);
	nx_p3_nic_add_mac(adapter, adapter->mac_addr, &del_list);
	nx_p3_nic_add_mac(adapter, bcast_addr, &del_list);
	nx_p3_nic_add_mac(adapter, bcast_addr, &del_list);


	if (netdev->flags & IFF_PROMISC) {
	if (netdev->flags & IFF_PROMISC) {
+3 −1
Original line number Original line Diff line number Diff line
@@ -437,6 +437,7 @@ netxen_read_mac_addr(struct netxen_adapter *adapter)
		netdev->dev_addr[i] = *(p + 5 - i);
		netdev->dev_addr[i] = *(p + 5 - i);


	memcpy(netdev->perm_addr, netdev->dev_addr, netdev->addr_len);
	memcpy(netdev->perm_addr, netdev->dev_addr, netdev->addr_len);
	memcpy(adapter->mac_addr, netdev->dev_addr, netdev->addr_len);


	/* set station address */
	/* set station address */


@@ -459,6 +460,7 @@ int netxen_nic_set_mac(struct net_device *netdev, void *p)
		netxen_napi_disable(adapter);
		netxen_napi_disable(adapter);
	}
	}


	memcpy(adapter->mac_addr, addr->sa_data, netdev->addr_len);
	memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len);
	memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len);
	adapter->macaddr_set(adapter, addr->sa_data);
	adapter->macaddr_set(adapter, addr->sa_data);


@@ -956,7 +958,7 @@ netxen_nic_up(struct netxen_adapter *adapter, struct net_device *netdev)
		return err;
		return err;
	}
	}
	if (NX_IS_REVISION_P2(adapter->ahw.revision_id))
	if (NX_IS_REVISION_P2(adapter->ahw.revision_id))
		adapter->macaddr_set(adapter, netdev->dev_addr);
		adapter->macaddr_set(adapter, adapter->mac_addr);


	adapter->set_multi(netdev);
	adapter->set_multi(netdev);
	adapter->set_mtu(adapter, netdev->mtu);
	adapter->set_mtu(adapter, netdev->mtu);