mirror of
https://github.com/hardkernel/linux.git
synced 2026-03-26 04:20:23 +09:00
net/mlx5: Use RMW accessors for changing LNKCTL
[ Upstream commit30de872537] Don't assume that only the driver would be accessing LNKCTL of the upstream bridge. ASPM policy changes can trigger write to LNKCTL outside of driver's control. Use RMW capability accessors which do proper locking to avoid losing concurrent updates to the register value. Suggested-by: Lukas Wunner <lukas@wunner.de> Fixes:eabe8e5e88("net/mlx5: Handle sync reset now event") Link: https://lore.kernel.org/r/20230717120503.15276-8-ilpo.jarvinen@linux.intel.com Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> Reviewed-by: Moshe Shemesh <moshe@nvidia.com> Reviewed-by: Simon Horman <simon.horman@corigine.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
348ef09df9
commit
ea670d0146
@@ -274,16 +274,11 @@ static int mlx5_pci_link_toggle(struct mlx5_core_dev *dev)
|
||||
pci_cfg_access_lock(sdev);
|
||||
}
|
||||
/* PCI link toggle */
|
||||
err = pci_read_config_word(bridge, cap + PCI_EXP_LNKCTL, ®16);
|
||||
if (err)
|
||||
return err;
|
||||
reg16 |= PCI_EXP_LNKCTL_LD;
|
||||
err = pci_write_config_word(bridge, cap + PCI_EXP_LNKCTL, reg16);
|
||||
err = pcie_capability_set_word(bridge, PCI_EXP_LNKCTL, PCI_EXP_LNKCTL_LD);
|
||||
if (err)
|
||||
return err;
|
||||
msleep(500);
|
||||
reg16 &= ~PCI_EXP_LNKCTL_LD;
|
||||
err = pci_write_config_word(bridge, cap + PCI_EXP_LNKCTL, reg16);
|
||||
err = pcie_capability_clear_word(bridge, PCI_EXP_LNKCTL, PCI_EXP_LNKCTL_LD);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user