]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
drm/nouveau: fix suspend/resume when in headless mode
authorBen Skeggs <bskeggs@redhat.com>
Thu, 1 Nov 2012 06:16:31 +0000 (16:16 +1000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 5 Nov 2012 08:56:52 +0000 (09:56 +0100)
Backport of fixes from upstream commit:
9430738d80223a1cd791a2baa74fa170d3df1262

Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/gpu/drm/nouveau/nouveau_drv.c

index 9a36f5f39b06447d5fce8ff6a17163eda7a41331..1fcc69a77f64276afc1570010e6dd2a8879afb06 100644 (file)
@@ -188,11 +188,13 @@ nouveau_pci_suspend(struct pci_dev *pdev, pm_message_t pm_state)
        if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
                return 0;
 
-       NV_INFO(dev, "Disabling display...\n");
-       nouveau_display_fini(dev);
+       if (dev->mode_config.num_crtc) {
+               NV_INFO(dev, "Disabling display...\n");
+               nouveau_display_fini(dev);
 
-       NV_INFO(dev, "Disabling fbcon...\n");
-       nouveau_fbcon_set_suspend(dev, 1);
+               NV_INFO(dev, "Disabling fbcon...\n");
+               nouveau_fbcon_set_suspend(dev, 1);
+       }
 
        NV_INFO(dev, "Unpinning framebuffer(s)...\n");
        list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {
@@ -359,10 +361,12 @@ nouveau_pci_resume(struct pci_dev *pdev)
                        NV_ERROR(dev, "Could not pin/map cursor.\n");
        }
 
-       nouveau_fbcon_set_suspend(dev, 0);
-       nouveau_fbcon_zfill_all(dev);
+       if (dev->mode_config.num_crtc) {
+               nouveau_fbcon_set_suspend(dev, 0);
+               nouveau_fbcon_zfill_all(dev);
 
-       nouveau_display_init(dev);
+               nouveau_display_init(dev);
+       }
 
        /* Force CLUT to get re-loaded during modeset */
        list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {