diff options
Diffstat (limited to 'drivers/pci')
| -rw-r--r-- | drivers/pci/access.c | 27 | ||||
| -rw-r--r-- | drivers/pci/bus.c | 2 | ||||
| -rw-r--r-- | drivers/pci/host/pci-keystone.c | 5 | ||||
| -rw-r--r-- | drivers/pci/host/pci-rcar-gen2.c | 1 | ||||
| -rw-r--r-- | drivers/pci/host/pci-xgene-msi.c | 2 | ||||
| -rw-r--r-- | drivers/pci/msi.c | 4 | ||||
| -rw-r--r-- | drivers/pci/pci-driver.c | 7 | ||||
| -rw-r--r-- | drivers/pci/pci-sysfs.c | 2 | ||||
| -rw-r--r-- | drivers/pci/probe.c | 23 | ||||
| -rw-r--r-- | drivers/pci/quirks.c | 20 | 
10 files changed, 48 insertions, 45 deletions
| diff --git a/drivers/pci/access.c b/drivers/pci/access.c index 769f7e35f1a2..59ac36fe7c42 100644 --- a/drivers/pci/access.c +++ b/drivers/pci/access.c @@ -442,7 +442,8 @@ static const struct pci_vpd_ops pci_vpd_pci22_ops = {  static ssize_t pci_vpd_f0_read(struct pci_dev *dev, loff_t pos, size_t count,  			       void *arg)  { -	struct pci_dev *tdev = pci_get_slot(dev->bus, PCI_SLOT(dev->devfn)); +	struct pci_dev *tdev = pci_get_slot(dev->bus, +					    PCI_DEVFN(PCI_SLOT(dev->devfn), 0));  	ssize_t ret;  	if (!tdev) @@ -456,7 +457,8 @@ static ssize_t pci_vpd_f0_read(struct pci_dev *dev, loff_t pos, size_t count,  static ssize_t pci_vpd_f0_write(struct pci_dev *dev, loff_t pos, size_t count,  				const void *arg)  { -	struct pci_dev *tdev = pci_get_slot(dev->bus, PCI_SLOT(dev->devfn)); +	struct pci_dev *tdev = pci_get_slot(dev->bus, +					    PCI_DEVFN(PCI_SLOT(dev->devfn), 0));  	ssize_t ret;  	if (!tdev) @@ -473,22 +475,6 @@ static const struct pci_vpd_ops pci_vpd_f0_ops = {  	.release = pci_vpd_pci22_release,  }; -static int pci_vpd_f0_dev_check(struct pci_dev *dev) -{ -	struct pci_dev *tdev = pci_get_slot(dev->bus, PCI_SLOT(dev->devfn)); -	int ret = 0; - -	if (!tdev) -		return -ENODEV; -	if (!tdev->vpd || !tdev->multifunction || -	    dev->class != tdev->class || dev->vendor != tdev->vendor || -	    dev->device != tdev->device) -		ret = -ENODEV; - -	pci_dev_put(tdev); -	return ret; -} -  int pci_vpd_pci22_init(struct pci_dev *dev)  {  	struct pci_vpd_pci22 *vpd; @@ -497,12 +483,7 @@ int pci_vpd_pci22_init(struct pci_dev *dev)  	cap = pci_find_capability(dev, PCI_CAP_ID_VPD);  	if (!cap)  		return -ENODEV; -	if (dev->dev_flags & PCI_DEV_FLAGS_VPD_REF_F0) { -		int ret = pci_vpd_f0_dev_check(dev); -		if (ret) -			return ret; -	}  	vpd = kzalloc(sizeof(*vpd), GFP_ATOMIC);  	if (!vpd)  		return -ENOMEM; diff --git a/drivers/pci/bus.c b/drivers/pci/bus.c index 6fbd3f2b5992..d3346d23963b 100644 --- a/drivers/pci/bus.c +++ b/drivers/pci/bus.c @@ -256,6 +256,8 @@ bool pci_bus_clip_resource(struct pci_dev *dev, int idx)  		res->start = start;  		res->end = end; +		res->flags &= ~IORESOURCE_UNSET; +		orig_res.flags &= ~IORESOURCE_UNSET;  		dev_printk(KERN_DEBUG, &dev->dev, "%pR clipped to %pR\n",  				 &orig_res, res); diff --git a/drivers/pci/host/pci-keystone.c b/drivers/pci/host/pci-keystone.c index 81253e70b1c5..0aa81bd3de12 100644 --- a/drivers/pci/host/pci-keystone.c +++ b/drivers/pci/host/pci-keystone.c @@ -110,7 +110,7 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie)  	return -EINVAL;  } -static void ks_pcie_msi_irq_handler(unsigned int __irq, struct irq_desc *desc) +static void ks_pcie_msi_irq_handler(struct irq_desc *desc)  {  	unsigned int irq = irq_desc_get_irq(desc);  	struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); @@ -138,8 +138,7 @@ static void ks_pcie_msi_irq_handler(unsigned int __irq, struct irq_desc *desc)   * Traverse through pending legacy interrupts and invoke handler for each. Also   * takes care of interrupt controller level mask/ack operation.   */ -static void ks_pcie_legacy_irq_handler(unsigned int __irq, -				       struct irq_desc *desc) +static void ks_pcie_legacy_irq_handler(struct irq_desc *desc)  {  	unsigned int irq = irq_desc_get_irq(desc);  	struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); diff --git a/drivers/pci/host/pci-rcar-gen2.c b/drivers/pci/host/pci-rcar-gen2.c index 367e28fa7564..c4f64bfee551 100644 --- a/drivers/pci/host/pci-rcar-gen2.c +++ b/drivers/pci/host/pci-rcar-gen2.c @@ -362,6 +362,7 @@ static int rcar_pci_probe(struct platform_device *pdev)  static struct of_device_id rcar_pci_of_match[] = {  	{ .compatible = "renesas,pci-r8a7790", },  	{ .compatible = "renesas,pci-r8a7791", }, +	{ .compatible = "renesas,pci-r8a7794", },  	{ },  }; diff --git a/drivers/pci/host/pci-xgene-msi.c b/drivers/pci/host/pci-xgene-msi.c index 996327cfa1e1..e491681daf22 100644 --- a/drivers/pci/host/pci-xgene-msi.c +++ b/drivers/pci/host/pci-xgene-msi.c @@ -295,7 +295,7 @@ static int xgene_msi_init_allocator(struct xgene_msi *xgene_msi)  	return 0;  } -static void xgene_msi_isr(unsigned int irq, struct irq_desc *desc) +static void xgene_msi_isr(struct irq_desc *desc)  {  	struct irq_chip *chip = irq_desc_get_chip(desc);  	struct xgene_msi_group *msi_groups; diff --git a/drivers/pci/msi.c b/drivers/pci/msi.c index d4497141d083..4a7da3c3e035 100644 --- a/drivers/pci/msi.c +++ b/drivers/pci/msi.c @@ -1243,6 +1243,10 @@ static void pci_msi_domain_update_chip_ops(struct msi_domain_info *info)  	BUG_ON(!chip);  	if (!chip->irq_write_msi_msg)  		chip->irq_write_msi_msg = pci_msi_domain_write_msg; +	if (!chip->irq_mask) +		chip->irq_mask = pci_msi_mask_irq; +	if (!chip->irq_unmask) +		chip->irq_unmask = pci_msi_unmask_irq;  }  /** diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c index dd652f2ae03d..108a3118ace7 100644 --- a/drivers/pci/pci-driver.c +++ b/drivers/pci/pci-driver.c @@ -299,9 +299,10 @@ static long local_pci_probe(void *_ddi)  	 * Unbound PCI devices are always put in D0, regardless of  	 * runtime PM status.  During probe, the device is set to  	 * active and the usage count is incremented.  If the driver -	 * supports runtime PM, it should call pm_runtime_put_noidle() -	 * in its probe routine and pm_runtime_get_noresume() in its -	 * remove routine. +	 * supports runtime PM, it should call pm_runtime_put_noidle(), +	 * or any other runtime PM helper function decrementing the usage +	 * count, in its probe routine and pm_runtime_get_noresume() in +	 * its remove routine.  	 */  	pm_runtime_get_sync(dev);  	pci_dev->driver = pci_drv; diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c index 312f23a8429c..92618686604c 100644 --- a/drivers/pci/pci-sysfs.c +++ b/drivers/pci/pci-sysfs.c @@ -216,7 +216,7 @@ static ssize_t numa_node_store(struct device *dev,  	if (ret)  		return ret; -	if (!node_online(node)) +	if (node >= MAX_NUMNODES || !node_online(node))  		return -EINVAL;  	add_taint(TAINT_FIRMWARE_WORKAROUND, LOCKDEP_STILL_OK); diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c index 0b2be174d981..8361d27e5eca 100644 --- a/drivers/pci/probe.c +++ b/drivers/pci/probe.c @@ -676,15 +676,20 @@ static struct irq_domain *pci_host_bridge_msi_domain(struct pci_bus *bus)  static void pci_set_bus_msi_domain(struct pci_bus *bus)  {  	struct irq_domain *d; +	struct pci_bus *b;  	/* -	 * Either bus is the root, and we must obtain it from the -	 * firmware, or we inherit it from the bridge device. +	 * The bus can be a root bus, a subordinate bus, or a virtual bus +	 * created by an SR-IOV device.  Walk up to the first bridge device +	 * found or derive the domain from the host bridge.  	 */ -	if (pci_is_root_bus(bus)) -		d = pci_host_bridge_msi_domain(bus); -	else -		d = dev_get_msi_domain(&bus->self->dev); +	for (b = bus, d = NULL; !d && !pci_is_root_bus(b); b = b->parent) { +		if (b->self) +			d = dev_get_msi_domain(&b->self->dev); +	} + +	if (!d) +		d = pci_host_bridge_msi_domain(b);  	dev_set_msi_domain(&bus->dev, d);  } @@ -855,9 +860,6 @@ int pci_scan_bridge(struct pci_bus *bus, struct pci_dev *dev, int max, int pass)  			child->bridge_ctl = bctl;  		} -		/* Read and initialize bridge resources */ -		pci_read_bridge_bases(child); -  		cmax = pci_scan_child_bus(child);  		if (cmax > subordinate)  			dev_warn(&dev->dev, "bridge has subordinate %02x but max busn %02x\n", @@ -918,9 +920,6 @@ int pci_scan_bridge(struct pci_bus *bus, struct pci_dev *dev, int max, int pass)  		if (!is_cardbus) {  			child->bridge_ctl = bctl; - -			/* Read and initialize bridge resources */ -			pci_read_bridge_bases(child);  			max = pci_scan_child_bus(child);  		} else {  			/* diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 6a30252cd79f..b03373fd05ca 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -1907,11 +1907,27 @@ static void quirk_netmos(struct pci_dev *dev)  DECLARE_PCI_FIXUP_CLASS_HEADER(PCI_VENDOR_ID_NETMOS, PCI_ANY_ID,  			 PCI_CLASS_COMMUNICATION_SERIAL, 8, quirk_netmos); +/* + * Quirk non-zero PCI functions to route VPD access through function 0 for + * devices that share VPD resources between functions.  The functions are + * expected to be identical devices. + */  static void quirk_f0_vpd_link(struct pci_dev *dev)  { -	if (!dev->multifunction || !PCI_FUNC(dev->devfn)) +	struct pci_dev *f0; + +	if (!PCI_FUNC(dev->devfn))  		return; -	dev->dev_flags |= PCI_DEV_FLAGS_VPD_REF_F0; + +	f0 = pci_get_slot(dev->bus, PCI_DEVFN(PCI_SLOT(dev->devfn), 0)); +	if (!f0) +		return; + +	if (f0->vpd && dev->class == f0->class && +	    dev->vendor == f0->vendor && dev->device == f0->device) +		dev->dev_flags |= PCI_DEV_FLAGS_VPD_REF_F0; + +	pci_dev_put(f0);  }  DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_INTEL, PCI_ANY_ID,  			      PCI_CLASS_NETWORK_ETHERNET, 8, quirk_f0_vpd_link); | 

