Commit 3e39da4f authored by Dave Ertman's avatar Dave Ertman Committed by Tony Nguyen

ice: Fix SRIOV LAG disable on non-compliant aggregate

If an attribute of an aggregate interface disqualifies it from supporting
SRIOV, the driver will unwind the SRIOV support.  Currently the driver is
clearing the feature bit for all interfaces in the aggregate, but this is
not allowing the other interfaces to unwind successfully on driver unload.

Only clear the feature bit for the interface that is currently unwinding.

Fixes: bf65da2e ("ice: enforce interface eligibility and add messaging for SRIOV LAG")
Signed-off-by: default avatarDave Ertman <david.m.ertman@intel.com>
Reviewed-by: default avatarWojciech Drewek <wojciech.drewek@intel.com>
Reviewed-by: default avatarSimon Horman <horms@kernel.org>
Tested-by: default avatarSujai Buvaneswaran <sujai.buvaneswaran@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent c1ed833e
...@@ -1555,18 +1555,12 @@ static void ice_lag_chk_disabled_bond(struct ice_lag *lag, void *ptr) ...@@ -1555,18 +1555,12 @@ static void ice_lag_chk_disabled_bond(struct ice_lag *lag, void *ptr)
*/ */
static void ice_lag_disable_sriov_bond(struct ice_lag *lag) static void ice_lag_disable_sriov_bond(struct ice_lag *lag)
{ {
struct ice_lag_netdev_list *entry;
struct ice_netdev_priv *np; struct ice_netdev_priv *np;
struct net_device *netdev;
struct ice_pf *pf; struct ice_pf *pf;
list_for_each_entry(entry, lag->netdev_head, node) { np = netdev_priv(lag->netdev);
netdev = entry->netdev;
np = netdev_priv(netdev);
pf = np->vsi->back; pf = np->vsi->back;
ice_clear_feature_support(pf, ICE_F_SRIOV_LAG); ice_clear_feature_support(pf, ICE_F_SRIOV_LAG);
}
} }
/** /**
......
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