|
@@ -652,7 +652,7 @@ void be_link_status_update(struct be_adapter *adapter, u8 link_status)
|
|
|
adapter->flags |= BE_FLAGS_LINK_STATUS_INIT;
|
|
|
}
|
|
|
|
|
|
- if ((link_status & LINK_STATUS_MASK) == LINK_UP)
|
|
|
+ if (link_status)
|
|
|
netif_carrier_on(netdev);
|
|
|
else
|
|
|
netif_carrier_off(netdev);
|
|
@@ -1288,6 +1288,7 @@ static int be_get_vf_config(struct net_device *netdev, int vf,
|
|
|
vi->vlan = vf_cfg->vlan_tag & VLAN_VID_MASK;
|
|
|
vi->qos = vf_cfg->vlan_tag >> VLAN_PRIO_SHIFT;
|
|
|
memcpy(&vi->mac, vf_cfg->mac_addr, ETH_ALEN);
|
|
|
+ vi->linkstate = adapter->vf_cfg[vf].plink_tracking;
|
|
|
|
|
|
return 0;
|
|
|
}
|
|
@@ -1354,6 +1355,24 @@ static int be_set_vf_tx_rate(struct net_device *netdev,
|
|
|
adapter->vf_cfg[vf].tx_rate = rate;
|
|
|
return status;
|
|
|
}
|
|
|
+static int be_set_vf_link_state(struct net_device *netdev, int vf,
|
|
|
+ int link_state)
|
|
|
+{
|
|
|
+ struct be_adapter *adapter = netdev_priv(netdev);
|
|
|
+ int status;
|
|
|
+
|
|
|
+ if (!sriov_enabled(adapter))
|
|
|
+ return -EPERM;
|
|
|
+
|
|
|
+ if (vf >= adapter->num_vfs)
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ status = be_cmd_set_logical_link_config(adapter, link_state, vf+1);
|
|
|
+ if (!status)
|
|
|
+ adapter->vf_cfg[vf].plink_tracking = link_state;
|
|
|
+
|
|
|
+ return status;
|
|
|
+}
|
|
|
|
|
|
static void be_aic_update(struct be_aic_obj *aic, u64 rx_pkts, u64 tx_pkts,
|
|
|
ulong now)
|
|
@@ -3109,8 +3128,12 @@ static int be_vf_setup(struct be_adapter *adapter)
|
|
|
if (!status)
|
|
|
vf_cfg->tx_rate = lnk_speed;
|
|
|
|
|
|
- if (!old_vfs)
|
|
|
+ if (!old_vfs) {
|
|
|
be_cmd_enable_vf(adapter, vf + 1);
|
|
|
+ be_cmd_set_logical_link_config(adapter,
|
|
|
+ IFLA_VF_LINK_STATE_AUTO,
|
|
|
+ vf+1);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
if (!old_vfs) {
|
|
@@ -3467,6 +3490,10 @@ static int be_setup(struct be_adapter *adapter)
|
|
|
be_cmd_set_flow_control(adapter, adapter->tx_fc,
|
|
|
adapter->rx_fc);
|
|
|
|
|
|
+ if (be_physfn(adapter))
|
|
|
+ be_cmd_set_logical_link_config(adapter,
|
|
|
+ IFLA_VF_LINK_STATE_AUTO, 0);
|
|
|
+
|
|
|
if (sriov_want(adapter)) {
|
|
|
if (be_max_vfs(adapter))
|
|
|
be_vf_setup(adapter);
|
|
@@ -4106,6 +4133,7 @@ static const struct net_device_ops be_netdev_ops = {
|
|
|
.ndo_set_vf_vlan = be_set_vf_vlan,
|
|
|
.ndo_set_vf_tx_rate = be_set_vf_tx_rate,
|
|
|
.ndo_get_vf_config = be_get_vf_config,
|
|
|
+ .ndo_set_vf_link_state = be_set_vf_link_state,
|
|
|
#ifdef CONFIG_NET_POLL_CONTROLLER
|
|
|
.ndo_poll_controller = be_netpoll,
|
|
|
#endif
|