[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <52CC77DC.5020801@cogentembedded.com>
Date: Wed, 08 Jan 2014 01:55:40 +0400
From: Sergei Shtylyov <sergei.shtylyov@...entembedded.com>
To: "Williams, Mitch A" <mitch.a.williams@...el.com>,
"Kirsher, Jeffrey T" <jeffrey.t.kirsher@...el.com>,
"Rose, Gregory V" <gregory.v.rose@...el.com>
CC: "davem@...emloft.net" <davem@...emloft.net>,
"netdev@...r.kernel.org" <netdev@...r.kernel.org>,
"gospo@...hat.com" <gospo@...hat.com>,
"sassmann@...hat.com" <sassmann@...hat.com>,
"Brandeburg, Jesse" <jesse.brandeburg@...el.com>
Subject: Re: [net-next 08/15] i40e: acknowledge VFLR when disabling SR-IOV
Hello.
On 06-01-2014 22:10, Williams, Mitch A wrote:
>>> From: Mitch Williams <mitch.a.williams@...el.com>
>>> When SR-IOV is disabled, the (now nonexistent) virtual function
>>> devices undergo a VFLR event. We don't need to handle this event
>>> because the VFs are gone, but we do need to tell the HW that they are
>>> complete. This fixes an issue with a phantom VFLR and broken VFs when
>>> SR-IOV is re-enabled.
>>> Change-Id: I7580b49ded0158172a85b14661ec212af77000c8
>>> Signed-off-by: Mitch Williams <mitch.a.williams@...el.com>
>>> Signed-off-by: Jesse Brandeburg <jesse.brandeburg@...el.com>
>>> Tested-by: Sibai Li <sibai.li@...el.com>
>>> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@...el.com>
>>> ---
>>> drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c | 15 +++++++++++++--
>>> 1 file changed, 13 insertions(+), 2 deletions(-)
>>> diff --git a/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
>> b/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
>>> index f92404c..e91f9d7 100644
>>> --- a/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
>>> +++ b/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
>> [...]
>>> @@ -748,8 +750,17 @@ void i40e_free_vfs(struct i40e_pf *pf)
>>> kfree(pf->vf);
>>> pf->vf = NULL;
>>>
>>> - if (!i40e_vfs_are_assigned(pf))
>>> + if (!i40e_vfs_are_assigned(pf)) {
>>> pci_disable_sriov(pf->pdev);
>>> + /* Acknowledge VFLR for all VFS. Without this, VFs will fail to
>>> + * work correctly when SR-IOV gets re-enabled.
>>> + */
>>> + for (vf_id = 0; vf_id < tmp; vf_id++) {
>>> + reg_idx = (hw->func_caps.vf_base_id + vf_id) / 32;
>>> + bit_idx = (hw->func_caps.vf_base_id + vf_id) % 32;
>>> + wr32(hw, I40E_GLGEN_VFLRSTAT(reg_idx), (1 << bit_idx));
>>> + }
>>> + }
>>> else
>> } and *else* should be on the same line. And the *else* arm should also
>> have {} now.
>>> dev_warn(&pf->pdev->dev,
>>> "unable to disable SR-IOV because VFs are assigned.\n");
>> WBR, Sergei
> You are absolutely correct, Sergei, and I apologize for not seeing this before I submitted the patch.
I guess you haven't run scripts/checkpatch.pl, have you?
> There will be a patch coming from Greg Rose in the next few weeks that will fix this problem in the process of adding a bug fix. Since this is just cosmetic, would it be all right with you if we just wait for Greg's patch to come through?
Looks like DaveM has decided for everybody and the patch with the fix has
been already posted too.
> -Mitch
WBR, Sergei
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists