Commit 11ac75ed authored by Sathya Perla's avatar Sathya Perla Committed by David S. Miller

be2net: refactor/cleanup vf configuration code

- use adapter->num_vfs (and not the module param) to store the actual
number of vfs created. Use the same variable to reflect SRIOV
enable/disable state. So, drop the adapter->sriov_enabled field.

- use for_all_vfs() macro in VF configuration code

- drop the "vf_" prefix for the fields of be_vf_cfg; the prefix is
redundant and removing it helps reduce line wrap
Signed-off-by: default avatarSathya Perla <sathya.perla@emulex.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 110b82bc
...@@ -288,11 +288,11 @@ struct be_drv_stats { ...@@ -288,11 +288,11 @@ struct be_drv_stats {
}; };
struct be_vf_cfg { struct be_vf_cfg {
unsigned char vf_mac_addr[ETH_ALEN]; unsigned char mac_addr[ETH_ALEN];
int vf_if_handle; int if_handle;
int vf_pmac_id; int pmac_id;
u16 vf_vlan_tag; u16 vlan_tag;
u32 vf_tx_rate; u32 tx_rate;
}; };
struct be_adapter { struct be_adapter {
...@@ -368,16 +368,20 @@ struct be_adapter { ...@@ -368,16 +368,20 @@ struct be_adapter {
u32 flash_status; u32 flash_status;
struct completion flash_compl; struct completion flash_compl;
bool be3_native; u32 num_vfs;
bool sriov_enabled;
struct be_vf_cfg *vf_cfg;
u8 is_virtfn; u8 is_virtfn;
struct be_vf_cfg *vf_cfg;
bool be3_native;
u32 sli_family; u32 sli_family;
u8 hba_port_num; u8 hba_port_num;
u16 pvid; u16 pvid;
}; };
#define be_physfn(adapter) (!adapter->is_virtfn) #define be_physfn(adapter) (!adapter->is_virtfn)
#define sriov_enabled(adapter) (adapter->num_vfs > 0)
#define for_all_vfs(adapter, vf_cfg, i) \
for (i = 0, vf_cfg = &adapter->vf_cfg[i]; i < adapter->num_vfs; \
i++, vf_cfg++)
/* BladeEngine Generation numbers */ /* BladeEngine Generation numbers */
#define BE_GEN2 2 #define BE_GEN2 2
......
...@@ -27,13 +27,14 @@ MODULE_DESCRIPTION(DRV_DESC " " DRV_VER); ...@@ -27,13 +27,14 @@ MODULE_DESCRIPTION(DRV_DESC " " DRV_VER);
MODULE_AUTHOR("ServerEngines Corporation"); MODULE_AUTHOR("ServerEngines Corporation");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
static ushort rx_frag_size = 2048;
static unsigned int num_vfs; static unsigned int num_vfs;
module_param(rx_frag_size, ushort, S_IRUGO);
module_param(num_vfs, uint, S_IRUGO); module_param(num_vfs, uint, S_IRUGO);
MODULE_PARM_DESC(rx_frag_size, "Size of a fragment that holds rcvd data.");
MODULE_PARM_DESC(num_vfs, "Number of PCI VFs to initialize"); MODULE_PARM_DESC(num_vfs, "Number of PCI VFs to initialize");
static ushort rx_frag_size = 2048;
module_param(rx_frag_size, ushort, S_IRUGO);
MODULE_PARM_DESC(rx_frag_size, "Size of a fragment that holds rcvd data.");
static DEFINE_PCI_DEVICE_TABLE(be_dev_ids) = { static DEFINE_PCI_DEVICE_TABLE(be_dev_ids) = {
{ PCI_DEVICE(BE_VENDOR_ID, BE_DEVICE_ID1) }, { PCI_DEVICE(BE_VENDOR_ID, BE_DEVICE_ID1) },
{ PCI_DEVICE(BE_VENDOR_ID, BE_DEVICE_ID2) }, { PCI_DEVICE(BE_VENDOR_ID, BE_DEVICE_ID2) },
...@@ -779,15 +780,15 @@ static int be_change_mtu(struct net_device *netdev, int new_mtu) ...@@ -779,15 +780,15 @@ static int be_change_mtu(struct net_device *netdev, int new_mtu)
*/ */
static int be_vid_config(struct be_adapter *adapter, bool vf, u32 vf_num) static int be_vid_config(struct be_adapter *adapter, bool vf, u32 vf_num)
{ {
struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf_num];
u16 vtag[BE_NUM_VLANS_SUPPORTED]; u16 vtag[BE_NUM_VLANS_SUPPORTED];
u16 ntags = 0, i; u16 ntags = 0, i;
int status = 0; int status = 0;
u32 if_handle;
if (vf) { if (vf) {
if_handle = adapter->vf_cfg[vf_num].vf_if_handle; vtag[0] = cpu_to_le16(vf_cfg->vlan_tag);
vtag[0] = cpu_to_le16(adapter->vf_cfg[vf_num].vf_vlan_tag); status = be_cmd_vlan_config(adapter, vf_cfg->if_handle, vtag,
status = be_cmd_vlan_config(adapter, if_handle, vtag, 1, 1, 0); 1, 1, 0);
} }
/* No need to further configure vids if in promiscuous mode */ /* No need to further configure vids if in promiscuous mode */
...@@ -877,31 +878,30 @@ static void be_set_rx_mode(struct net_device *netdev) ...@@ -877,31 +878,30 @@ static void be_set_rx_mode(struct net_device *netdev)
static int be_set_vf_mac(struct net_device *netdev, int vf, u8 *mac) 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];
int status; int status;
if (!adapter->sriov_enabled) if (!sriov_enabled(adapter))
return -EPERM; return -EPERM;
if (!is_valid_ether_addr(mac) || (vf >= num_vfs)) if (!is_valid_ether_addr(mac) || vf >= adapter->num_vfs)
return -EINVAL; return -EINVAL;
if (lancer_chip(adapter)) { if (lancer_chip(adapter)) {
status = be_cmd_set_mac_list(adapter, mac, 1, vf + 1); status = be_cmd_set_mac_list(adapter, mac, 1, vf + 1);
} else { } else {
status = be_cmd_pmac_del(adapter, status = be_cmd_pmac_del(adapter, vf_cfg->if_handle,
adapter->vf_cfg[vf].vf_if_handle, vf_cfg->pmac_id, vf + 1);
adapter->vf_cfg[vf].vf_pmac_id, vf + 1);
status = be_cmd_pmac_add(adapter, mac, status = be_cmd_pmac_add(adapter, mac, vf_cfg->if_handle,
adapter->vf_cfg[vf].vf_if_handle, &vf_cfg->pmac_id, vf + 1);
&adapter->vf_cfg[vf].vf_pmac_id, vf + 1);
} }
if (status) if (status)
dev_err(&adapter->pdev->dev, "MAC %pM set on VF %d Failed\n", dev_err(&adapter->pdev->dev, "MAC %pM set on VF %d Failed\n",
mac, vf); mac, vf);
else else
memcpy(adapter->vf_cfg[vf].vf_mac_addr, mac, ETH_ALEN); memcpy(vf_cfg->mac_addr, mac, ETH_ALEN);
return status; return status;
} }
...@@ -910,18 +910,19 @@ static int be_get_vf_config(struct net_device *netdev, int vf, ...@@ -910,18 +910,19 @@ static int be_get_vf_config(struct net_device *netdev, int vf,
struct ifla_vf_info *vi) struct ifla_vf_info *vi)
{ {
struct be_adapter *adapter = netdev_priv(netdev); struct be_adapter *adapter = netdev_priv(netdev);
struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf];
if (!adapter->sriov_enabled) if (!sriov_enabled(adapter))
return -EPERM; return -EPERM;
if (vf >= num_vfs) if (vf >= adapter->num_vfs)
return -EINVAL; return -EINVAL;
vi->vf = vf; vi->vf = vf;
vi->tx_rate = adapter->vf_cfg[vf].vf_tx_rate; vi->tx_rate = vf_cfg->tx_rate;
vi->vlan = adapter->vf_cfg[vf].vf_vlan_tag; vi->vlan = vf_cfg->vlan_tag;
vi->qos = 0; vi->qos = 0;
memcpy(&vi->mac, adapter->vf_cfg[vf].vf_mac_addr, ETH_ALEN); memcpy(&vi->mac, vf_cfg->mac_addr, ETH_ALEN);
return 0; return 0;
} }
...@@ -932,17 +933,17 @@ static int be_set_vf_vlan(struct net_device *netdev, ...@@ -932,17 +933,17 @@ static int be_set_vf_vlan(struct net_device *netdev,
struct be_adapter *adapter = netdev_priv(netdev); struct be_adapter *adapter = netdev_priv(netdev);
int status = 0; int status = 0;
if (!adapter->sriov_enabled) if (!sriov_enabled(adapter))
return -EPERM; return -EPERM;
if ((vf >= num_vfs) || (vlan > 4095)) if (vf >= adapter->num_vfs || vlan > 4095)
return -EINVAL; return -EINVAL;
if (vlan) { if (vlan) {
adapter->vf_cfg[vf].vf_vlan_tag = vlan; adapter->vf_cfg[vf].vlan_tag = vlan;
adapter->vlans_added++; adapter->vlans_added++;
} else { } else {
adapter->vf_cfg[vf].vf_vlan_tag = 0; adapter->vf_cfg[vf].vlan_tag = 0;
adapter->vlans_added--; adapter->vlans_added--;
} }
...@@ -960,16 +961,16 @@ static int be_set_vf_tx_rate(struct net_device *netdev, ...@@ -960,16 +961,16 @@ static int be_set_vf_tx_rate(struct net_device *netdev,
struct be_adapter *adapter = netdev_priv(netdev); struct be_adapter *adapter = netdev_priv(netdev);
int status = 0; int status = 0;
if (!adapter->sriov_enabled) if (!sriov_enabled(adapter))
return -EPERM; return -EPERM;
if ((vf >= num_vfs) || (rate < 0)) if (vf >= adapter->num_vfs || rate < 0)
return -EINVAL; return -EINVAL;
if (rate > 10000) if (rate > 10000)
rate = 10000; rate = 10000;
adapter->vf_cfg[vf].vf_tx_rate = rate; adapter->vf_cfg[vf].tx_rate = rate;
status = be_cmd_set_qos(adapter, rate / 10, vf + 1); status = be_cmd_set_qos(adapter, rate / 10, vf + 1);
if (status) if (status)
...@@ -1685,8 +1686,7 @@ static void be_tx_queues_destroy(struct be_adapter *adapter) ...@@ -1685,8 +1686,7 @@ static void be_tx_queues_destroy(struct be_adapter *adapter)
static int be_num_txqs_want(struct be_adapter *adapter) static int be_num_txqs_want(struct be_adapter *adapter)
{ {
if ((num_vfs && adapter->sriov_enabled) || if (sriov_enabled(adapter) || be_is_mc(adapter) ||
be_is_mc(adapter) ||
lancer_chip(adapter) || !be_physfn(adapter) || lancer_chip(adapter) || !be_physfn(adapter) ||
adapter->generation == BE_GEN2) adapter->generation == BE_GEN2)
return 1; return 1;
...@@ -1768,8 +1768,8 @@ static void be_rx_queues_destroy(struct be_adapter *adapter) ...@@ -1768,8 +1768,8 @@ static void be_rx_queues_destroy(struct be_adapter *adapter)
static u32 be_num_rxqs_want(struct be_adapter *adapter) static u32 be_num_rxqs_want(struct be_adapter *adapter)
{ {
if ((adapter->function_caps & BE_FUNCTION_CAPS_RSS) && if ((adapter->function_caps & BE_FUNCTION_CAPS_RSS) &&
!adapter->sriov_enabled && be_physfn(adapter) && !sriov_enabled(adapter) && be_physfn(adapter) &&
!be_is_mc(adapter)) { !be_is_mc(adapter)) {
return 1 + MAX_RSS_QS; /* one default non-RSS queue */ return 1 + MAX_RSS_QS; /* one default non-RSS queue */
} else { } else {
dev_warn(&adapter->pdev->dev, dev_warn(&adapter->pdev->dev,
...@@ -2116,27 +2116,28 @@ static void be_msix_enable(struct be_adapter *adapter) ...@@ -2116,27 +2116,28 @@ static void be_msix_enable(struct be_adapter *adapter)
static int be_sriov_enable(struct be_adapter *adapter) static int be_sriov_enable(struct be_adapter *adapter)
{ {
be_check_sriov_fn_type(adapter); be_check_sriov_fn_type(adapter);
#ifdef CONFIG_PCI_IOV #ifdef CONFIG_PCI_IOV
if (be_physfn(adapter) && num_vfs) { if (be_physfn(adapter) && num_vfs) {
int status, pos; int status, pos;
u16 nvfs; u16 dev_vfs;
pos = pci_find_ext_capability(adapter->pdev, pos = pci_find_ext_capability(adapter->pdev,
PCI_EXT_CAP_ID_SRIOV); PCI_EXT_CAP_ID_SRIOV);
pci_read_config_word(adapter->pdev, pci_read_config_word(adapter->pdev,
pos + PCI_SRIOV_TOTAL_VF, &nvfs); pos + PCI_SRIOV_TOTAL_VF, &dev_vfs);
if (num_vfs > nvfs) { adapter->num_vfs = min_t(u16, num_vfs, dev_vfs);
if (adapter->num_vfs != num_vfs)
dev_info(&adapter->pdev->dev, dev_info(&adapter->pdev->dev,
"Device supports %d VFs and not %d\n", "Device supports %d VFs and not %d\n",
nvfs, num_vfs); adapter->num_vfs, num_vfs);
num_vfs = nvfs;
}
status = pci_enable_sriov(adapter->pdev, num_vfs); status = pci_enable_sriov(adapter->pdev, adapter->num_vfs);
adapter->sriov_enabled = status ? false : true; if (status)
adapter->num_vfs = 0;
if (adapter->sriov_enabled) { if (adapter->num_vfs) {
adapter->vf_cfg = kcalloc(num_vfs, adapter->vf_cfg = kcalloc(num_vfs,
sizeof(struct be_vf_cfg), sizeof(struct be_vf_cfg),
GFP_KERNEL); GFP_KERNEL);
...@@ -2151,10 +2152,10 @@ static int be_sriov_enable(struct be_adapter *adapter) ...@@ -2151,10 +2152,10 @@ static int be_sriov_enable(struct be_adapter *adapter)
static void be_sriov_disable(struct be_adapter *adapter) static void be_sriov_disable(struct be_adapter *adapter)
{ {
#ifdef CONFIG_PCI_IOV #ifdef CONFIG_PCI_IOV
if (adapter->sriov_enabled) { if (sriov_enabled(adapter)) {
pci_disable_sriov(adapter->pdev); pci_disable_sriov(adapter->pdev);
kfree(adapter->vf_cfg); kfree(adapter->vf_cfg);
adapter->sriov_enabled = false; adapter->num_vfs = 0;
} }
#endif #endif
} }
...@@ -2466,24 +2467,24 @@ static inline int be_vf_eth_addr_config(struct be_adapter *adapter) ...@@ -2466,24 +2467,24 @@ static inline int be_vf_eth_addr_config(struct be_adapter *adapter)
u32 vf; u32 vf;
int status = 0; int status = 0;
u8 mac[ETH_ALEN]; u8 mac[ETH_ALEN];
struct be_vf_cfg *vf_cfg;
be_vf_eth_addr_generate(adapter, mac); be_vf_eth_addr_generate(adapter, mac);
for (vf = 0; vf < num_vfs; vf++) { for_all_vfs(adapter, vf_cfg, vf) {
if (lancer_chip(adapter)) { if (lancer_chip(adapter)) {
status = be_cmd_set_mac_list(adapter, mac, 1, vf + 1); status = be_cmd_set_mac_list(adapter, mac, 1, vf + 1);
} else { } else {
status = be_cmd_pmac_add(adapter, mac, status = be_cmd_pmac_add(adapter, mac,
adapter->vf_cfg[vf].vf_if_handle, vf_cfg->if_handle,
&adapter->vf_cfg[vf].vf_pmac_id, &vf_cfg->pmac_id, vf + 1);
vf + 1);
} }
if (status) if (status)
dev_err(&adapter->pdev->dev, dev_err(&adapter->pdev->dev,
"Mac address assignment failed for VF %d\n", vf); "Mac address assignment failed for VF %d\n", vf);
else else
memcpy(adapter->vf_cfg[vf].vf_mac_addr, mac, ETH_ALEN); memcpy(vf_cfg->mac_addr, mac, ETH_ALEN);
mac[5] += 1; mac[5] += 1;
} }
...@@ -2492,25 +2493,23 @@ static inline int be_vf_eth_addr_config(struct be_adapter *adapter) ...@@ -2492,25 +2493,23 @@ static inline int be_vf_eth_addr_config(struct be_adapter *adapter)
static void be_vf_clear(struct be_adapter *adapter) static void be_vf_clear(struct be_adapter *adapter)
{ {
struct be_vf_cfg *vf_cfg;
u32 vf; u32 vf;
for (vf = 0; vf < num_vfs; vf++) { for_all_vfs(adapter, vf_cfg, vf) {
if (lancer_chip(adapter)) if (lancer_chip(adapter))
be_cmd_set_mac_list(adapter, NULL, 0, vf + 1); be_cmd_set_mac_list(adapter, NULL, 0, vf + 1);
else else
be_cmd_pmac_del(adapter, be_cmd_pmac_del(adapter, vf_cfg->if_handle,
adapter->vf_cfg[vf].vf_if_handle, vf_cfg->pmac_id, vf + 1);
adapter->vf_cfg[vf].vf_pmac_id, vf + 1);
}
for (vf = 0; vf < num_vfs; vf++) be_cmd_if_destroy(adapter, vf_cfg->if_handle, vf + 1);
be_cmd_if_destroy(adapter, adapter->vf_cfg[vf].vf_if_handle, }
vf + 1);
} }
static int be_clear(struct be_adapter *adapter) static int be_clear(struct be_adapter *adapter)
{ {
if (be_physfn(adapter) && adapter->sriov_enabled) if (sriov_enabled(adapter))
be_vf_clear(adapter); be_vf_clear(adapter);
be_cmd_if_destroy(adapter, adapter->if_handle, 0); be_cmd_if_destroy(adapter, adapter->if_handle, 0);
...@@ -2526,16 +2525,18 @@ static int be_clear(struct be_adapter *adapter) ...@@ -2526,16 +2525,18 @@ static int be_clear(struct be_adapter *adapter)
static void be_vf_setup_init(struct be_adapter *adapter) static void be_vf_setup_init(struct be_adapter *adapter)
{ {
struct be_vf_cfg *vf_cfg;
int vf; int vf;
for (vf = 0; vf < num_vfs; vf++) { for_all_vfs(adapter, vf_cfg, vf) {
adapter->vf_cfg[vf].vf_if_handle = -1; vf_cfg->if_handle = -1;
adapter->vf_cfg[vf].vf_pmac_id = -1; vf_cfg->pmac_id = -1;
} }
} }
static int be_vf_setup(struct be_adapter *adapter) static int be_vf_setup(struct be_adapter *adapter)
{ {
struct be_vf_cfg *vf_cfg;
u32 cap_flags, en_flags, vf; u32 cap_flags, en_flags, vf;
u16 lnk_speed; u16 lnk_speed;
int status; int status;
...@@ -2544,11 +2545,9 @@ static int be_vf_setup(struct be_adapter *adapter) ...@@ -2544,11 +2545,9 @@ static int be_vf_setup(struct be_adapter *adapter)
cap_flags = en_flags = BE_IF_FLAGS_UNTAGGED | BE_IF_FLAGS_BROADCAST | cap_flags = en_flags = BE_IF_FLAGS_UNTAGGED | BE_IF_FLAGS_BROADCAST |
BE_IF_FLAGS_MULTICAST; BE_IF_FLAGS_MULTICAST;
for_all_vfs(adapter, vf_cfg, vf) {
for (vf = 0; vf < num_vfs; vf++) {
status = be_cmd_if_create(adapter, cap_flags, en_flags, NULL, status = be_cmd_if_create(adapter, cap_flags, en_flags, NULL,
&adapter->vf_cfg[vf].vf_if_handle, &vf_cfg->if_handle, NULL, vf + 1);
NULL, vf+1);
if (status) if (status)
goto err; goto err;
} }
...@@ -2557,12 +2556,12 @@ static int be_vf_setup(struct be_adapter *adapter) ...@@ -2557,12 +2556,12 @@ static int be_vf_setup(struct be_adapter *adapter)
if (status) if (status)
goto err; goto err;
for (vf = 0; vf < num_vfs; vf++) { for_all_vfs(adapter, vf_cfg, vf) {
status = be_cmd_link_status_query(adapter, NULL, &lnk_speed, status = be_cmd_link_status_query(adapter, NULL, &lnk_speed,
vf + 1); vf + 1);
if (status) if (status)
goto err; goto err;
adapter->vf_cfg[vf].vf_tx_rate = lnk_speed * 10; vf_cfg->tx_rate = lnk_speed * 10;
} }
return 0; return 0;
err: err:
...@@ -2690,7 +2689,7 @@ static int be_setup(struct be_adapter *adapter) ...@@ -2690,7 +2689,7 @@ static int be_setup(struct be_adapter *adapter)
pcie_set_readrq(adapter->pdev, 4096); pcie_set_readrq(adapter->pdev, 4096);
if (be_physfn(adapter) && adapter->sriov_enabled) { if (sriov_enabled(adapter)) {
status = be_vf_setup(adapter); status = be_vf_setup(adapter);
if (status) if (status)
goto err; goto err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment