Merge branches 'acpi-pci', 'acpi-soc' and 'pnp'
* acpi-pci: x86/ACPI/PCI: Recognize that Interrupt Line 255 means "not connected" * acpi-soc: i2c: designware: Add device HID for future AMD I2C controller * pnp: PNP / ACPI: add ACPI_RESOURCE_TYPE_SERIAL_BUS as a valid type
This commit is contained in:
@@ -143,6 +143,7 @@ static const struct acpi_device_id acpi_apd_device_ids[] = {
|
||||
/* Generic apd devices */
|
||||
#ifdef CONFIG_X86_AMD_PLATFORM_DEVICE
|
||||
{ "AMD0010", APD_ADDR(cz_i2c_desc) },
|
||||
{ "AMDI0010", APD_ADDR(cz_i2c_desc) },
|
||||
{ "AMD0020", APD_ADDR(cz_uart_desc) },
|
||||
{ "AMD0030", },
|
||||
#endif
|
||||
|
||||
@@ -33,6 +33,7 @@
|
||||
#include <linux/pci.h>
|
||||
#include <linux/acpi.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/interrupt.h>
|
||||
|
||||
#define PREFIX "ACPI: "
|
||||
|
||||
@@ -387,6 +388,23 @@ static inline int acpi_isa_register_gsi(struct pci_dev *dev)
|
||||
}
|
||||
#endif
|
||||
|
||||
static inline bool acpi_pci_irq_valid(struct pci_dev *dev, u8 pin)
|
||||
{
|
||||
#ifdef CONFIG_X86
|
||||
/*
|
||||
* On x86 irq line 0xff means "unknown" or "no connection"
|
||||
* (PCI 3.0, Section 6.2.4, footnote on page 223).
|
||||
*/
|
||||
if (dev->irq == 0xff) {
|
||||
dev->irq = IRQ_NOTCONNECTED;
|
||||
dev_warn(&dev->dev, "PCI INT %c: not connected\n",
|
||||
pin_name(pin));
|
||||
return false;
|
||||
}
|
||||
#endif
|
||||
return true;
|
||||
}
|
||||
|
||||
int acpi_pci_irq_enable(struct pci_dev *dev)
|
||||
{
|
||||
struct acpi_prt_entry *entry;
|
||||
@@ -431,11 +449,14 @@ int acpi_pci_irq_enable(struct pci_dev *dev)
|
||||
} else
|
||||
gsi = -1;
|
||||
|
||||
/*
|
||||
* No IRQ known to the ACPI subsystem - maybe the BIOS /
|
||||
* driver reported one, then use it. Exit in any case.
|
||||
*/
|
||||
if (gsi < 0) {
|
||||
/*
|
||||
* No IRQ known to the ACPI subsystem - maybe the BIOS /
|
||||
* driver reported one, then use it. Exit in any case.
|
||||
*/
|
||||
if (!acpi_pci_irq_valid(dev, pin))
|
||||
return 0;
|
||||
|
||||
if (acpi_isa_register_gsi(dev))
|
||||
dev_warn(&dev->dev, "PCI INT %c: no GSI\n",
|
||||
pin_name(pin));
|
||||
|
||||
Reference in New Issue
Block a user