net/i40e: fix VF reset flow
Add missing step during VF reset: PF should
set I40E_VFGEN_RSTAT to ACTIVE at end of the
VF reset operation or VF driver may not able
to detect that reset is already completed.
This patch also remove the unnecessary enum
for vfr state.
Fixes: 4861cde461
("i40e: new poll mode driver")
Signed-off-by: Qi Zhang <qi.z.zhang@intel.com>
Acked-by: Helin Zhang <helin.zhang@intel.com>
Acked-by: Vincent Jardin <vincent.jardin@6wind.com>
This commit is contained in:
parent
26b83c86a6
commit
32ecaf723f
@ -139,7 +139,7 @@ i40e_pf_host_vf_reset(struct i40e_pf_vf *vf, bool do_hw_reset)
|
||||
abs_vf_id = vf_id + hw->func_caps.vf_base_id;
|
||||
|
||||
/* Notify VF that we are in VFR progress */
|
||||
I40E_WRITE_REG(hw, I40E_VFGEN_RSTAT1(vf_id), I40E_PF_VFR_INPROGRESS);
|
||||
I40E_WRITE_REG(hw, I40E_VFGEN_RSTAT1(vf_id), I40E_VFR_INPROGRESS);
|
||||
|
||||
/*
|
||||
* If require a SW VF reset, a VFLR interrupt will be generated,
|
||||
@ -220,7 +220,7 @@ i40e_pf_host_vf_reset(struct i40e_pf_vf *vf, bool do_hw_reset)
|
||||
}
|
||||
|
||||
/* Reset done, Set COMPLETE flag and clear reset bit */
|
||||
I40E_WRITE_REG(hw, I40E_VFGEN_RSTAT1(vf_id), I40E_PF_VFR_COMPLETED);
|
||||
I40E_WRITE_REG(hw, I40E_VFGEN_RSTAT1(vf_id), I40E_VFR_COMPLETED);
|
||||
val = I40E_READ_REG(hw, I40E_VPGEN_VFRTRIG(vf_id));
|
||||
val &= ~I40E_VPGEN_VFRTRIG_VFSWR_MASK;
|
||||
I40E_WRITE_REG(hw, I40E_VPGEN_VFRTRIG(vf_id), val);
|
||||
@ -248,6 +248,8 @@ i40e_pf_host_vf_reset(struct i40e_pf_vf *vf, bool do_hw_reset)
|
||||
return -EFAULT;
|
||||
}
|
||||
|
||||
I40E_WRITE_REG(hw, I40E_VFGEN_RSTAT1(vf_id), I40E_VFR_VFACTIVE);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -48,11 +48,6 @@
|
||||
|
||||
#define I40E_DPDK_OFFSET 0x100
|
||||
|
||||
enum i40e_pf_vfr_state {
|
||||
I40E_PF_VFR_INPROGRESS = 0,
|
||||
I40E_PF_VFR_COMPLETED = 1,
|
||||
};
|
||||
|
||||
/* DPDK pf driver specific command to VF */
|
||||
enum i40e_virtchnl_ops_dpdk {
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user