mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-05 18:41:58 +09:00
net/mlx5: Stop waiting for PCI up if teardown was triggered
[ Upstream commit 8ff38e730c ]
If driver teardown is called while PCI is turned off, there is a race
between health recovery and teardown. If health recovery already started
it will wait 60 sec trying to see if PCI gets back and it can recover,
but actually there is no need to wait anymore once teardown was called.
Use the MLX5_BREAK_FW_WAIT flag which is set on driver teardown to break
waiting for PCI up.
Signed-off-by: Moshe Shemesh <moshe@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@nvidia.com>
Link: https://lore.kernel.org/r/20230314054234.267365-3-saeed@kernel.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Stable-dep-of: 33afbfcc105a ("net/mlx5: Stop waiting for PCI if pci channel is offline")
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
a2ab7dae67
commit
e4df7b53a4
@@ -325,6 +325,10 @@ int mlx5_health_wait_pci_up(struct mlx5_core_dev *dev)
|
|||||||
while (sensor_pci_not_working(dev)) {
|
while (sensor_pci_not_working(dev)) {
|
||||||
if (time_after(jiffies, end))
|
if (time_after(jiffies, end))
|
||||||
return -ETIMEDOUT;
|
return -ETIMEDOUT;
|
||||||
|
if (test_bit(MLX5_BREAK_FW_WAIT, &dev->intf_state)) {
|
||||||
|
mlx5_core_warn(dev, "device is being removed, stop waiting for PCI\n");
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
msleep(100);
|
msleep(100);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
Reference in New Issue
Block a user