diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2020-07-03 12:14:51 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2020-07-03 12:14:51 -0700 | 
| commit | 7fec3ce50a5d3fc54de9c0e9d43682ea9320b199 (patch) | |
| tree | c0690a7e1eb943f745005cac9758506ffa3b5edc /include/linux | |
| parent | 718b7a570a346323cd80dc28d0a41892036b050b (diff) | |
| parent | 5396956cc7c6874180c9bfc1ceceb02b739a6a87 (diff) | |
Merge tag 'pci-v5.8-fixes-1' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci
Pull PCI fix from Bjorn Helgaas:
 "Fix a pcie_find_root_port() simplification that broke power management
  because it didn't handle the edge case of finding the Root Port of a
  Root Port itself (Mika Westerberg)""
* tag 'pci-v5.8-fixes-1' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci:
  PCI: Make pcie_find_root_port() work for Root Ports
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/pci.h | 11 | 
1 files changed, 5 insertions, 6 deletions
| diff --git a/include/linux/pci.h b/include/linux/pci.h index c79d83304e52..34c1c4f45288 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -2169,12 +2169,11 @@ static inline int pci_pcie_type(const struct pci_dev *dev)   */  static inline struct pci_dev *pcie_find_root_port(struct pci_dev *dev)  { -	struct pci_dev *bridge = pci_upstream_bridge(dev); - -	while (bridge) { -		if (pci_pcie_type(bridge) == PCI_EXP_TYPE_ROOT_PORT) -			return bridge; -		bridge = pci_upstream_bridge(bridge); +	while (dev) { +		if (pci_is_pcie(dev) && +		    pci_pcie_type(dev) == PCI_EXP_TYPE_ROOT_PORT) +			return dev; +		dev = pci_upstream_bridge(dev);  	}  	return NULL; | 
