Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754457Ab0BINdz (ORCPT ); Tue, 9 Feb 2010 08:33:55 -0500 Received: from ogre.sisk.pl ([217.79.144.158]:36111 "EHLO ogre.sisk.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754189Ab0BINdy (ORCPT ); Tue, 9 Feb 2010 08:33:54 -0500 From: "Rafael J. Wysocki" To: Gary Hade Subject: Re: [linux-pm] [PATCH 8/9] PCI / ACPI / PM: Platform support for PCI PME wake-up (rev. 7) Date: Tue, 9 Feb 2010 14:34:35 +0100 User-Agent: KMail/1.12.4 (Linux/2.6.33-rc7-rjw; KDE/4.3.5; x86_64; ; ) Cc: linux-pm@lists.linux-foundation.org, Linux PCI , LKML , Jesse Barnes , "Moore, Robert" , Matthew Garrett References: <201001101431.38630.rjw@sisk.pl> <20100209005324.GB17124@us.ibm.com> <201002091348.20245.rjw@sisk.pl> In-Reply-To: <201002091348.20245.rjw@sisk.pl> MIME-Version: 1.0 Content-Type: Text/Plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Message-Id: <201002091434.35421.rjw@sisk.pl> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 6554 Lines: 127 On Tuesday 09 February 2010, Rafael J. Wysocki wrote: > On Tuesday 09 February 2010, Gary Hade wrote: > > On Mon, Feb 08, 2010 at 03:37:08PM -0800, Gary Hade wrote: > > > On Mon, Feb 08, 2010 at 10:30:30PM +0100, Rafael J. Wysocki wrote: > > > > On Monday 08 February 2010, Rafael J. Wysocki wrote: > > > > > On Monday 08 February 2010, Gary Hade wrote: > > > > > > On Sat, Feb 06, 2010 at 09:11:56PM +0100, Rafael J. Wysocki wrote: > > > > > > > On Saturday 06 February 2010, Bjorn Helgaas wrote: > > > > > > > > On Sunday 10 January 2010 07:01:03 am Rafael J. Wysocki wrote: > > > > > > > > > From: Rafael J. Wysocki > > > > > > > > > > > > > > > > > > Although the majority of PCI devices can generate PMEs that in > > > > > > > > > principle may be used to wake up devices suspended at run time, > > > > > > > > > platform support is generally necessary to convert PMEs into wake-up > > > > > > > > > events that can be delivered to the kernel. If ACPI is used for this > > > > > > > > > purpose, a PME generated by a PCI device will trigger the ACPI GPE > > > > > > > > > associated with the device to generate an ACPI wake-up event that we > > > > > > > > > can set up a handler for, provided that everything is configured > > > > > > > > > correctly. > > > > > > > > > > > > > > > > I think acpiphp needs a little attention after this patch. Gary > > > > > > > > Hade noticed while testing Jesse's linux-next branch that acpiphp > > > > > > > > complains like this: > > > > > > > > > > > > > > > > acpiphp: ACPI Hot Plug PCI Controller Driver version: 0.5 > > > > > > > > acpiphp: Slot [9] registered > > > > > > > > acpiphp: Slot [10] registered > > > > > > > > acpiphp_glue: failed to register interrupt notify handler > > > > > > > > acpiphp: Slot [6] registered > > > > > > > > acpiphp_glue: failed to register interrupt notify handler > > > > > > > > > > > > > > > > I reproduced this on an HP rx3600 (ia64), and found that acpiphp > > > > > > > > doesn't complain on commit 82533a617f453, but it *does* complain > > > > > > > > on commit fb3383bb4ac6e, which seems to be this patch. > > > > > > > > > > > > > > I can't see the possible reason looking at the code alone. > > > > > > > > > > > > > > Could you add a debug printk() printing the error code returned by > > > > > > > pci_acpi_add_hp_notifier() in acpiphp_glue.c:register_slot(), please? > > > > > > > > > > > > Rafael, On the system where I ran into the problem it returns > > > > > > AE_NOT_FOUND. See below. > > > > > > > > > > Thanks! > > > > > > > > > > Well, that means there's no struct acpi_device object associated with handle. > > > > > > > > > > I must admit I didn't take that into consideration, but it should be easily > > > > > fixable. I'll send a patch for that later today. > > > > > > > > Patch appended. > > > > > > > > If the theory is correct, it should fix the issue. Please test. > > > > > > Well, acpiphp now loads OK with no disturbing messages: > > > [ 247.360878] pci_hotplug: PCI Hot Plug PCI Core version: 0.5 > > > [ 247.385048] acpiphp: ACPI Hot Plug PCI Controller Driver version: 0.5 > > > [ 247.385459] acpiphp_glue: found PCI host-bus bridge with hot-pluggable slots > > > [ 247.385486] acpiphp_glue: found ACPI PCI Hotplug slot 1 at PCI 0000:02:01 > > > [ 247.385519] acpiphp: Slot [1] registered > > > [ 247.386167] acpiphp_glue: found PCI host-bus bridge with hot-pluggable slots > > > [ 247.386196] acpiphp_glue: found ACPI PCI Hotplug slot 2 at PCI 0000:06:01 > > > [ 247.386225] acpiphp: Slot [2] registered > > > [ 247.386828] acpiphp_glue: found PCI-to-PCI bridge at PCI 0000:0a:00.0 > > > [ 247.386861] acpiphp_glue: found ACPI PCI Hotplug slot 3 at PCI 0000:0b:00 > > > [ 247.386902] acpiphp: Slot [3] registered > > > [ 247.387564] acpiphp_glue: found PCI-to-PCI bridge at PCI 0000:0f:00.0 > > > [ 247.387597] acpiphp_glue: found ACPI PCI Hotplug slot 4 at PCI 0000:10:00 > > > [ 247.387620] acpiphp: Slot [4] registered > > > [ 247.388293] acpiphp_glue: found PCI-to-PCI bridge at PCI 0000:14:00.0 > > > [ 247.388324] acpiphp_glue: found ACPI PCI Hotplug slot 5 at PCI 0000:15:00 > > > [ 247.388347] acpiphp: Slot [5] registered > > > [ 247.389041] acpiphp_glue: found PCI-to-PCI bridge at PCI 0000:19:00.0 > > > [ 247.389077] acpiphp_glue: found ACPI PCI Hotplug slot 6 at PCI 0000:1a:00 > > > [ 247.389114] acpiphp: Slot [6] registered > > > [ 247.389736] acpiphp_glue: Bus 0000:1a has 1 slot > > > [ 247.389739] acpiphp_glue: Bus 0000:15 has 1 slot > > > [ 247.389742] acpiphp_glue: Bus 0000:10 has 1 slot > > > [ 247.389746] acpiphp_glue: Bus 0000:0b has 1 slot > > > [ 247.389748] acpiphp_glue: Bus 0000:06 has 1 slot > > > [ 247.389751] acpiphp_glue: Bus 0000:02 has 1 slot > > > [ 247.389753] acpiphp_glue: Total 6 slots > > > > > > However, I didn't have a chance to confirm that hot-add of a > > > PCI card works correctly before someone else swiped the system > > > from me for a while. I will verify this when I get it back, > > > hopefully later today. > > > > I got the system back but unfortunately have some bad news. > > The system has 2 hotpluggable PCI-X slots and 4 hotpluggable > > PCIe slots. I tried hot-adding both a PCI-X card and a PCIe > > card but acpiphp did not seem to see the hot-add event for > > either card. acpiphp was loaded with debug=1 and issued no > > messages when I added the cards. > > I gather it works without the $subject patch? Anyway, can you please try with the appended patch applied and see if "handle_bridge_insertion" appears in the log? There's one case we don't handle correctly at the moment and it may be the reason for the hotplug not working. Rafael --- drivers/pci/hotplug/acpiphp_glue.c | 2 ++ 1 file changed, 2 insertions(+) Index: linux-2.6/drivers/pci/hotplug/acpiphp_glue.c =================================================================== --- linux-2.6.orig/drivers/pci/hotplug/acpiphp_glue.c +++ linux-2.6/drivers/pci/hotplug/acpiphp_glue.c @@ -1065,6 +1065,8 @@ static void handle_bridge_insertion(acpi struct acpi_device *device, *pdevice; acpi_handle phandle; + warn("%s\n", __func__); + if ((type != ACPI_NOTIFY_BUS_CHECK) && (type != ACPI_NOTIFY_DEVICE_CHECK)) { err("unexpected notification type %d\n", type); -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/