be2net: use SET/GET_MAC_LIST for SH-R
On SH-R and Lancer-R, GET_MAC_LIST cmd is better supported (instead of NTWK_MAC_QUERY cmd) to query provisioned MAC addresses. Similiarly, (on SH-R and Lancer-R) SET_MAC_LIST must be used by the PF to provision a permanent MAC addresses to the VF. Signed-off-by: Sathya Perla <sathya.perla@emulex.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
95046b927a
commit
3175d8c2d0
|
@ -2740,19 +2740,15 @@ out:
|
||||||
|
|
||||||
int be_cmd_get_active_mac(struct be_adapter *adapter, u32 curr_pmac_id, u8 *mac)
|
int be_cmd_get_active_mac(struct be_adapter *adapter, u32 curr_pmac_id, u8 *mac)
|
||||||
{
|
{
|
||||||
int status;
|
|
||||||
bool active = true;
|
bool active = true;
|
||||||
|
|
||||||
/* When SH FW is ready, SH should use Lancer path too */
|
if (BEx_chip(adapter))
|
||||||
if (lancer_chip(adapter)) {
|
|
||||||
/* Fetch the MAC address using pmac_id */
|
|
||||||
status = be_cmd_get_mac_from_list(adapter, mac, &active,
|
|
||||||
&curr_pmac_id, 0);
|
|
||||||
return status;
|
|
||||||
} else {
|
|
||||||
return be_cmd_mac_addr_query(adapter, mac, false,
|
return be_cmd_mac_addr_query(adapter, mac, false,
|
||||||
adapter->if_handle, curr_pmac_id);
|
adapter->if_handle, curr_pmac_id);
|
||||||
}
|
else
|
||||||
|
/* Fetch the MAC address using pmac_id */
|
||||||
|
return be_cmd_get_mac_from_list(adapter, mac, &active,
|
||||||
|
&curr_pmac_id, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int be_cmd_get_perm_mac(struct be_adapter *adapter, u8 *mac)
|
int be_cmd_get_perm_mac(struct be_adapter *adapter, u8 *mac)
|
||||||
|
@ -2762,14 +2758,18 @@ int be_cmd_get_perm_mac(struct be_adapter *adapter, u8 *mac)
|
||||||
|
|
||||||
memset(mac, 0, ETH_ALEN);
|
memset(mac, 0, ETH_ALEN);
|
||||||
|
|
||||||
if (lancer_chip(adapter))
|
if (BEx_chip(adapter)) {
|
||||||
status = be_cmd_get_mac_from_list(adapter, mac, &pmac_valid,
|
if (be_physfn(adapter))
|
||||||
NULL, 0);
|
status = be_cmd_mac_addr_query(adapter, mac, true, 0,
|
||||||
else if (be_physfn(adapter))
|
0);
|
||||||
status = be_cmd_mac_addr_query(adapter, mac, true, 0, 0);
|
|
||||||
else
|
else
|
||||||
status = be_cmd_mac_addr_query(adapter, mac, false,
|
status = be_cmd_mac_addr_query(adapter, mac, false,
|
||||||
adapter->if_handle, 0);
|
adapter->if_handle, 0);
|
||||||
|
} else {
|
||||||
|
status = be_cmd_get_mac_from_list(adapter, mac, &pmac_valid,
|
||||||
|
NULL, 0);
|
||||||
|
}
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2816,6 +2816,25 @@ err:
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Wrapper to delete any active MACs and provision the new mac.
|
||||||
|
* Changes to MAC_LIST are allowed iff none of the MAC addresses in the
|
||||||
|
* current list are active.
|
||||||
|
*/
|
||||||
|
int be_cmd_set_mac(struct be_adapter *adapter, u8 *mac, int if_id, u32 dom)
|
||||||
|
{
|
||||||
|
bool active_mac = false;
|
||||||
|
u8 old_mac[ETH_ALEN];
|
||||||
|
u32 pmac_id;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
status = be_cmd_get_mac_from_list(adapter, old_mac, &active_mac,
|
||||||
|
&pmac_id, dom);
|
||||||
|
if (!status && active_mac)
|
||||||
|
be_cmd_pmac_del(adapter, if_id, pmac_id, dom);
|
||||||
|
|
||||||
|
return be_cmd_set_mac_list(adapter, mac, mac ? 1 : 0, dom);
|
||||||
|
}
|
||||||
|
|
||||||
int be_cmd_set_hsw_config(struct be_adapter *adapter, u16 pvid,
|
int be_cmd_set_hsw_config(struct be_adapter *adapter, u16 pvid,
|
||||||
u32 domain, u16 intf_id)
|
u32 domain, u16 intf_id)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1937,6 +1937,8 @@ extern int be_cmd_get_active_mac(struct be_adapter *adapter, u32 pmac_id,
|
||||||
extern int be_cmd_get_perm_mac(struct be_adapter *adapter, u8 *mac);
|
extern int be_cmd_get_perm_mac(struct be_adapter *adapter, u8 *mac);
|
||||||
extern int be_cmd_set_mac_list(struct be_adapter *adapter, u8 *mac_array,
|
extern int be_cmd_set_mac_list(struct be_adapter *adapter, u8 *mac_array,
|
||||||
u8 mac_count, u32 domain);
|
u8 mac_count, u32 domain);
|
||||||
|
extern int be_cmd_set_mac(struct be_adapter *adapter, u8 *mac, int if_id,
|
||||||
|
u32 dom);
|
||||||
extern int be_cmd_set_hsw_config(struct be_adapter *adapter, u16 pvid,
|
extern int be_cmd_set_hsw_config(struct be_adapter *adapter, u16 pvid,
|
||||||
u32 domain, u16 intf_id);
|
u32 domain, u16 intf_id);
|
||||||
extern int be_cmd_get_hsw_config(struct be_adapter *adapter, u16 *pvid,
|
extern int be_cmd_get_hsw_config(struct be_adapter *adapter, u16 *pvid,
|
||||||
|
|
|
@ -1146,9 +1146,6 @@ static int be_set_vf_mac(struct net_device *netdev, int vf, u8 *mac)
|
||||||
struct be_adapter *adapter = netdev_priv(netdev);
|
struct be_adapter *adapter = netdev_priv(netdev);
|
||||||
struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf];
|
struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf];
|
||||||
int status;
|
int status;
|
||||||
bool active_mac = false;
|
|
||||||
u32 pmac_id;
|
|
||||||
u8 old_mac[ETH_ALEN];
|
|
||||||
|
|
||||||
if (!sriov_enabled(adapter))
|
if (!sriov_enabled(adapter))
|
||||||
return -EPERM;
|
return -EPERM;
|
||||||
|
@ -1156,20 +1153,15 @@ static int be_set_vf_mac(struct net_device *netdev, int vf, u8 *mac)
|
||||||
if (!is_valid_ether_addr(mac) || vf >= adapter->num_vfs)
|
if (!is_valid_ether_addr(mac) || vf >= adapter->num_vfs)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (lancer_chip(adapter)) {
|
if (BEx_chip(adapter)) {
|
||||||
status = be_cmd_get_mac_from_list(adapter, old_mac, &active_mac,
|
be_cmd_pmac_del(adapter, vf_cfg->if_handle, vf_cfg->pmac_id,
|
||||||
&pmac_id, vf + 1);
|
vf + 1);
|
||||||
if (!status && active_mac)
|
|
||||||
be_cmd_pmac_del(adapter, vf_cfg->if_handle,
|
|
||||||
pmac_id, vf + 1);
|
|
||||||
|
|
||||||
status = be_cmd_set_mac_list(adapter, mac, 1, vf + 1);
|
|
||||||
} else {
|
|
||||||
status = be_cmd_pmac_del(adapter, vf_cfg->if_handle,
|
|
||||||
vf_cfg->pmac_id, vf + 1);
|
|
||||||
|
|
||||||
status = be_cmd_pmac_add(adapter, mac, vf_cfg->if_handle,
|
status = be_cmd_pmac_add(adapter, mac, vf_cfg->if_handle,
|
||||||
&vf_cfg->pmac_id, vf + 1);
|
&vf_cfg->pmac_id, vf + 1);
|
||||||
|
} else {
|
||||||
|
status = be_cmd_set_mac(adapter, mac, vf_cfg->if_handle,
|
||||||
|
vf + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status)
|
if (status)
|
||||||
|
@ -2735,13 +2727,13 @@ static int be_vf_eth_addr_config(struct be_adapter *adapter)
|
||||||
be_vf_eth_addr_generate(adapter, mac);
|
be_vf_eth_addr_generate(adapter, mac);
|
||||||
|
|
||||||
for_all_vfs(adapter, vf_cfg, vf) {
|
for_all_vfs(adapter, vf_cfg, vf) {
|
||||||
if (lancer_chip(adapter)) {
|
if (BEx_chip(adapter))
|
||||||
status = be_cmd_set_mac_list(adapter, mac, 1, vf + 1);
|
|
||||||
} else {
|
|
||||||
status = be_cmd_pmac_add(adapter, mac,
|
status = be_cmd_pmac_add(adapter, mac,
|
||||||
vf_cfg->if_handle,
|
vf_cfg->if_handle,
|
||||||
&vf_cfg->pmac_id, vf + 1);
|
&vf_cfg->pmac_id, vf + 1);
|
||||||
}
|
else
|
||||||
|
status = be_cmd_set_mac(adapter, mac, vf_cfg->if_handle,
|
||||||
|
vf + 1);
|
||||||
|
|
||||||
if (status)
|
if (status)
|
||||||
dev_err(&adapter->pdev->dev,
|
dev_err(&adapter->pdev->dev,
|
||||||
|
@ -2788,11 +2780,12 @@ static void be_vf_clear(struct be_adapter *adapter)
|
||||||
pci_disable_sriov(adapter->pdev);
|
pci_disable_sriov(adapter->pdev);
|
||||||
|
|
||||||
for_all_vfs(adapter, vf_cfg, vf) {
|
for_all_vfs(adapter, vf_cfg, vf) {
|
||||||
if (lancer_chip(adapter))
|
if (BEx_chip(adapter))
|
||||||
be_cmd_set_mac_list(adapter, NULL, 0, vf + 1);
|
|
||||||
else
|
|
||||||
be_cmd_pmac_del(adapter, vf_cfg->if_handle,
|
be_cmd_pmac_del(adapter, vf_cfg->if_handle,
|
||||||
vf_cfg->pmac_id, vf + 1);
|
vf_cfg->pmac_id, vf + 1);
|
||||||
|
else
|
||||||
|
be_cmd_set_mac(adapter, NULL, vf_cfg->if_handle,
|
||||||
|
vf + 1);
|
||||||
|
|
||||||
be_cmd_if_destroy(adapter, vf_cfg->if_handle, vf + 1);
|
be_cmd_if_destroy(adapter, vf_cfg->if_handle, vf + 1);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue