mirror of
https://github.com/torvalds/linux.git
synced 2024-11-26 22:21:42 +00:00
PCI updates for v4.5:
Enumeration Revert x86 pcibios_alloc_irq() to fix regression (Bjorn Helgaas) Marvell MVEBU host bridge driver Restrict build to 32-bit ARM (Thierry Reding) -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJW0gP1AAoJEFmIoMA60/r84qkQAJXOFW20cie2yepQXIk7f5aN M2/+iFte8YHf4ZFgZWA/oS+mZAp1OqctSTjWg1KTPZsPHAiB6DkL7WOV6fK+uXr9 fX8D7Ec2eLgeIFl78iSQaAht4kfmfz8f5LlU6Oi9kvQOt+35gp4lP834HClx7Jep XT2qZy/zUQy8GylTzRqueMBpXBCnBQR8iyaD8j4rmklQB3yLXaEMTs7HzwJKBmhM ZDnH1xrV5cWYb7niSCBkq4IomCmezJZCvxcDjh/Z8gjDKbVl7TLYOdU8Jh4wNO++ ng0J8WDSKQJ9Hfv6H+5dgPzoqgrIrWb/Oz5GXd8i6cqv00szG5S/w8nHcO8LPSJv dJxxfTlz4KRxdv/sqOVW4cDFUmScODMkDMh+hAeEVYKl9ty5fQ4O2iNwNehzrdNj FRrgN1980amYN2n09NZNF863dvVN+DMJ4Ll2VT01rOIUH3bwt4cO6rVWrEUlEKCn DiSvJlXHm5nLLCQpkkGKAeq5hYl25DFtYVwLopIbUSHFXCASHPtQewDvgzfn9zYi M7J8bDa/uTscSqJsGsb4/gHLEblCfju7Pj2gEHoiK4XtbCuuamFA3nsA7lzcAG9j W5pVDQTqctdgHq/UMLKIeoBJ592fhYzKipY8vELOKwkieDR9F3g3u8nWt4ZAUIXE /oS5F1eWMkDMvdjyZO4C =yQ41 -----END PGP SIGNATURE----- Merge tag 'pci-v4.5-fixes-3' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci Pull PCI fixes from Bjorn Helgaas: "Enumeration: Revert x86 pcibios_alloc_irq() to fix regression (Bjorn Helgaas) Marvell MVEBU host bridge driver: Restrict build to 32-bit ARM (Thierry Reding)" * tag 'pci-v4.5-fixes-3' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci: PCI: mvebu: Restrict build to 32-bit ARM Revert "PCI, x86: Implement pcibios_alloc_irq() and pcibios_free_irq()" Revert "PCI: Add helpers to manage pci_dev->irq and pci_dev->irq_managed" Revert "x86/PCI: Don't alloc pcibios-irq when MSI is enabled"
This commit is contained in:
commit
a9f8094aae
@ -93,6 +93,8 @@ extern raw_spinlock_t pci_config_lock;
|
|||||||
extern int (*pcibios_enable_irq)(struct pci_dev *dev);
|
extern int (*pcibios_enable_irq)(struct pci_dev *dev);
|
||||||
extern void (*pcibios_disable_irq)(struct pci_dev *dev);
|
extern void (*pcibios_disable_irq)(struct pci_dev *dev);
|
||||||
|
|
||||||
|
extern bool mp_should_keep_irq(struct device *dev);
|
||||||
|
|
||||||
struct pci_raw_ops {
|
struct pci_raw_ops {
|
||||||
int (*read)(unsigned int domain, unsigned int bus, unsigned int devfn,
|
int (*read)(unsigned int domain, unsigned int bus, unsigned int devfn,
|
||||||
int reg, int len, u32 *val);
|
int reg, int len, u32 *val);
|
||||||
|
@ -711,28 +711,22 @@ int pcibios_add_device(struct pci_dev *dev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pcibios_alloc_irq(struct pci_dev *dev)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* If the PCI device was already claimed by core code and has
|
|
||||||
* MSI enabled, probing of the pcibios IRQ will overwrite
|
|
||||||
* dev->irq. So bail out if MSI is already enabled.
|
|
||||||
*/
|
|
||||||
if (pci_dev_msi_enabled(dev))
|
|
||||||
return -EBUSY;
|
|
||||||
|
|
||||||
return pcibios_enable_irq(dev);
|
|
||||||
}
|
|
||||||
|
|
||||||
void pcibios_free_irq(struct pci_dev *dev)
|
|
||||||
{
|
|
||||||
if (pcibios_disable_irq)
|
|
||||||
pcibios_disable_irq(dev);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pcibios_enable_device(struct pci_dev *dev, int mask)
|
int pcibios_enable_device(struct pci_dev *dev, int mask)
|
||||||
{
|
{
|
||||||
return pci_enable_resources(dev, mask);
|
int err;
|
||||||
|
|
||||||
|
if ((err = pci_enable_resources(dev, mask)) < 0)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
if (!pci_dev_msi_enabled(dev))
|
||||||
|
return pcibios_enable_irq(dev);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void pcibios_disable_device (struct pci_dev *dev)
|
||||||
|
{
|
||||||
|
if (!pci_dev_msi_enabled(dev) && pcibios_disable_irq)
|
||||||
|
pcibios_disable_irq(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
int pci_ext_cfg_avail(void)
|
int pci_ext_cfg_avail(void)
|
||||||
|
@ -215,7 +215,7 @@ static int intel_mid_pci_irq_enable(struct pci_dev *dev)
|
|||||||
int polarity;
|
int polarity;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (pci_has_managed_irq(dev))
|
if (dev->irq_managed && dev->irq > 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
switch (intel_mid_identify_cpu()) {
|
switch (intel_mid_identify_cpu()) {
|
||||||
@ -256,13 +256,10 @@ static int intel_mid_pci_irq_enable(struct pci_dev *dev)
|
|||||||
|
|
||||||
static void intel_mid_pci_irq_disable(struct pci_dev *dev)
|
static void intel_mid_pci_irq_disable(struct pci_dev *dev)
|
||||||
{
|
{
|
||||||
if (pci_has_managed_irq(dev)) {
|
if (!mp_should_keep_irq(&dev->dev) && dev->irq_managed &&
|
||||||
|
dev->irq > 0) {
|
||||||
mp_unmap_irq(dev->irq);
|
mp_unmap_irq(dev->irq);
|
||||||
dev->irq_managed = 0;
|
dev->irq_managed = 0;
|
||||||
/*
|
|
||||||
* Don't reset dev->irq here, otherwise
|
|
||||||
* intel_mid_pci_irq_enable() will fail on next call.
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1202,7 +1202,7 @@ static int pirq_enable_irq(struct pci_dev *dev)
|
|||||||
struct pci_dev *temp_dev;
|
struct pci_dev *temp_dev;
|
||||||
int irq;
|
int irq;
|
||||||
|
|
||||||
if (pci_has_managed_irq(dev))
|
if (dev->irq_managed && dev->irq > 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
irq = IO_APIC_get_PCI_irq_vector(dev->bus->number,
|
irq = IO_APIC_get_PCI_irq_vector(dev->bus->number,
|
||||||
@ -1230,7 +1230,8 @@ static int pirq_enable_irq(struct pci_dev *dev)
|
|||||||
}
|
}
|
||||||
dev = temp_dev;
|
dev = temp_dev;
|
||||||
if (irq >= 0) {
|
if (irq >= 0) {
|
||||||
pci_set_managed_irq(dev, irq);
|
dev->irq_managed = 1;
|
||||||
|
dev->irq = irq;
|
||||||
dev_info(&dev->dev, "PCI->APIC IRQ transform: "
|
dev_info(&dev->dev, "PCI->APIC IRQ transform: "
|
||||||
"INT %c -> IRQ %d\n", 'A' + pin - 1, irq);
|
"INT %c -> IRQ %d\n", 'A' + pin - 1, irq);
|
||||||
return 0;
|
return 0;
|
||||||
@ -1256,10 +1257,24 @@ static int pirq_enable_irq(struct pci_dev *dev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool mp_should_keep_irq(struct device *dev)
|
||||||
|
{
|
||||||
|
if (dev->power.is_prepared)
|
||||||
|
return true;
|
||||||
|
#ifdef CONFIG_PM
|
||||||
|
if (dev->power.runtime_status == RPM_SUSPENDING)
|
||||||
|
return true;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static void pirq_disable_irq(struct pci_dev *dev)
|
static void pirq_disable_irq(struct pci_dev *dev)
|
||||||
{
|
{
|
||||||
if (io_apic_assign_pci_irqs && pci_has_managed_irq(dev)) {
|
if (io_apic_assign_pci_irqs && !mp_should_keep_irq(&dev->dev) &&
|
||||||
|
dev->irq_managed && dev->irq) {
|
||||||
mp_unmap_irq(dev->irq);
|
mp_unmap_irq(dev->irq);
|
||||||
pci_reset_managed_irq(dev);
|
dev->irq = 0;
|
||||||
|
dev->irq_managed = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -406,7 +406,7 @@ int acpi_pci_irq_enable(struct pci_dev *dev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pci_has_managed_irq(dev))
|
if (dev->irq_managed && dev->irq > 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
entry = acpi_pci_irq_lookup(dev, pin);
|
entry = acpi_pci_irq_lookup(dev, pin);
|
||||||
@ -451,7 +451,8 @@ int acpi_pci_irq_enable(struct pci_dev *dev)
|
|||||||
kfree(entry);
|
kfree(entry);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
pci_set_managed_irq(dev, rc);
|
dev->irq = rc;
|
||||||
|
dev->irq_managed = 1;
|
||||||
|
|
||||||
if (link)
|
if (link)
|
||||||
snprintf(link_desc, sizeof(link_desc), " -> Link[%s]", link);
|
snprintf(link_desc, sizeof(link_desc), " -> Link[%s]", link);
|
||||||
@ -474,9 +475,17 @@ void acpi_pci_irq_disable(struct pci_dev *dev)
|
|||||||
u8 pin;
|
u8 pin;
|
||||||
|
|
||||||
pin = dev->pin;
|
pin = dev->pin;
|
||||||
if (!pin || !pci_has_managed_irq(dev))
|
if (!pin || !dev->irq_managed || dev->irq <= 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
/* Keep IOAPIC pin configuration when suspending */
|
||||||
|
if (dev->dev.power.is_prepared)
|
||||||
|
return;
|
||||||
|
#ifdef CONFIG_PM
|
||||||
|
if (dev->dev.power.runtime_status == RPM_SUSPENDING)
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
|
||||||
entry = acpi_pci_irq_lookup(dev, pin);
|
entry = acpi_pci_irq_lookup(dev, pin);
|
||||||
if (!entry)
|
if (!entry)
|
||||||
return;
|
return;
|
||||||
@ -496,6 +505,6 @@ void acpi_pci_irq_disable(struct pci_dev *dev)
|
|||||||
dev_dbg(&dev->dev, "PCI INT %c disabled\n", pin_name(pin));
|
dev_dbg(&dev->dev, "PCI INT %c disabled\n", pin_name(pin));
|
||||||
if (gsi >= 0) {
|
if (gsi >= 0) {
|
||||||
acpi_unregister_gsi(gsi);
|
acpi_unregister_gsi(gsi);
|
||||||
pci_reset_managed_irq(dev);
|
dev->irq_managed = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ config PCI_DRA7XX
|
|||||||
config PCI_MVEBU
|
config PCI_MVEBU
|
||||||
bool "Marvell EBU PCIe controller"
|
bool "Marvell EBU PCIe controller"
|
||||||
depends on ARCH_MVEBU || ARCH_DOVE
|
depends on ARCH_MVEBU || ARCH_DOVE
|
||||||
|
depends on ARM
|
||||||
depends on OF
|
depends on OF
|
||||||
|
|
||||||
config PCIE_DW
|
config PCIE_DW
|
||||||
|
@ -988,23 +988,6 @@ static inline int pci_is_managed(struct pci_dev *pdev)
|
|||||||
return pdev->is_managed;
|
return pdev->is_managed;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pci_set_managed_irq(struct pci_dev *pdev, unsigned int irq)
|
|
||||||
{
|
|
||||||
pdev->irq = irq;
|
|
||||||
pdev->irq_managed = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pci_reset_managed_irq(struct pci_dev *pdev)
|
|
||||||
{
|
|
||||||
pdev->irq = 0;
|
|
||||||
pdev->irq_managed = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline bool pci_has_managed_irq(struct pci_dev *pdev)
|
|
||||||
{
|
|
||||||
return pdev->irq_managed && pdev->irq > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void pci_disable_device(struct pci_dev *dev);
|
void pci_disable_device(struct pci_dev *dev);
|
||||||
|
|
||||||
extern unsigned int pcibios_max_latency;
|
extern unsigned int pcibios_max_latency;
|
||||||
|
Loading…
Reference in New Issue
Block a user