mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-23 07:09:37 +07:00
ice: report link down for VF when PF's queues are not enabled
This is port of a fix from i40e commit 2ad1274fa3
("i40e: don't
report link up for a VF who hasn't enabled queues")
Older VF drivers do not respond well to receiving a link
up notification before queues are enabled. This can cause their state
machine to think that it is safe to send traffic. This results in a Tx
hang on the VF.
Record whether the PF has actually enabled queues for the VF. When
reporting link status, always report link down if the queues aren't
enabled. In this way, the VF driver will never receive a link up
notification until after its queues are enabled.
Signed-off-by: Lukasz Czapnik <lukasz.czapnik@intel.com>
Signed-off-by: Tony Nguyen <anthony.l.nguyen@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
29d42f1f3a
commit
c61d234234
@ -129,7 +129,10 @@ static void ice_vc_notify_vf_link_state(struct ice_vf *vf)
|
||||
pfe.event = VIRTCHNL_EVENT_LINK_CHANGE;
|
||||
pfe.severity = PF_EVENT_SEVERITY_INFO;
|
||||
|
||||
if (vf->link_forced)
|
||||
/* Always report link is down if the VF queues aren't enabled */
|
||||
if (!vf->num_qs_ena)
|
||||
ice_set_pfe_link(vf, &pfe, ICE_AQ_LINK_SPEED_UNKNOWN, false);
|
||||
else if (vf->link_forced)
|
||||
ice_set_pfe_link_forced(vf, &pfe, vf->link_up);
|
||||
else
|
||||
ice_set_pfe_link(vf, &pfe, ls->link_speed, ls->link_info &
|
||||
|
Loading…
Reference in New Issue
Block a user