mirror of https://gitee.com/openkylin/linux.git
qede: Update link status only when interface is ready.
In the case of internal reload (e.g., mtu change), there could be a race between link-up notification from mfw and the driver unload processing. In such case kernel assumes the link is up and starts using the queues which leads to the server crash. Send link notification to the kernel only when driver has already requested MFW for the link. Signed-off-by: Sudarsana Reddy Kalluru <Sudarsana.Kalluru@cavium.com> Signed-off-by: Ariel Elior <Ariel.Elior@cavium.com> Signed-off-by: Michal Kalderon <Michal.Kalderon@cavium.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
149d3775f1
commit
f04e48dbfa
|
@ -170,6 +170,7 @@ struct qede_ptp;
|
|||
|
||||
enum qede_flags_bit {
|
||||
QEDE_FLAGS_IS_VF = 0,
|
||||
QEDE_FLAGS_LINK_REQUESTED,
|
||||
QEDE_FLAGS_PTP_TX_IN_PRORGESS,
|
||||
QEDE_FLAGS_TX_TIMESTAMPING_EN
|
||||
};
|
||||
|
|
|
@ -2057,6 +2057,8 @@ static void qede_unload(struct qede_dev *edev, enum qede_unload_mode mode,
|
|||
if (!is_locked)
|
||||
__qede_lock(edev);
|
||||
|
||||
clear_bit(QEDE_FLAGS_LINK_REQUESTED, &edev->flags);
|
||||
|
||||
edev->state = QEDE_STATE_CLOSED;
|
||||
|
||||
qede_rdma_dev_event_close(edev);
|
||||
|
@ -2163,6 +2165,8 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode,
|
|||
/* Program un-configured VLANs */
|
||||
qede_configure_vlan_filters(edev);
|
||||
|
||||
set_bit(QEDE_FLAGS_LINK_REQUESTED, &edev->flags);
|
||||
|
||||
/* Ask for link-up using current configuration */
|
||||
memset(&link_params, 0, sizeof(link_params));
|
||||
link_params.link_up = true;
|
||||
|
@ -2258,8 +2262,8 @@ static void qede_link_update(void *dev, struct qed_link_output *link)
|
|||
{
|
||||
struct qede_dev *edev = dev;
|
||||
|
||||
if (!netif_running(edev->ndev)) {
|
||||
DP_VERBOSE(edev, NETIF_MSG_LINK, "Interface is not running\n");
|
||||
if (!test_bit(QEDE_FLAGS_LINK_REQUESTED, &edev->flags)) {
|
||||
DP_VERBOSE(edev, NETIF_MSG_LINK, "Interface is not ready\n");
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue