From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Rafael J. Wysocki" Subject: Re: [RFC PATCH] PCIe: Add PCIe runtime D3cold support Date: Mon, 16 Apr 2012 23:11:37 +0200 Message-ID: <201204162311.37499.rjw@sisk.pl> References: <4F8790F6.5080408@intel.com> <201204132141.58063.rjw@sisk.pl> <4F8BCF00.3020004@intel.com> Mime-Version: 1.0 Content-Type: Text/Plain; charset="windows-1252" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <4F8BCF00.3020004@intel.com> Sender: linux-pci-owner@vger.kernel.org To: "Yan, Zheng" Cc: bhelgaas@google.com, linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org, linux-pm@vger.kernel.org, Lin Ming , Zhang Rui , huang ying , ACPI Devel Mailing List List-Id: linux-acpi@vger.kernel.org On Monday, April 16, 2012, Yan, Zheng wrote: > On 04/14/2012 03:41 AM, Rafael J. Wysocki wrote: > >> > @@ -296,7 +296,8 @@ static void acpi_pci_propagate_run_wake(struct pci_bus *bus, bool enable) > >> > > >> > static int acpi_pci_run_wake(struct pci_dev *dev, bool enable) > >> > { > >> > - if (dev->pme_interrupt) > >> > + /* PME interrupt isn't available in the D3cold case */ > >> > + if (dev->pme_interrupt && !dev->runtime_d3cold) > > > > This whole thing is wrong. First off, I don't think that the runtime_d3cold > > flag makes any sense. We already cover that in dev->pme_support. > > > > Second, pme_interrupt means that the _root_ _port_, not the device itself will > > trigger an interrupt whenever the device sends the PME message to it (which > > very well may happen for a device in D3_cold woken up by an external signal). > > > > I rechecked this. The port does trigger PME interrupt, but after the WAKE# signal > restores device power. So my comments "PME interrupt isn't available in the D3cold > case" is wrong, but setup ACPI wakeup is still required. What exactly do you mean by "setup ACPI wakeup"? Rafael