From: David Daney <david.daney@xxxxxxxxxx> The original patches are from Sean O. Stalley. I made a few tweaks, but feel that it is substancially Sean's work, so I am keeping the patch set version numbering scheme going. Tested on Cavium ThunderX system with 4 Root Complexes containing 50 devices/bridges provisioned with EA. Here is Sean's description of the patches: PCI Enhanced Allocation is a new method of allocating MMIO & IO resources for PCI devices & bridges. It can be used instead of the traditional PCI method of using BARs. EA entries are hardware-initialized to a fixed address. Unlike BARs, regions described by EA are cannot be moved. Because of this, only devices which are permanently connected to the PCI bus can use EA. A removable PCI card must not use EA. This patchset adds support for using EA entries instead of BARs on Root Complex Integrated Endpoints. The Enhanced Allocation ECN is publicly available here: https://www.pcisig.com/specifications/conventional/ECN_Enhanced_Allocation_23_Oct_2014_Final.pdf Changes from V1: - Use generic PCI resource claim functions (instead of EA-specific functions) - Only add support for RCiEPs (instead of all devices). - Removed some debugging messages leftover from early testing. Changes from V2 (By David Daney): - Add ea_cap to struct pci_device, to aid in finding the EA capability. - Factored EA entity decoding into a separate function. - Add functions to find EA entities by BEI or Property. - Add handling of EA provisioned bridges. - Add handling of EA SRIOV BARs. - Try to assign proper resource parent so that SRIOV device creation can occur. Sean O. Stalley (2): PCI: Add Enhanced Allocation register entries PCI: Add support for Enhanced Allocation devices drivers/pci/iov.c | 15 ++- drivers/pci/pci.c | 278 ++++++++++++++++++++++++++++++++++++++++++ drivers/pci/pci.h | 4 + drivers/pci/probe.c | 42 ++++++- drivers/pci/setup-bus.c | 3 + include/linux/pci.h | 1 + include/uapi/linux/pci_regs.h | 42 ++++++- 7 files changed, 380 insertions(+), 5 deletions(-) -- 1.9.1 -- To unsubscribe from this list: send the line "unsubscribe linux-api" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html