Commit c12833ac authored by Daniel Jurgens's avatar Daniel Jurgens Committed by David S. Miller

net/mlx4_core: Implement pci_resume callback

Move resume related activities to a new pci_resume function instead of
performing them in mlx4_pci_slot_reset.  This change is needed to avoid
a hotplug during EEH recovery due to commit f2da4ccf ("powerpc/eeh:
More relaxed hotplug criterion").

Fixes: 2ba5fbd6 ('net/mlx4_core: Handle AER flow properly')
Signed-off-by: default avatarDaniel Jurgens <danielj@mellanox.com>
Signed-off-by: default avatarYishai Hadas <yishaih@mellanox.com>
Signed-off-by: default avatarOr Gerlitz <ogerlitz@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a1459c1c
...@@ -4050,45 +4050,53 @@ static pci_ers_result_t mlx4_pci_slot_reset(struct pci_dev *pdev) ...@@ -4050,45 +4050,53 @@ static pci_ers_result_t mlx4_pci_slot_reset(struct pci_dev *pdev)
{ {
struct mlx4_dev_persistent *persist = pci_get_drvdata(pdev); struct mlx4_dev_persistent *persist = pci_get_drvdata(pdev);
struct mlx4_dev *dev = persist->dev; struct mlx4_dev *dev = persist->dev;
struct mlx4_priv *priv = mlx4_priv(dev); int err;
int ret;
int nvfs[MLX4_MAX_PORTS + 1] = {0, 0, 0};
int total_vfs;
mlx4_err(dev, "mlx4_pci_slot_reset was called\n"); mlx4_err(dev, "mlx4_pci_slot_reset was called\n");
ret = pci_enable_device(pdev); err = pci_enable_device(pdev);
if (ret) { if (err) {
mlx4_err(dev, "Can not re-enable device, ret=%d\n", ret); mlx4_err(dev, "Can not re-enable device, err=%d\n", err);
return PCI_ERS_RESULT_DISCONNECT; return PCI_ERS_RESULT_DISCONNECT;
} }
pci_set_master(pdev); pci_set_master(pdev);
pci_restore_state(pdev); pci_restore_state(pdev);
pci_save_state(pdev); pci_save_state(pdev);
return PCI_ERS_RESULT_RECOVERED;
}
static void mlx4_pci_resume(struct pci_dev *pdev)
{
struct mlx4_dev_persistent *persist = pci_get_drvdata(pdev);
struct mlx4_dev *dev = persist->dev;
struct mlx4_priv *priv = mlx4_priv(dev);
int nvfs[MLX4_MAX_PORTS + 1] = {0, 0, 0};
int total_vfs;
int err;
mlx4_err(dev, "%s was called\n", __func__);
total_vfs = dev->persist->num_vfs; total_vfs = dev->persist->num_vfs;
memcpy(nvfs, dev->persist->nvfs, sizeof(dev->persist->nvfs)); memcpy(nvfs, dev->persist->nvfs, sizeof(dev->persist->nvfs));
mutex_lock(&persist->interface_state_mutex); mutex_lock(&persist->interface_state_mutex);
if (!(persist->interface_state & MLX4_INTERFACE_STATE_UP)) { if (!(persist->interface_state & MLX4_INTERFACE_STATE_UP)) {
ret = mlx4_load_one(pdev, priv->pci_dev_data, total_vfs, nvfs, err = mlx4_load_one(pdev, priv->pci_dev_data, total_vfs, nvfs,
priv, 1); priv, 1);
if (ret) { if (err) {
mlx4_err(dev, "%s: mlx4_load_one failed, ret=%d\n", mlx4_err(dev, "%s: mlx4_load_one failed, err=%d\n",
__func__, ret); __func__, err);
goto end; goto end;
} }
ret = restore_current_port_types(dev, dev->persist-> err = restore_current_port_types(dev, dev->persist->
curr_port_type, dev->persist-> curr_port_type, dev->persist->
curr_port_poss_type); curr_port_poss_type);
if (ret) if (err)
mlx4_err(dev, "could not restore original port types (%d)\n", ret); mlx4_err(dev, "could not restore original port types (%d)\n", err);
} }
end: end:
mutex_unlock(&persist->interface_state_mutex); mutex_unlock(&persist->interface_state_mutex);
return ret ? PCI_ERS_RESULT_DISCONNECT : PCI_ERS_RESULT_RECOVERED;
} }
static void mlx4_shutdown(struct pci_dev *pdev) static void mlx4_shutdown(struct pci_dev *pdev)
...@@ -4105,6 +4113,7 @@ static void mlx4_shutdown(struct pci_dev *pdev) ...@@ -4105,6 +4113,7 @@ static void mlx4_shutdown(struct pci_dev *pdev)
static const struct pci_error_handlers mlx4_err_handler = { static const struct pci_error_handlers mlx4_err_handler = {
.error_detected = mlx4_pci_err_detected, .error_detected = mlx4_pci_err_detected,
.slot_reset = mlx4_pci_slot_reset, .slot_reset = mlx4_pci_slot_reset,
.resume = mlx4_pci_resume,
}; };
static struct pci_driver mlx4_driver = { static struct pci_driver mlx4_driver = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment