mirror of https://gitee.com/openkylin/linux.git
i40e: fix client notify of VF reset
Currently there is a bug in which the PF driver fails to inform clients of a VF reset which then causes clients to leak resources. The bug exists because we were incorrectly checking the I40E_VF_STATE_PRE_ENABLE bit. When a VF is first init we go through a reset to initialize variables and allocate resources but we don't want to inform clients of this first reset since the client isn't fully enabled yet so we set a state bit signifying we're in a "pre-enabled" client state. During the first reset we should be clearing the bit, allowing all following resets to notify the client of the reset when the bit is not set. This patch fixes the issue by negating the 'test_and_clear_bit' check to accurately reflect the behavior we want. Signed-off-by: Alan Brady <alan.brady@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
41d0a4d0c8
commit
c53d11f669
|
@ -1050,8 +1050,8 @@ static void i40e_cleanup_reset_vf(struct i40e_vf *vf)
|
|||
set_bit(I40E_VF_STATE_ACTIVE, &vf->vf_states);
|
||||
clear_bit(I40E_VF_STATE_DISABLED, &vf->vf_states);
|
||||
/* Do not notify the client during VF init */
|
||||
if (test_and_clear_bit(I40E_VF_STATE_PRE_ENABLE,
|
||||
&vf->vf_states))
|
||||
if (!test_and_clear_bit(I40E_VF_STATE_PRE_ENABLE,
|
||||
&vf->vf_states))
|
||||
i40e_notify_client_of_vf_reset(pf, abs_vf_id);
|
||||
vf->num_vlan = 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue