Commit 59100eb2 authored by Maciej W. Rozycki's avatar Maciej W. Rozycki Committed by Krzysztof Wilczyński

PCI: Use an error code with PCIe failed link retraining

Given how the call place in pcie_wait_for_link_delay() got structured now,
and that pcie_retrain_link() returns a potentially useful error code,
convert pcie_failed_link_retrain() to return an error code rather than a
boolean status, fixing handling at the call site mentioned.  Update the
other call site accordingly.

Fixes: 1abb4739 ("Merge branch 'pci/enumeration'")
Link: https://lore.kernel.org/r/alpine.DEB.2.21.2408091156530.61955@angie.orcam.me.ukReported-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Link: https://lore.kernel.org/r/aa2d1c4e-9961-d54a-00c7-ddf8e858a9b0@linux.intel.com/Signed-off-by: default avatarMaciej W. Rozycki <macro@orcam.me.uk>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Signed-off-by: default avatarKrzysztof Wilczyński <kwilczynski@kernel.org>
Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Cc: <stable@vger.kernel.org> # v6.5+
parent 712e49c9
...@@ -1324,7 +1324,7 @@ static int pci_dev_wait(struct pci_dev *dev, char *reset_type, int timeout) ...@@ -1324,7 +1324,7 @@ static int pci_dev_wait(struct pci_dev *dev, char *reset_type, int timeout)
if (delay > PCI_RESET_WAIT) { if (delay > PCI_RESET_WAIT) {
if (retrain) { if (retrain) {
retrain = false; retrain = false;
if (pcie_failed_link_retrain(bridge)) { if (pcie_failed_link_retrain(bridge) == 0) {
delay = 1; delay = 1;
continue; continue;
} }
......
...@@ -606,7 +606,7 @@ void pci_acs_init(struct pci_dev *dev); ...@@ -606,7 +606,7 @@ void pci_acs_init(struct pci_dev *dev);
int pci_dev_specific_acs_enabled(struct pci_dev *dev, u16 acs_flags); int pci_dev_specific_acs_enabled(struct pci_dev *dev, u16 acs_flags);
int pci_dev_specific_enable_acs(struct pci_dev *dev); int pci_dev_specific_enable_acs(struct pci_dev *dev);
int pci_dev_specific_disable_acs_redir(struct pci_dev *dev); int pci_dev_specific_disable_acs_redir(struct pci_dev *dev);
bool pcie_failed_link_retrain(struct pci_dev *dev); int pcie_failed_link_retrain(struct pci_dev *dev);
#else #else
static inline int pci_dev_specific_acs_enabled(struct pci_dev *dev, static inline int pci_dev_specific_acs_enabled(struct pci_dev *dev,
u16 acs_flags) u16 acs_flags)
...@@ -621,9 +621,9 @@ static inline int pci_dev_specific_disable_acs_redir(struct pci_dev *dev) ...@@ -621,9 +621,9 @@ static inline int pci_dev_specific_disable_acs_redir(struct pci_dev *dev)
{ {
return -ENOTTY; return -ENOTTY;
} }
static inline bool pcie_failed_link_retrain(struct pci_dev *dev) static inline int pcie_failed_link_retrain(struct pci_dev *dev)
{ {
return false; return -ENOTTY;
} }
#endif #endif
......
...@@ -78,21 +78,21 @@ ...@@ -78,21 +78,21 @@
* again to remove any residual state, ignoring the result as it's supposed * again to remove any residual state, ignoring the result as it's supposed
* to fail anyway. * to fail anyway.
* *
* Return TRUE if the link has been successfully retrained. Return FALSE * Return 0 if the link has been successfully retrained. Return an error
* if retraining was not needed or we attempted a retrain and it failed. * if retraining was not needed or we attempted a retrain and it failed.
*/ */
bool pcie_failed_link_retrain(struct pci_dev *dev) int pcie_failed_link_retrain(struct pci_dev *dev)
{ {
static const struct pci_device_id ids[] = { static const struct pci_device_id ids[] = {
{ PCI_VDEVICE(ASMEDIA, 0x2824) }, /* ASMedia ASM2824 */ { PCI_VDEVICE(ASMEDIA, 0x2824) }, /* ASMedia ASM2824 */
{} {}
}; };
u16 lnksta, lnkctl2; u16 lnksta, lnkctl2;
bool ret = false; int ret = -ENOTTY;
if (!pci_is_pcie(dev) || !pcie_downstream_port(dev) || if (!pci_is_pcie(dev) || !pcie_downstream_port(dev) ||
!pcie_cap_has_lnkctl2(dev) || !dev->link_active_reporting) !pcie_cap_has_lnkctl2(dev) || !dev->link_active_reporting)
return false; return ret;
pcie_capability_read_word(dev, PCI_EXP_LNKCTL2, &lnkctl2); pcie_capability_read_word(dev, PCI_EXP_LNKCTL2, &lnkctl2);
pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &lnksta); pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &lnksta);
...@@ -106,13 +106,13 @@ bool pcie_failed_link_retrain(struct pci_dev *dev) ...@@ -106,13 +106,13 @@ bool pcie_failed_link_retrain(struct pci_dev *dev)
lnkctl2 |= PCI_EXP_LNKCTL2_TLS_2_5GT; lnkctl2 |= PCI_EXP_LNKCTL2_TLS_2_5GT;
pcie_capability_write_word(dev, PCI_EXP_LNKCTL2, lnkctl2); pcie_capability_write_word(dev, PCI_EXP_LNKCTL2, lnkctl2);
ret = pcie_retrain_link(dev, false) == 0; ret = pcie_retrain_link(dev, false);
if (!ret) { if (ret) {
pci_info(dev, "retraining failed\n"); pci_info(dev, "retraining failed\n");
pcie_capability_write_word(dev, PCI_EXP_LNKCTL2, pcie_capability_write_word(dev, PCI_EXP_LNKCTL2,
oldlnkctl2); oldlnkctl2);
pcie_retrain_link(dev, true); pcie_retrain_link(dev, true);
return false; return ret;
} }
pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &lnksta); pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &lnksta);
...@@ -129,10 +129,10 @@ bool pcie_failed_link_retrain(struct pci_dev *dev) ...@@ -129,10 +129,10 @@ bool pcie_failed_link_retrain(struct pci_dev *dev)
lnkctl2 |= lnkcap & PCI_EXP_LNKCAP_SLS; lnkctl2 |= lnkcap & PCI_EXP_LNKCAP_SLS;
pcie_capability_write_word(dev, PCI_EXP_LNKCTL2, lnkctl2); pcie_capability_write_word(dev, PCI_EXP_LNKCTL2, lnkctl2);
ret = pcie_retrain_link(dev, false) == 0; ret = pcie_retrain_link(dev, false);
if (!ret) { if (ret) {
pci_info(dev, "retraining failed\n"); pci_info(dev, "retraining failed\n");
return false; return ret;
} }
} }
......
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