diff options
| author | Alex Deucher <alexdeucher@gmail.com> | 2010-06-02 12:08:41 -0400 |
|---|---|---|
| committer | Dave Airlie <airlied@redhat.com> | 2010-06-02 23:13:37 -0400 |
| commit | d8dcaa1dc50f5aecd38d34180cd99d6af8566c88 (patch) | |
| tree | 8a5873a428310454998c1c0162d520ee873c0bdf | |
| parent | d8bd19d2aff95e52c7f356cc2fc722584a656065 (diff) | |
drm/radeon/kms: make sure display hw is disabled when suspending
Disable the display hw when suspending.
Should fix bug:
https://bugzilla.redhat.com/show_bug.cgi?id=522393
Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
| -rw-r--r-- | drivers/gpu/drm/radeon/radeon_device.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_device.c b/drivers/gpu/drm/radeon/radeon_device.c index db338522191f..f10faed21567 100644 --- a/drivers/gpu/drm/radeon/radeon_device.c +++ b/drivers/gpu/drm/radeon/radeon_device.c | |||
| @@ -713,6 +713,7 @@ int radeon_suspend_kms(struct drm_device *dev, pm_message_t state) | |||
| 713 | { | 713 | { |
| 714 | struct radeon_device *rdev; | 714 | struct radeon_device *rdev; |
| 715 | struct drm_crtc *crtc; | 715 | struct drm_crtc *crtc; |
| 716 | struct drm_connector *connector; | ||
| 716 | int r; | 717 | int r; |
| 717 | 718 | ||
| 718 | if (dev == NULL || dev->dev_private == NULL) { | 719 | if (dev == NULL || dev->dev_private == NULL) { |
| @@ -725,6 +726,12 @@ int radeon_suspend_kms(struct drm_device *dev, pm_message_t state) | |||
| 725 | 726 | ||
| 726 | if (rdev->powered_down) | 727 | if (rdev->powered_down) |
| 727 | return 0; | 728 | return 0; |
| 729 | |||
| 730 | /* turn off display hw */ | ||
| 731 | list_for_each_entry(connector, &dev->mode_config.connector_list, head) { | ||
| 732 | drm_helper_connector_dpms(connector, DRM_MODE_DPMS_OFF); | ||
| 733 | } | ||
| 734 | |||
| 728 | /* unpin the front buffers */ | 735 | /* unpin the front buffers */ |
| 729 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { | 736 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { |
| 730 | struct radeon_framebuffer *rfb = to_radeon_framebuffer(crtc->fb); | 737 | struct radeon_framebuffer *rfb = to_radeon_framebuffer(crtc->fb); |
