Commit e4934832 authored by Ilpo Järvinen's avatar Ilpo Järvinen Committed by Bjorn Helgaas
Browse files

PCI: Add defines for bridge window indexing



include/linux/pci.h provides PCI_BRIDGE_{IO,MEM,PREF_MEM}_WINDOW defines,
however, they're based on the resource array indexing in the pci_dev
struct. The struct pci_bus also has pointers to those same resources but
they start from zeroth index.

Add PCI_BUS_BRIDGE_{IO,MEM,PREF_MEM}_WINDOW defines to get rid of literal
indexing.

Signed-off-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Link: https://patch.msgid.link/20250829131113.36754-12-ilpo.jarvinen@linux.intel.com
parent 8278c691
Loading
Loading
Loading
Loading
+4 −0
Original line number Diff line number Diff line
@@ -81,6 +81,10 @@ struct pcie_tlp_log;
#define PCIE_MSG_CODE_DEASSERT_INTC	0x26
#define PCIE_MSG_CODE_DEASSERT_INTD	0x27

#define PCI_BUS_BRIDGE_IO_WINDOW	0
#define PCI_BUS_BRIDGE_MEM_WINDOW	1
#define PCI_BUS_BRIDGE_PREF_MEM_WINDOW	2

extern const unsigned char pcie_link_speed[];
extern bool pci_early_dump;

+7 −3
Original line number Diff line number Diff line
@@ -598,9 +598,13 @@ void pci_read_bridge_bases(struct pci_bus *child)
	for (i = 0; i < PCI_BRIDGE_RESOURCE_NUM; i++)
		child->resource[i] = &dev->resource[PCI_BRIDGE_RESOURCES+i];

	pci_read_bridge_io(child->self, child->resource[0], false);
	pci_read_bridge_mmio(child->self, child->resource[1], false);
	pci_read_bridge_mmio_pref(child->self, child->resource[2], false);
	pci_read_bridge_io(child->self,
			   child->resource[PCI_BUS_BRIDGE_IO_WINDOW], false);
	pci_read_bridge_mmio(child->self,
			     child->resource[PCI_BUS_BRIDGE_MEM_WINDOW], false);
	pci_read_bridge_mmio_pref(child->self,
				  child->resource[PCI_BUS_BRIDGE_PREF_MEM_WINDOW],
				  false);

	if (!dev->transparent)
		return;