qed*: Fix link indication race
Driver changes the link properties via communication with the management firmware, and re-reads the resulting link status when it receives an indication that the link has changed. However, there are certain scenarios where such indications might be missing, and so driver also re-reads the current link results without attention in several places. Specifically, it does so during load and when resetting the link. This creates a race where driver might reflect incorrect link status - e.g., when explicit reading of the link status is switched by attention with the changed configuration. Correct this flow by a lock syncronizing the handling of the link indications [both explicit requests and attention]. Signed-off-by: Yuval Mintz <Yuval.Mintz@cavium.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
85750d74fb
commit
65ed2ffd64
@@ -1872,7 +1872,6 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode,
|
||||
bool is_locked)
|
||||
{
|
||||
struct qed_link_params link_params;
|
||||
struct qed_link_output link_output;
|
||||
int rc;
|
||||
|
||||
DP_INFO(edev, "Starting qede load\n");
|
||||
@@ -1924,11 +1923,7 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode,
|
||||
link_params.link_up = true;
|
||||
edev->ops->common->set_link(edev->cdev, &link_params);
|
||||
|
||||
/* Query whether link is already-up */
|
||||
memset(&link_output, 0, sizeof(link_output));
|
||||
edev->ops->common->get_link(edev->cdev, &link_output);
|
||||
qede_roce_dev_event_open(edev);
|
||||
qede_link_update(edev, &link_output);
|
||||
|
||||
qede_ptp_start(edev, (mode == QEDE_LOAD_NORMAL));
|
||||
|
||||
|
||||
Reference in New Issue
Block a user