xen-devel.lists.xenproject.org archive mirror
 help / color / mirror / Atom feed
* [RFC PATCH] set current_state to D0 in register_slot
@ 2011-02-28 16:20 Stefano Stabellini
  2011-03-04 18:42 ` Jesse Barnes
  0 siblings, 1 reply; 13+ messages in thread
From: Stefano Stabellini @ 2011-02-28 16:20 UTC (permalink / raw)
  Cc: xen-devel, linux-pci, linux-kernel, jbarnes, Allen Kay

Hi all,
if a device doesn't support power management (pm_cap == 0) but it is
acpi_pci_power_manageable() because there is a _PS0 method declared for
it and _EJ0 is also declared for the slot then nobody is going to set
current_state = PCI_D0 for this device.  This is what I think it is
happening:


pci_enable_device
    |
__pci_enable_device_flags
/* here we do not set current_state because !pm_cap */
    |
do_pci_enable_device
    |
pci_set_power_state
    |
__pci_start_power_transition
    |
pci_platform_power_transition
/* platform_pci_power_manageable() calls acpi_pci_power_manageable that
 * returns true */
    |
platform_pci_set_power_state
/* acpi_pci_set_power_state gets called and does nothing because the
 * acpi device has _EJ0, see the comment "If the ACPI device has _EJ0,
 * ignore the device" */


at this point if we refer to the commit message that introduced the
comment above (10b3dcae0f275e2546e55303d64ddbb58cec7599), it is up to
the hotplug driver to set the state to D0.
However AFAICT the pci hotplug driver never does, in fact
drivers/pci/hotplug/acpiphp_glue.c:register_slot sets the slot flags to
(SLOT_ENABLED | SLOT_POWEREDON) but it does not set the pci device
current state to PCI_D0.

So my proposed fix is also to set current_state = PCI_D0 in
register_slot.
Comments are very welcome.


Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>

---

diff --git a/drivers/pci/hotplug/acpiphp_glue.c b/drivers/pci/hotplug/acpiphp_glue.c
index cb23aa2..e610cfe 100644
--- a/drivers/pci/hotplug/acpiphp_glue.c
+++ b/drivers/pci/hotplug/acpiphp_glue.c
@@ -212,6 +212,7 @@ register_slot(acpi_handle handle, u32 lvl, void *context, void **rv)
 
 	pdev = pci_get_slot(pbus, PCI_DEVFN(device, function));
 	if (pdev) {
+		pdev->current_state = PCI_D0;
 		slot->flags |= (SLOT_ENABLED | SLOT_POWEREDON);
 		pci_dev_put(pdev);
 	}

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

end of thread, other threads:[~2011-05-12  9:21 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-02-28 16:20 [RFC PATCH] set current_state to D0 in register_slot Stefano Stabellini
2011-03-04 18:42 ` Jesse Barnes
2011-03-07 15:01   ` Stefano Stabellini
2011-03-08 14:50   ` [Xen-devel] " Ian Campbell
2011-03-08 16:17     ` Ian Campbell
2011-03-16 12:34       ` Stefano Stabellini
2011-03-16 15:32         ` Jesse Barnes
2011-03-16 16:13           ` Stefano Stabellini
2011-05-11 13:33             ` Ian Campbell
2011-05-11 15:43               ` [Xen-devel] " Jesse Barnes
2011-05-11 16:00                 ` [PATCH] acpiphp: assume device is in state D0 after powering on a slot Ian Campbell
2011-05-11 16:14                   ` Jesse Barnes
2011-05-12  9:21                     ` Ian Campbell

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).