Commit 3f341acc authored by Sridhar Samudrala's avatar Sridhar Samudrala Committed by Jeff Kirsher

i40evf: Fix link state event handling

Currently disabling the link state from PF via
	ip link set enp5s0f0 vf 0 state disable
doesn't disable the CARRIER on the VF.

This patch updates the carrier and starts/stops the tx queues based on the
link state notification from PF.

  PF: enp5s0f0, VF: enp5s2
  #modprobe i40e
  #echo 2 > /sys/class/net/enp5s0f0/device/sriov_numvfs
  #ip link set enp5s2 up
  #ip -d link show enp5s2
  175: enp5s2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 1000
      link/ether ea:4d:60:bc:6f:85 brd ff:ff:ff:ff:ff:ff promiscuity 0 addrgenmode eui64
  #ip link set enp5s0f0 vf 0 state disable
  #ip -d link show enp5s0f0
  171: enp5s0f0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
      link/ether 68:05:ca:2e:72:68 brd ff:ff:ff:ff:ff:ff promiscuity 0 addrgenmode eui64 numtxqueues 72 numrxqueues 72 portid 6805ca2e7268
      vf 0 MAC 00:00:00:00:00:00, spoof checking on, link-state disable, trust off
      vf 1 MAC 00:00:00:00:00:00, spoof checking on, link-state auto, trust off
  #ip -d link show enp5s2
  175: enp5s2: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN mode DEFAULT group default qlen 1000
       link/ether ea:4d:60:bc:6f:85 brd ff:ff:ff:ff:ff:ff promiscuity 0 addrgenmode eui64 numtxqueues 16 numrxqueues 16
Signed-off-by: default avatarSridhar Samudrala <sridhar.samudrala@intel.com>
Tested-by: default avatarAndrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent ff918912
...@@ -1037,6 +1037,7 @@ void i40evf_down(struct i40evf_adapter *adapter) ...@@ -1037,6 +1037,7 @@ void i40evf_down(struct i40evf_adapter *adapter)
netif_carrier_off(netdev); netif_carrier_off(netdev);
netif_tx_disable(netdev); netif_tx_disable(netdev);
adapter->link_up = false;
i40evf_napi_disable_all(adapter); i40evf_napi_disable_all(adapter);
i40evf_irq_disable(adapter); i40evf_irq_disable(adapter);
...@@ -1731,6 +1732,7 @@ static void i40evf_reset_task(struct work_struct *work) ...@@ -1731,6 +1732,7 @@ static void i40evf_reset_task(struct work_struct *work)
set_bit(__I40E_DOWN, &adapter->vsi.state); set_bit(__I40E_DOWN, &adapter->vsi.state);
netif_carrier_off(netdev); netif_carrier_off(netdev);
netif_tx_disable(netdev); netif_tx_disable(netdev);
adapter->link_up = false;
i40evf_napi_disable_all(adapter); i40evf_napi_disable_all(adapter);
i40evf_irq_disable(adapter); i40evf_irq_disable(adapter);
i40evf_free_traffic_irqs(adapter); i40evf_free_traffic_irqs(adapter);
...@@ -1769,6 +1771,7 @@ static void i40evf_reset_task(struct work_struct *work) ...@@ -1769,6 +1771,7 @@ static void i40evf_reset_task(struct work_struct *work)
if (netif_running(adapter->netdev)) { if (netif_running(adapter->netdev)) {
netif_carrier_off(netdev); netif_carrier_off(netdev);
netif_tx_stop_all_queues(netdev); netif_tx_stop_all_queues(netdev);
adapter->link_up = false;
i40evf_napi_disable_all(adapter); i40evf_napi_disable_all(adapter);
} }
i40evf_irq_disable(adapter); i40evf_irq_disable(adapter);
...@@ -2457,6 +2460,7 @@ static void i40evf_init_task(struct work_struct *work) ...@@ -2457,6 +2460,7 @@ static void i40evf_init_task(struct work_struct *work)
goto err_sw_init; goto err_sw_init;
netif_carrier_off(netdev); netif_carrier_off(netdev);
adapter->link_up = false;
if (!adapter->netdev_registered) { if (!adapter->netdev_registered) {
err = register_netdev(netdev); err = register_netdev(netdev);
......
...@@ -898,8 +898,14 @@ void i40evf_virtchnl_completion(struct i40evf_adapter *adapter, ...@@ -898,8 +898,14 @@ void i40evf_virtchnl_completion(struct i40evf_adapter *adapter,
vpe->event_data.link_event.link_status) { vpe->event_data.link_event.link_status) {
adapter->link_up = adapter->link_up =
vpe->event_data.link_event.link_status; vpe->event_data.link_event.link_status;
if (adapter->link_up) {
netif_tx_start_all_queues(netdev);
netif_carrier_on(netdev);
} else {
netif_tx_stop_all_queues(netdev);
netif_carrier_off(netdev);
}
i40evf_print_link_message(adapter); i40evf_print_link_message(adapter);
netif_tx_stop_all_queues(netdev);
} }
break; break;
case I40E_VIRTCHNL_EVENT_RESET_IMPENDING: case I40E_VIRTCHNL_EVENT_RESET_IMPENDING:
...@@ -974,8 +980,6 @@ void i40evf_virtchnl_completion(struct i40evf_adapter *adapter, ...@@ -974,8 +980,6 @@ void i40evf_virtchnl_completion(struct i40evf_adapter *adapter,
case I40E_VIRTCHNL_OP_ENABLE_QUEUES: case I40E_VIRTCHNL_OP_ENABLE_QUEUES:
/* enable transmits */ /* enable transmits */
i40evf_irq_enable(adapter, true); i40evf_irq_enable(adapter, true);
netif_tx_start_all_queues(adapter->netdev);
netif_carrier_on(adapter->netdev);
break; break;
case I40E_VIRTCHNL_OP_DISABLE_QUEUES: case I40E_VIRTCHNL_OP_DISABLE_QUEUES:
i40evf_free_all_tx_resources(adapter); i40evf_free_all_tx_resources(adapter);
......
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