Linus Torvalds
c8d0267efd
Merge tag 'pci-v4.8-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci
Pull PCI updates from Bjorn Helgaas:
"Highlights:
- ARM64 support for ACPI host bridges
- new drivers for Axis ARTPEC-6 and Marvell Aardvark
- new pci_alloc_irq_vectors() interface for MSI-X, MSI, legacy INTx
- pci_resource_to_user() cleanup (more to come)
Detailed summary:
Enumeration:
- Move ecam.h to linux/include/pci-ecam.h (Jayachandran C)
- Add parent device field to ECAM struct pci_config_window (Jayachandran C)
- Add generic MCFG table handling (Tomasz Nowicki)
- Refactor pci_bus_assign_domain_nr() for CONFIG_PCI_DOMAINS_GENERIC (Tomasz Nowicki)
- Factor DT-specific pci_bus_find_domain_nr() code out (Tomasz Nowicki)
Resource management:
- Add devm_request_pci_bus_resources() (Bjorn Helgaas)
- Unify pci_resource_to_user() declarations (Bjorn Helgaas)
- Implement pci_resource_to_user() with pcibios_resource_to_bus() (microblaze, powerpc, sparc) (Bjorn Helgaas)
- Request host bridge window resources (designware, iproc, rcar, xgene, xilinx, xilinx-nwl) (Bjorn Helgaas)
- Make PCI I/O space optional on ARM32 (Bjorn Helgaas)
- Ignore write combining when mapping I/O port space (Bjorn Helgaas)
- Claim bus resources on MIPS PCI_PROBE_ONLY set-ups (Bjorn Helgaas)
- Remove unicore32 pci=firmware command line parameter handling (Bjorn Helgaas)
- Support I/O resources when parsing host bridge resources (Jayachandran C)
- Add helpers to request/release memory and I/O regions (Johannes Thumshirn)
- Use pci_(request|release)_mem_regions (NVMe, lpfc, GenWQE, ethernet/intel, alx) (Johannes Thumshirn)
- Extend pci=resource_alignment to specify device/vendor IDs (Koehrer Mathias (ETAS/ESW5))
- Add generic pci_bus_claim_resources() (Lorenzo Pieralisi)
- Claim bus resources on ARM32 PCI_PROBE_ONLY set-ups (Lorenzo Pieralisi)
- Remove ARM32 and ARM64 arch-specific pcibios_enable_device() (Lorenzo Pieralisi)
- Add pci_unmap_iospace() to unmap I/O resources (Sinan Kaya)
- Remove powerpc __pci_mmap_set_pgprot() (Yinghai Lu)
PCI device hotplug:
- Allow additional bus numbers for hotplug bridges (Keith Busch)
- Ignore interrupts during D3cold (Lukas Wunner)
Power management:
- Enforce type casting for pci_power_t (Andy Shevchenko)
- Don't clear d3cold_allowed for PCIe ports (Mika Westerberg)
- Put PCIe ports into D3 during suspend (Mika Westerberg)
- Power on bridges before scanning new devices (Mika Westerberg)
- Runtime resume bridge before rescan (Mika Westerberg)
- Add runtime PM support for PCIe ports (Mika Westerberg)
- Remove redundant check of pcie_set_clkpm (Shawn Lin)
Virtualization:
- Add function 1 DMA alias quirk for Marvell 88SE9182 (Aaron Sierra)
- Add DMA alias quirk for Adaptec 3805 (Alex Williamson)
- Mark Atheros AR9485 and QCA9882 to avoid bus reset (Chris Blake)
- Add ACS quirk for Solarflare SFC9220 (Edward Cree)
MSI:
- Fix PCI_MSI dependencies (Arnd Bergmann)
- Add pci_msix_desc_addr() helper (Christoph Hellwig)
- Switch msix_program_entries() to use pci_msix_desc_addr() (Christoph Hellwig)
- Make the "entries" argument to pci_enable_msix() optional (Christoph Hellwig)
- Provide sensible IRQ vector alloc/free routines (Christoph Hellwig)
- Spread interrupt vectors in pci_alloc_irq_vectors() (Christoph Hellwig)
Error Handling:
- Bind DPC to Root Ports as well as Downstream Ports (Keith Busch)
- Remove DPC tristate module option (Keith Busch)
- Convert Downstream Port Containment driver to use devm_* functions (Mika Westerberg)
Generic host bridge driver:
- Select IRQ_DOMAIN (Arnd Bergmann)
- Claim bus resources on PCI_PROBE_ONLY set-ups (Lorenzo Pieralisi)
ACPI host bridge driver:
- Add ARM64 acpi_pci_bus_find_domain_nr() (Tomasz Nowicki)
- Add ARM64 ACPI support for legacy IRQs parsing and consolidation with DT code (Tomasz Nowicki)
- Implement ARM64 AML accessors for PCI_Config region (Tomasz Nowicki)
- Support ARM64 ACPI-based PCI host controller (Tomasz Nowicki)
Altera host bridge driver:
- Check link status before retrain link (Ley Foon Tan)
- Poll for link up status after retraining the link (Ley Foon Tan)
Axis ARTPEC-6 host bridge driver:
- Add PCI_MSI_IRQ_DOMAIN dependency (Arnd Bergmann)
- Add DT binding for Axis ARTPEC-6 PCIe controller (Niklas Cassel)
- Add Axis ARTPEC-6 PCIe controller driver (Niklas Cassel)
Intel VMD host bridge driver:
- Use lock save/restore in interrupt enable path (Jon Derrick)
- Select device dma ops to override (Keith Busch)
- Initialize list item in IRQ disable (Keith Busch)
- Use x86_vector_domain as parent domain (Keith Busch)
- Separate MSI and MSI-X vector sharing (Keith Busch)
Marvell Aardvark host bridge driver:
- Add DT binding for the Aardvark PCIe controller (Thomas Petazzoni)
- Add Aardvark PCI host controller driver (Thomas Petazzoni)
- Add Aardvark PCIe support for Armada 3700 (Thomas Petazzoni)
Microsoft Hyper-V host bridge driver:
- Fix interrupt cleanup path (Cathy Avery)
- Don't leak buffer in hv_pci_onchannelcallback() (Vitaly Kuznetsov)
- Handle all pending messages in hv_pci_onchannelcallback() (Vitaly Kuznetsov)
NVIDIA Tegra host bridge driver:
- Program PADS_REFCLK_CFG* always, not just on legacy SoCs (Stephen Warren)
- Program PADS_REFCLK_CFG* registers with per-SoC values (Stephen Warren)
- Use lower-case hex consistently for register definitions (Thierry Reding)
- Use generic pci_remap_iospace() rather than ARM32-specific one (Thierry Reding)
- Stop setting pcibios_min_mem (Thierry Reding)
Renesas R-Car host bridge driver:
- Drop gen2 dummy I/O port region (Bjorn Helgaas)
TI DRA7xx host bridge driver:
- Fix return value in case of error (Christophe JAILLET)
Xilinx AXI host bridge driver:
- Fix return value in case of error (Christophe JAILLET)
Miscellaneous:
- Make bus_attr_resource_alignment static (Ben Dooks)
- Include <asm/dma.h> for isa_dma_bridge_buggy (Ben Dooks)
- MAINTAINERS: Add file patterns for PCI device tree bindings (Geert Uytterhoeven)
- Make host bridge drivers explicitly non-modular (Paul Gortmaker)"
* tag 'pci-v4.8-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci: (125 commits)
PCI: xgene: Make explicitly non-modular
PCI: thunder-pem: Make explicitly non-modular
PCI: thunder-ecam: Make explicitly non-modular
PCI: tegra: Make explicitly non-modular
PCI: rcar-gen2: Make explicitly non-modular
PCI: rcar: Make explicitly non-modular
PCI: mvebu: Make explicitly non-modular
PCI: layerscape: Make explicitly non-modular
PCI: keystone: Make explicitly non-modular
PCI: hisi: Make explicitly non-modular
PCI: generic: Make explicitly non-modular
PCI: designware-plat: Make it explicitly non-modular
PCI: artpec6: Make explicitly non-modular
PCI: armada8k: Make explicitly non-modular
PCI: artpec: Add PCI_MSI_IRQ_DOMAIN dependency
PCI: Add ACS quirk for Solarflare SFC9220
arm64: dts: marvell: Add Aardvark PCIe support for Armada 3700
PCI: aardvark: Add Aardvark PCI host controller driver
dt-bindings: add DT binding for the Aardvark PCIe controller
PCI: tegra: Program PADS_REFCLK_CFG* registers with per-SoC values
...
2016-08-02 17:12:29 -04:00
..
2014-10-20 16:20:15 +02:00
2013-07-10 13:56:10 -07:00
2016-03-20 21:28:58 -07:00
2014-05-18 19:01:27 -07:00
2014-10-20 16:20:15 +02:00
2014-05-18 19:01:30 -07:00
2014-10-20 16:20:15 +02:00
2016-04-27 17:27:37 -04:00
2014-10-20 16:20:15 +02:00
2016-03-20 21:28:58 -07:00
2016-04-21 16:43:47 -04:00
2016-04-21 16:43:47 -04:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2011-10-31 19:30:54 -04:00
2014-09-16 18:31:31 -07:00
2008-12-04 09:17:21 -08:00
2016-07-27 17:50:26 -07:00
2014-01-28 23:38:23 -08:00
2015-05-31 22:15:01 -07:00
2016-05-20 17:55:41 -07:00
2012-05-27 23:52:49 -07:00
2012-10-14 19:26:52 -04:00
2016-04-27 17:27:37 -04:00
2014-03-07 10:06:14 -05:00
2008-12-04 09:17:21 -08:00
2012-07-26 16:46:15 -07:00
2016-04-27 17:27:37 -04:00
2010-08-08 22:07:36 -07:00
2015-03-19 18:54:49 -07:00
2016-01-31 11:06:24 -08:00
2014-10-24 09:52:49 -07:00
2016-01-06 16:31:56 -05:00
2015-05-05 13:35:39 -06:00
2015-11-04 11:30:57 -08:00
2016-03-20 21:28:58 -07:00
2016-07-27 22:53:17 -07:00
2016-07-04 12:25:13 +02:00
2014-05-18 19:01:29 -07:00
2008-12-04 09:17:21 -08:00
2008-12-04 09:17:21 -08:00
2015-08-03 11:34:12 +02:00
2016-05-20 17:55:41 -07:00
2016-05-20 17:55:41 -07:00
2014-05-18 19:01:34 -07:00
2014-08-26 13:45:55 -04:00
2010-04-14 02:04:29 -07:00
2016-07-27 17:50:26 -07:00
2015-11-04 11:30:57 -08:00
2010-03-30 22:02:32 +09:00
2016-03-20 21:28:58 -07:00
2015-09-16 15:47:51 +02:00
2015-09-16 15:47:51 +02:00
2015-03-19 10:17:22 -05:00
2014-04-29 01:12:27 -04:00
2014-12-11 18:51:56 -08:00
2016-05-29 18:55:54 -07:00
2015-12-23 10:41:31 -05:00
2016-04-27 17:27:37 -04:00
2015-02-13 21:21:42 -08:00
2014-08-26 13:45:55 -04:00
2012-04-15 10:28:49 -07:00
2012-07-06 07:16:34 -05:00
2014-04-29 01:12:27 -04:00
2009-06-16 04:56:49 -07:00
2015-10-29 17:35:46 -05:00
2014-10-20 16:20:15 +02:00
2015-10-29 17:35:46 -05:00
2014-11-23 13:01:45 +01:00
2014-10-20 16:20:15 +02:00
2014-10-20 16:20:15 +02:00
2014-12-14 16:10:09 -08:00
2008-12-04 09:17:21 -08:00
2015-11-04 11:30:57 -08:00
2014-05-18 19:01:29 -07:00
2016-06-17 14:45:03 -05:00
2015-03-12 15:04:01 -05:00
2015-03-19 18:54:49 -07:00
2016-05-16 23:11:51 -03:00
2014-10-20 16:20:15 +02:00
2014-10-20 16:20:15 +02:00
2016-05-20 17:58:30 -07:00
2016-05-20 17:58:30 -07:00
2011-10-31 19:30:54 -04:00
2014-05-18 19:01:31 -07:00
2013-06-13 22:12:14 +01:00
2011-06-07 16:06:34 -07:00
2014-05-18 19:01:29 -07:00
2011-06-07 16:06:34 -07:00
2014-05-18 19:01:29 -07:00
2014-04-29 01:12:26 -04:00
2014-09-23 16:21:26 -04:00
2012-03-28 18:30:03 +01:00
2012-05-27 23:52:49 -07:00
2016-05-29 18:55:54 -07:00
2013-01-21 14:33:00 -08:00
2016-05-20 17:55:41 -07:00
2016-04-21 16:43:47 -04:00
2016-05-29 11:24:05 -07:00
2016-05-29 11:24:05 -07:00
2016-05-29 11:24:05 -07:00
2016-05-29 11:24:05 -07:00
2016-05-29 11:24:05 -07:00
2011-08-20 17:14:54 -07:00
2016-03-01 20:36:57 +01:00
2016-03-01 20:36:57 +01:00
2014-01-28 23:38:23 -08:00
2016-01-31 11:06:24 -08:00
2016-04-27 17:27:37 -04:00
2011-08-02 21:28:52 -07:00
2011-10-31 19:30:53 -04:00
2015-03-01 21:33:58 -08:00
2015-07-31 22:20:05 +02:00
2014-08-26 13:45:55 -04:00
2015-07-31 22:20:05 +02:00
2015-08-10 11:41:05 +02:00
2008-12-04 09:17:21 -08:00
2014-09-16 17:46:44 -07:00
2014-07-21 22:27:56 -07:00
2014-05-18 19:01:31 -07:00
2014-05-18 19:01:28 -07:00
2016-03-20 21:28:58 -07:00
2016-01-21 16:06:00 -08:00
2016-03-20 21:28:58 -07:00
2016-03-29 18:39:26 -07:00
2016-03-29 18:39:26 -07:00
2014-05-18 19:01:31 -07:00
2015-08-10 11:41:05 +02:00
2015-08-10 11:41:05 +02:00
2014-01-28 23:38:23 -08:00
2014-10-24 09:52:49 -07:00
2015-04-12 21:03:21 +02:00
2015-04-12 21:03:21 +02:00
2016-07-27 17:50:26 -07:00
2012-05-19 23:27:25 -07:00
2012-05-19 23:26:41 -07:00
2011-02-01 12:39:59 -08:00
2011-03-16 18:19:15 -07:00
2014-07-21 21:37:06 -07:00
2016-03-20 21:28:58 -07:00
2016-05-29 18:55:54 -07:00
2016-04-27 17:27:37 -04:00
2016-04-21 16:43:46 -04:00
2014-09-30 14:17:08 -07:00
2012-10-26 15:18:37 -07:00
2016-04-27 17:27:37 -04:00
2014-04-29 01:12:25 -04:00
2016-04-27 17:27:37 -04:00
2012-05-27 23:52:49 -07:00
2012-05-27 23:52:49 -07:00