public inbox for linux-pm@vger.kernel.org
 help / color / mirror / Atom feed
* [Patch v2]
@ 2015-08-21  7:26 Jiang Liu
  2015-08-21  7:32 ` Jiang Liu
  0 siblings, 1 reply; 71+ messages in thread
From: Jiang Liu @ 2015-08-21  7:26 UTC (permalink / raw)
  To: Thomas Gleixner, Rafael J . Wysocki, Nick Meier,
	Rafael J. Wysocki, Len Brown, Pavel Machek, Ingo Molnar,
	H. Peter Anvin, x86
  Cc: Jiang Liu, linux-acpi, linux-kernel, linux-pm

Hi Nick,
	Rafael and Thomas have concerns about the way to solve the
regression by quirk, so could you please help to test this patch?
Thanks!
Gerry

Signed-off-by: Jiang Liu <jiang.liu@linux.intel.com>
---
 arch/x86/kernel/acpi/boot.c |    1 +
 drivers/acpi/pci_link.c     |   16 ++++++++++++++++
 include/linux/acpi.h        |    2 +-
 3 files changed, 18 insertions(+), 1 deletion(-)

diff --git a/arch/x86/kernel/acpi/boot.c b/arch/x86/kernel/acpi/boot.c
index e49ee24da85e..9393896717d0 100644
--- a/arch/x86/kernel/acpi/boot.c
+++ b/arch/x86/kernel/acpi/boot.c
@@ -445,6 +445,7 @@ static void __init acpi_sci_ioapic_setup(u8 bus_irq, u16 polarity, u16 trigger,
 		polarity = acpi_sci_flags & ACPI_MADT_POLARITY_MASK;
 
 	mp_override_legacy_irq(bus_irq, polarity, trigger, gsi);
+	acpi_penalize_sci_irq(bus_irq, trigger, polarity);
 
 	/*
 	 * stash over-ride to indicate we've been here
diff --git a/drivers/acpi/pci_link.c b/drivers/acpi/pci_link.c
index cfd7581cc19f..b09ad554430a 100644
--- a/drivers/acpi/pci_link.c
+++ b/drivers/acpi/pci_link.c
@@ -826,6 +826,22 @@ void acpi_penalize_isa_irq(int irq, int active)
 }
 
 /*
+ * Penalize IRQ used by ACPI SCI. If ACPI SCI pin attributes conflict with
+ * PCI IRQ attributes, mark ACPI SCI as ISA_ALWAYS so it won't be use for
+ * PCI IRQs.
+ */
+void acpi_penalize_sci_irq(int irq, int trigger, int polarity)
+{
+	if (irq >= 0 && irq < ARRAY_SIZE(acpi_irq_penalty)) {
+		if (trigger != ACPI_MADT_TRIGGER_LEVEL ||
+		    polarity != ACPI_MADT_POLARITY_ACTIVE_LOW)
+			acpi_irq_penalty[irq] += PIRQ_PENALTY_ISA_ALWAYS;
+		else
+			acpi_irq_penalty[irq] += PIRQ_PENALTY_PCI_USING;
+	}
+}
+
+/*
  * Over-ride default table to reserve additional IRQs for use by ISA
  * e.g. acpi_irq_isa=5
  * Useful for telling ACPI how not to interfere with your ISA sound card.
diff --git a/include/linux/acpi.h b/include/linux/acpi.h
index d2445fa9999f..0b2394f61af4 100644
--- a/include/linux/acpi.h
+++ b/include/linux/acpi.h
@@ -221,7 +221,7 @@ struct pci_dev;
 
 int acpi_pci_irq_enable (struct pci_dev *dev);
 void acpi_penalize_isa_irq(int irq, int active);
-
+void acpi_penalize_sci_irq(int irq, int trigger, int polarity);
 void acpi_pci_irq_disable (struct pci_dev *dev);
 
 extern int ec_read(u8 addr, u8 *val);
-- 
1.7.10.4


^ permalink raw reply related	[flat|nested] 71+ messages in thread

end of thread, other threads:[~2015-08-21  7:32 UTC | newest]

Thread overview: 71+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <20140724212620.GO3935@laptop>
2014-07-24 22:02 ` [RFC][PATCH] irq: Rework IRQF_NO_SUSPENDED Rafael J. Wysocki
2014-07-24 23:10 ` Rafael J. Wysocki
2014-07-25  5:58   ` Peter Zijlstra
2014-07-29 19:20     ` Brian Norris
2014-07-29 19:28       ` Peter Zijlstra
2014-07-29 20:41         ` Brian Norris
2014-07-25  9:27   ` Thomas Gleixner
2014-07-25 12:49     ` Rafael J. Wysocki
2014-07-25 13:55       ` Thomas Gleixner
     [not found] ` <alpine.DEB.2.10.1407251135590.23352@nanos>
2014-07-25 12:47   ` Rafael J. Wysocki
2014-07-25 13:22     ` Peter Zijlstra
     [not found] ` <20140725124037.GL20603@laptop.programming.kicks-ass.net>
     [not found]   ` <20140725132541.GT12054@laptop.lan>
2014-07-25 17:03     ` Rafael J. Wysocki
2014-07-25 16:58       ` Peter Zijlstra
2014-07-25 21:00       ` Thomas Gleixner
2014-07-25 22:25         ` Rafael J. Wysocki
2014-07-25 23:07           ` Rafael J. Wysocki
2014-07-26 11:49           ` Rafael J. Wysocki
2014-07-26 11:53             ` Rafael J. Wysocki
2014-07-28  6:49             ` Peter Zijlstra
2014-07-28 12:33               ` Thomas Gleixner
2014-07-28 13:04                 ` Peter Zijlstra
2014-07-28 21:53                 ` Rafael J. Wysocki
2014-07-28 23:01                   ` Rafael J. Wysocki
2014-07-29 12:46                     ` Thomas Gleixner
2014-07-29 13:33                       ` Rafael J. Wysocki
2014-07-30 21:46                         ` [PATCH 0/3] irq / PM: wakeup interrupt interface for drivers (was: Re: [RFC][PATCH] irq: Rework IRQF_NO_SUSPENDED) Rafael J. Wysocki
2014-07-30 21:51                           ` [PATCH 1/3] irq / PM: New driver interface for wakeup interrupts Rafael J. Wysocki
2014-07-30 22:56                             ` Thomas Gleixner
2014-07-31  0:12                               ` Thomas Gleixner
2014-07-31  2:14                                 ` Rafael J. Wysocki
2014-07-31 10:44                                   ` Thomas Gleixner
2014-07-31 18:36                                     ` Rafael J. Wysocki
2014-07-31 20:12                                       ` Alan Stern
2014-07-31 21:04                                         ` Rafael J. Wysocki
2014-07-31 23:41                                           ` Thomas Gleixner
2014-08-01  0:51                                             ` Rafael J. Wysocki
2014-08-01 14:41                                             ` Alan Stern
2014-07-31 22:16                                       ` Thomas Gleixner
2014-08-01  0:08                                         ` Rafael J. Wysocki
2014-08-01  1:24                                           ` Rafael J. Wysocki
2014-08-01  9:40                                           ` [PATCH 1/3] irq / PM: New driver interface for wakeup interruptsn Thomas Gleixner
2014-08-01 13:45                                             ` Rafael J. Wysocki
2014-08-01 13:43                                               ` Thomas Gleixner
2014-08-01 14:29                                                 ` Rafael J. Wysocki
2014-08-02  1:31                                                   ` Rafael J. Wysocki
2014-08-03 13:42                                                     ` Rafael J. Wysocki
2014-08-04  3:38                                                       ` Rafael J. Wysocki
2014-08-05 15:22                                                   ` [PATCH 0/5] irq / PM: Shared IRQs vs IRQF_NO_SUSPEND and suspend-to-idle wakeup Rafael J. Wysocki
2014-08-05 15:24                                                     ` [PATCH 1/5] PM / sleep: Mechanism for aborting system suspends unconditionally Rafael J. Wysocki
2014-08-05 23:29                                                       ` [Update][PATCH " Rafael J. Wysocki
2014-08-05 15:25                                                     ` [PATCH 2/5] irq / PM: Fix IRQF_NO_SUSPEND problem with shared interrupts Rafael J. Wysocki
2014-08-05 15:26                                                     ` [PATCH 3/5] irq / PM: Make wakeup interrupts wake up from suspend-to-idle Rafael J. Wysocki
2014-08-08  1:58                                                       ` [Update][PATCH " Rafael J. Wysocki
2014-08-09  0:28                                                         ` Rafael J. Wysocki
2014-08-05 15:27                                                     ` [PATCH 4/5] x86 / PM: Set IRQCHIP_SKIP_SET_WAKE for IOAPIC IRQ chip objects Rafael J. Wysocki
2014-08-05 15:28                                                     ` [PATCH 5/5] PCI / PM: Make PCIe PME interrupts wake up from suspend-to-idle Rafael J. Wysocki
2014-08-05 16:12                                                     ` [PATCH 0/5] irq / PM: Shared IRQs vs IRQF_NO_SUSPEND and suspend-to-idle wakeup Peter Zijlstra
2014-08-08  2:09                                                     ` Rafael J. Wysocki
2014-07-31 22:54                                       ` [PATCH 1/3] irq / PM: New driver interface for wakeup interrupts Thomas Gleixner
2014-07-30 21:51                           ` [PATCH 2/3] PCI / PM: Make PCIe PME interrupts wake up from "freeze" sleep state Rafael J. Wysocki
2014-07-30 21:52                           ` [PATCH 3/3] gpio-keys / PM: use enable/disable_device_irq_wake() Rafael J. Wysocki
2014-07-28 21:27               ` [RFC][PATCH] irq: Rework IRQF_NO_SUSPENDED Rafael J. Wysocki
2014-07-27 15:53           ` Rafael J. Wysocki
2014-07-27 22:00             ` [PATCH, v2] Rafael J. Wysocki
2014-07-28 12:11               ` Thomas Gleixner
2014-07-28 21:17                 ` [PATCH, v3] irq / PM: Fix IRQF_NO_SUSPEND problem with shared interrupts (was: Re: [PATCH, v2]) Rafael J. Wysocki
2014-07-29  7:28                   ` [PATCH, v4] irq / PM: Fix IRQF_NO_SUSPEND problem with shared interrupts Rafael J. Wysocki
2014-07-29 13:46                     ` [PATCH, v5] " Rafael J. Wysocki
2014-07-30  0:54                       ` [PATCH, v6] " Rafael J. Wysocki
2015-08-21  7:26 [Patch v2] Jiang Liu
2015-08-21  7:32 ` Jiang Liu

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox