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
..
2015-10-27 09:20:50 +09:00
2016-06-21 10:54:29 -05:00
2016-07-06 10:42:14 +01:00
2016-02-18 19:15:45 +00:00
2014-12-04 23:30:26 -08:00
2015-03-27 13:44:35 +00:00
2016-06-22 19:54:52 +01:00
2016-06-16 10:48:32 +02:00
2015-03-27 22:20:45 +00:00
2016-07-02 11:01:08 +01:00
2015-08-18 14:00:30 +01:00
2015-01-16 14:06:18 +00:00
2013-09-23 18:47:31 -04:00
2015-12-03 00:02:29 +00:00
2016-02-22 08:51:37 +01:00
2016-03-13 23:55:13 -04:00
2015-10-09 16:22:54 +01:00
2015-02-10 10:23:11 +00:00
2014-06-02 09:20:18 +01:00
2012-11-19 14:51:11 +00:00
2016-04-20 06:59:10 +02:00
2016-04-19 19:42:26 +01:00
2013-01-10 21:13:05 +00:00
2014-05-28 13:33:18 -07:00
2016-06-22 19:55:12 +01:00
2014-12-04 12:41:50 +00:00
2016-02-11 15:33:37 +00:00
2013-08-27 09:18:29 +02:00
2015-05-03 23:21:55 +01:00
2016-05-20 10:01:38 -07:00
2015-05-05 13:35:39 -06:00
2016-05-05 19:03:02 +01:00
2015-05-28 15:31:53 +02:00
2016-06-27 13:06:56 +02:00
2015-04-14 21:03:26 -07:00
2015-05-08 17:33:50 +01:00
2016-03-25 16:37:42 -07:00
2015-06-06 02:17:56 +09:00
2015-12-13 19:18:28 +01:00
2012-10-09 20:29:06 +02:00
2016-07-02 11:02:13 +01:00
2014-09-26 14:40:03 +01:00
2015-08-25 16:14:43 +01:00
2015-08-01 22:25:04 +01:00
2014-05-30 01:12:30 +01:00
2014-07-18 12:29:37 +01:00
2014-06-30 21:37:39 +02:00
2015-12-22 12:09:43 +00:00
2015-11-09 15:11:24 -08:00
2013-06-04 16:52:37 +01:00
2015-06-25 17:00:35 -07:00
2014-02-10 11:48:05 +00:00
2015-09-16 16:53:39 +02:00
2014-02-25 11:40:48 +00:00
2013-04-28 22:23:08 -07:00
2015-01-13 16:10:17 +00:00
2016-07-28 14:22:25 -07:00
2014-09-13 18:38:39 +02:00
2015-11-26 18:05:01 +00:00
2015-09-22 08:13:56 +01:00
2015-08-03 11:34:15 +02:00
2016-03-20 14:37:22 -07:00
2013-10-19 20:46:35 +01:00
2015-01-14 12:24:52 +00:00
2015-12-18 10:15:12 +00:00
2016-07-03 23:41:27 +02:00
2013-01-23 13:29:14 -05:00
2016-02-29 18:34:15 +00:00
2016-07-18 18:10:31 +01:00
2016-07-03 23:41:27 +02:00
2016-05-20 15:39:42 +02:00
2016-07-03 23:41:27 +02:00
2014-04-30 04:18:57 -07:00
2015-05-06 11:47:10 -04:00
2014-07-18 12:29:35 +01:00
2014-06-01 01:17:12 +01:00
2016-05-03 11:17:28 +01:00
2016-05-13 16:12:53 +02:00
2015-03-27 22:20:45 +00:00
2015-05-08 10:42:34 +01:00
2013-06-17 15:13:18 +01:00
2012-08-25 09:22:31 +01:00
2013-07-08 22:08:51 +01:00
2013-01-10 21:10:20 +00:00
2012-09-19 08:32:49 +01:00
2013-01-10 21:10:20 +00:00
2015-07-25 15:28:05 +01:00
2016-02-26 15:24:55 +01:00
2013-08-01 14:31:58 +01:00
2015-12-21 14:40:54 +00:00
2015-01-09 09:36:50 +00:00
2016-03-07 10:40:02 -06:00
2014-11-13 23:58:06 +00:00
2015-05-27 16:12:05 +01:00
2016-07-26 16:19:19 -07:00
2015-08-21 13:55:53 +01:00
2016-06-09 17:51:47 +01:00
2014-12-03 15:57:45 +00:00
2016-06-09 17:51:47 +01:00
2015-02-11 17:06:03 -08:00
2016-08-02 16:11:27 -04:00
2015-01-14 12:24:52 +00:00
2015-06-01 23:48:19 +01:00
2014-07-17 12:32:47 +02:00
2014-04-30 00:59:17 -05:00
2016-01-20 17:55:20 -08:00
2016-07-07 16:01:01 +01:00
2016-02-11 15:43:14 +00:00
2016-01-04 11:26:00 +00:00
2013-02-03 18:15:47 -05:00
2015-07-31 18:58:30 +01:00
2014-07-18 12:29:02 +01:00
2013-03-11 08:42:08 -05:00
2015-09-22 08:13:57 +01:00
2016-02-16 16:35:21 +00:00
2013-09-30 16:42:55 +01:00
2016-06-14 11:55:15 +02:00
2014-07-18 12:29:11 +01:00
2016-04-21 14:57:26 +02:00
2015-06-12 21:17:17 +01:00
2012-10-12 13:05:52 +01:00
2015-08-04 09:37:52 +02:00
2014-02-25 11:33:37 +00:00
2014-09-26 14:39:53 +01:00
2015-05-08 10:42:35 +01:00
2013-07-09 10:33:29 -07:00
2015-09-14 12:24:10 -07:00
2013-12-20 17:17:16 +01:00
2016-07-26 16:19:19 -07:00
2013-10-29 11:06:13 +00:00
2014-09-30 16:55:23 +01:00
2015-05-27 15:22:15 +02:00
2014-05-23 21:28:11 +02:00
2013-08-25 17:09:46 +01:00
2016-06-22 19:55:11 +01:00
2015-05-08 17:33:50 +01:00
2016-04-07 21:57:02 +01:00
2014-03-18 16:39:40 -04:00
2013-09-02 13:49:29 +01:00
2015-03-27 22:20:45 +00:00
2015-03-27 22:20:45 +00:00
2015-05-20 15:07:00 -07:00
2012-10-29 10:04:05 +00:00
2016-07-03 23:41:27 +02:00
2015-03-29 23:11:56 +01:00
2013-07-08 22:09:06 +01:00