1. 07 5月, 2010 1 次提交
  2. 06 5月, 2010 1 次提交
  3. 09 3月, 2010 1 次提交
  4. 23 2月, 2010 1 次提交
    • R
      ACPI: Use GPE reference counting to support shared GPEs · 9630bdd9
      Rafael J. Wysocki 提交于
      ACPI GPEs may map to multiple devices.  The current GPE interface
      only provides a mechanism for enabling and disabling GPEs, making
      it difficult to change the state of GPEs at runtime without extensive
      cooperation between devices.
      
      Add an API to allow devices to indicate whether or not they want
      their device's GPE to be enabled for both runtime and wakeup events.
      
      Remove the old GPE type handling entirely, which gets rid of various
      quirks, like the implicit disabling with GPE type setting. This
      requires a small amount of rework in order to ensure that non-wake
      GPEs are enabled by default to preserve existing behaviour.
      
      Based on patches from Matthew Garrett <mjg@redhat.com>.
      Signed-off-by: NMatthew Garrett <mjg@redhat.com>
      Signed-off-by: NRafael J. Wysocki <rjw@sisk.pl>
      Signed-off-by: NJesse Barnes <jbarnes@virtuousgeek.org>
      9630bdd9
  5. 31 12月, 2009 1 次提交
  6. 24 11月, 2009 1 次提交
  7. 06 11月, 2009 2 次提交
  8. 10 9月, 2009 2 次提交
  9. 30 8月, 2009 1 次提交
  10. 30 7月, 2009 1 次提交
  11. 20 4月, 2009 1 次提交
    • R
      PM/Suspend: Introduce two new platform callbacks to avoid breakage · 6a7c7eaf
      Rafael J. Wysocki 提交于
      Commit 900af0d9 (PM: Change suspend
      code ordering) changed the ordering of suspend code in such a way
      that the platform .prepare() callback is now executed after the
      device drivers' late suspend callbacks have run.  Unfortunately, this
      turns out to break ARM platforms that need to talk via I2C to power
      control devices during the .prepare() callback.
      
      For this reason introduce two new platform suspend callbacks,
      .prepare_late() and .wake(), that will be called just prior to
      disabling non-boot CPUs and right after bringing them back on line,
      respectively, and use them instead of .prepare() and .finish() for
      ACPI suspend.  Make the PM core execute the .prepare() and .finish()
      platform suspend callbacks where they were executed previously (that
      is, right after calling the regular suspend methods provided by
      device drivers and right before executing their regular resume
      methods, respectively).
      
      It is not necessary to make analogous changes to the hibernation
      code and data structures at the moment, because they are only used
      by ACPI platforms.
      Signed-off-by: NRafael J. Wysocki <rjw@sisk.pl>
      Reported-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      Acked-by: NLen Brown <len.brown@intel.com>
      6a7c7eaf
  12. 18 4月, 2009 1 次提交
  13. 04 4月, 2009 1 次提交
  14. 27 3月, 2009 1 次提交
  15. 17 3月, 2009 1 次提交
  16. 16 3月, 2009 2 次提交
  17. 07 2月, 2009 1 次提交
  18. 17 1月, 2009 2 次提交
  19. 09 1月, 2009 1 次提交
  20. 31 12月, 2008 1 次提交
  21. 19 12月, 2008 2 次提交
  22. 27 11月, 2008 1 次提交
  23. 25 10月, 2008 1 次提交
  24. 23 10月, 2008 2 次提交
    • L
      ACPI suspend: fix build warning when CONFIG_ACPI_SLEEP=n · b849075c
      Len Brown 提交于
      drivers/acpi/sleep/main.c:27: warning: ‘acpi_target_sleep_state’ defined but not used
      Signed-off-by: NLen Brown <len.brown@intel.com>
      b849075c
    • R
      ACPI suspend: Fix CONFIG_ACPI_SLEEP dependence and some compilation warnings · 5d1e072b
      Rafael J. Wysocki 提交于
      Initially CONFIG_PM_SLEEP was defined as
      CONFIG_SUSPEND || CONFIG_HIBERNATION and some ACPI code, most
      importantly the code in drivers/acpi/main.c, was written with this
      assumption.  Currently, however, CONFIG_PM_SLEEP is also set when
      CONFIG_XEN_SAVE_RESTORE is set.
      
      This causes some compilation warnings to appear in
      drivers/acpi/main.c if both CONFIG_SUSPEND and CONFIG_HIBERNATION
      are unset and CONFIG_PM_SLEEP is set (this was impossible before).
      To fix this problem, redefine CONFIG_ACPI_SLEEP do depend directly
      on CONFIG_SUSPEND || CONFIG_HIBERNATION, as originally intended, and
      use it instead of CONFIG_PM_SLEEP in drivers/acpi/main.c, wherever
      appropriate.
      
      Additionally, move the acpi_target_sleep_state definition from under
      the #ifdef to prevent compilation from failing in some cases.
      Signed-off-by: NRafael J. Wysocki <rjw@sisk.pl>
      Signed-off-by: NLen Brown <len.brown@intel.com>
      5d1e072b
  25. 17 10月, 2008 3 次提交
    • R
      ACPI suspend: Blacklist HP xw4600 Workstation for old code ordering · 4fb507b6
      Rafael J. Wysocki 提交于
      HP xw4600 Workstation is known to require the "old" (ie. compatible
      with ACPI 1.0) suspend code ordering, so blacklist it for this
      purpose.
      Signed-off-by: NRafael J. Wysocki <rjw@sisk.pl>
      Tested-by: NJohn Brown <john.brown3@hp.com>
      Signed-off-by: NLen Brown <len.brown@intel.com>
      4fb507b6
    • R
      ACPI Suspend: Enable ACPI during resume if SCI_EN is not set · d0c71fe7
      Rafael J. Wysocki 提交于
      On some machines, like for example MSI Wind U100, the BIOS doesn't
      enable ACPI before returning control to the OS, which sometimes
      causes resume to fail.  This is against the ACPI specification,
      which clearly states that "When the platform is waking from an S1, S2
      or S3 state, OSPM assumes the hardware is already in the ACPI mode
      and will not issue an ACPI_ENABLE", but it won't hurt to check the
      SCI_EN bit and enable ACPI during resume from S3 if this bit is not
      set.
      
      Fortunately, we already have acpi_enable() for that, so use it in the
      resume code path, before executing _BFS, in analogy with the
      resume-from-hibernation code path.
      
      NOTE: We aren't supposed to set SCI_EN directly, because it's owned
      by the hardware.
      Signed-off-by: NRafael J. Wysocki <rjw@sisk.pl>
      Pavel Machek <pavel@suse.cz>
      Signed-off-by: NLen Brown <len.brown@intel.com>
      d0c71fe7
    • Z
      ACPI: Add the support for _TTS object · e49f711c
      Zhao Yakui 提交于
          The _TTS object is defined in the section 7.3 of acpi 3.0b spec.
          The _TTS control method is executed by the OSPM at the beginning of
      the sleep transition process for S1,S2, S3, S4, and orderly S5 shutdown.
      OS will invoke _TTS before it has notified any native mode device drivers
      of the sleep state transition. The target sleeping state value is passed to
      the _TTS control method.
      
          The _TTS control method is also executed by the OSPM at the end of
      any sleep transition process when the system transitions to S0 from
      S1, S2, S3, or S4. The _TTS object should be evaluated after it has
      notified any native mode device drivers of the end of the sleep state
      transition. The working state value (0) is passed to the _TTS control method.
      
          So it is necessary to add the support for _TTS object. The _TTS object
      will be evaluated if it exists.
          At the same time a block notifier is added to the reboot notifier list so
      that the _TTS object will also be evaluated when the system shutdown.
      
      lenb: note that as of Sep 2008, I've not yet seen _TTS in any shipping BIOS.
      So this patch is to future-proof Linux, rather than fix the installed base.
      
      http://bugzilla.kernel.org/show_bug.cgi?id=11132Signed-off-by: NZhao Yakui <yakui.zhao@intel.com>
      Signed-off-by: NLi Shaohua <shaohua.li@intel.com>
      Signed-off-by: NAndi Kleen <ak@linux.intel.com>
      Signed-off-by: NLen Brown <len.brown@intel.com>
      e49f711c
  26. 11 10月, 2008 1 次提交
  27. 25 7月, 2008 2 次提交
  28. 17 7月, 2008 2 次提交
  29. 08 7月, 2008 1 次提交
    • R
      PCI ACPI: Rework PCI handling of wake-up · eb9d0fe4
      Rafael J. Wysocki 提交于
      * Introduce function acpi_pm_device_sleep_wake() for enabling and
        disabling the system wake-up capability of devices that are power
        manageable by ACPI.
      
      * Introduce function acpi_bus_can_wakeup() allowing other (dependent)
        subsystems to check if ACPI is able to enable the system wake-up
        capability of given device.
      
      * Introduce callback .sleep_wake() in struct pci_platform_pm_ops and
        for the ACPI PCI 'driver' make it use acpi_pm_device_sleep_wake().
      
      * Introduce callback .can_wakeup() in struct pci_platform_pm_ops and
        for the ACPI 'driver' make it use acpi_bus_can_wakeup().
      
      * Move the PME# handlig code out of pci_enable_wake() and split it
        into two functions, pci_pme_capable() and pci_pme_active(),
        allowing the caller to check if given device is capable of
        generating PME# from given power state and to enable/disable the
        device's PME# functionality, respectively.
      
      * Modify pci_enable_wake() to use the new ACPI callbacks and the new
        PME#-related functions.
      
      * Drop the generic .platform_enable_wakeup() callback that is not
        used any more.
      
      * Introduce device_set_wakeup_capable() that will set the
        power.can_wakeup flag of given device.
      
      * Rework PCI device PM initialization so that, if given device is
        capable of generating wake-up events, either natively through the
        PME# mechanism, or with the help of the platform, its
        power.can_wakeup flag is set and its power.should_wakeup flag is
        unset as appropriate.
      
      * Make ACPI set the power.can_wakeup flag for devices found to be
        wake-up capable by it.
      
      * Make the ACPI wake-up code enable/disable GPEs for devices that
        have the wakeup.flags.prepared flag set (which means that their
        wake-up power has been enabled).
      Signed-off-by: NRafael J. Wysocki <rjw@sisk.pl>
      Signed-off-by: NJesse Barnes <jbarnes@virtuousgeek.org>
      eb9d0fe4
  30. 05 7月, 2008 1 次提交