Commit 124cd547 authored by Dave Ertman's avatar Dave Ertman Committed by Jeff Kirsher

ice: Use the right function to enable/disable VSI

The ice_ena/dis_vsi should have a single differentiating
factor to determine if the netdev_ops call is used or a
direct call to ice_vsi_open/close.  This is if the netif is
running or not.  If netif is running, use ndo_open/ndo_close.
Else, use ice_vsi_open/ice_vsi_close.
Signed-off-by: default avatarDave Ertman <david.m.ertman@intel.com>
Signed-off-by: default avatarAnirudh Venkataramanan <anirudh.venkataramanan@intel.com>
Tested-by: default avatarAndrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent d2b464a7
...@@ -3214,14 +3214,15 @@ static void ice_dis_vsi(struct ice_vsi *vsi) ...@@ -3214,14 +3214,15 @@ static void ice_dis_vsi(struct ice_vsi *vsi)
set_bit(__ICE_NEEDS_RESTART, vsi->state); set_bit(__ICE_NEEDS_RESTART, vsi->state);
if (vsi->netdev && netif_running(vsi->netdev) && if (vsi->type == ICE_VSI_PF && vsi->netdev) {
vsi->type == ICE_VSI_PF) { if (netif_running(vsi->netdev)) {
rtnl_lock(); rtnl_lock();
vsi->netdev->netdev_ops->ndo_stop(vsi->netdev); vsi->netdev->netdev_ops->ndo_stop(vsi->netdev);
rtnl_unlock(); rtnl_unlock();
} else { } else {
ice_vsi_close(vsi); ice_vsi_close(vsi);
} }
}
} }
/** /**
...@@ -3232,11 +3233,15 @@ static int ice_ena_vsi(struct ice_vsi *vsi) ...@@ -3232,11 +3233,15 @@ static int ice_ena_vsi(struct ice_vsi *vsi)
{ {
int err = 0; int err = 0;
if (test_and_clear_bit(__ICE_NEEDS_RESTART, vsi->state)) if (test_and_clear_bit(__ICE_NEEDS_RESTART, vsi->state) &&
if (vsi->netdev && netif_running(vsi->netdev)) { vsi->netdev) {
if (netif_running(vsi->netdev)) {
rtnl_lock(); rtnl_lock();
err = vsi->netdev->netdev_ops->ndo_open(vsi->netdev); err = vsi->netdev->netdev_ops->ndo_open(vsi->netdev);
rtnl_unlock(); rtnl_unlock();
} else {
err = ice_vsi_open(vsi);
}
} }
return err; return 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