diff options
author | Dave Airlie <airlied@redhat.com> | 2008-02-19 19:02:20 -0500 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2008-02-19 19:05:12 -0500 |
commit | b932ccb5674eb649133b5c33950405c37d17aab3 (patch) | |
tree | 8ba30575cb83cc8d7d35517871b15657d1c1ab19 /drivers/char/drm/i915_drv.c | |
parent | da636ad6a0d72eb5cb99738056af0bcc3db9ef9d (diff) |
drm: add support for passing state into the suspend hooks.
fix i915 driver to use state for hibernate save avoidance.
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/char/drm/i915_drv.c')
-rw-r--r-- | drivers/char/drm/i915_drv.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/drivers/char/drm/i915_drv.c b/drivers/char/drm/i915_drv.c index 35758a6c8b0d..4048f39b7eed 100644 --- a/drivers/char/drm/i915_drv.c +++ b/drivers/char/drm/i915_drv.c | |||
@@ -238,7 +238,7 @@ static void i915_restore_vga(struct drm_device *dev) | |||
238 | 238 | ||
239 | } | 239 | } |
240 | 240 | ||
241 | static int i915_suspend(struct drm_device *dev) | 241 | static int i915_suspend(struct drm_device *dev, pm_message_t state) |
242 | { | 242 | { |
243 | struct drm_i915_private *dev_priv = dev->dev_private; | 243 | struct drm_i915_private *dev_priv = dev->dev_private; |
244 | int i; | 244 | int i; |
@@ -249,6 +249,9 @@ static int i915_suspend(struct drm_device *dev) | |||
249 | return -ENODEV; | 249 | return -ENODEV; |
250 | } | 250 | } |
251 | 251 | ||
252 | if (state.event == PM_EVENT_PRETHAW) | ||
253 | return 0; | ||
254 | |||
252 | pci_save_state(dev->pdev); | 255 | pci_save_state(dev->pdev); |
253 | pci_read_config_byte(dev->pdev, LBB, &dev_priv->saveLBB); | 256 | pci_read_config_byte(dev->pdev, LBB, &dev_priv->saveLBB); |
254 | 257 | ||
@@ -363,9 +366,11 @@ static int i915_suspend(struct drm_device *dev) | |||
363 | 366 | ||
364 | i915_save_vga(dev); | 367 | i915_save_vga(dev); |
365 | 368 | ||
366 | /* Shut down the device */ | 369 | if (state.event == PM_EVENT_SUSPEND) { |
367 | pci_disable_device(dev->pdev); | 370 | /* Shut down the device */ |
368 | pci_set_power_state(dev->pdev, PCI_D3hot); | 371 | pci_disable_device(dev->pdev); |
372 | pci_set_power_state(dev->pdev, PCI_D3hot); | ||
373 | } | ||
369 | 374 | ||
370 | return 0; | 375 | return 0; |
371 | } | 376 | } |