We need to call drm_helper_hpd_irq_event() on resume to properly detect
monitor connection / disconnection on some laptops, use hpd_work for
this to avoid deadlocks.

Signed-off-by: Hans de Goede <hdegoede at redhat.com>
---
 drivers/gpu/drm/nouveau/nouveau_drm.c | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/nouveau/nouveau_drm.c 
b/drivers/gpu/drm/nouveau/nouveau_drm.c
index 3100fd88..b564ab8 100644
--- a/drivers/gpu/drm/nouveau/nouveau_drm.c
+++ b/drivers/gpu/drm/nouveau/nouveau_drm.c
@@ -692,7 +692,12 @@ nouveau_pmops_resume(struct device *dev)
                return ret;
        pci_set_master(pdev);

-       return nouveau_do_resume(drm_dev, false);
+       ret = nouveau_do_resume(drm_dev, false);
+
+       /* Monitors may have been connected / disconnected during suspend */
+       schedule_work(&nouveau_drm(drm_dev)->hpd_work);
+
+       return ret;
 }

 static int
@@ -766,6 +771,10 @@ nouveau_pmops_runtime_resume(struct device *dev)
        nvif_mask(&device->object, 0x088488, (1 << 25), (1 << 25));
        vga_switcheroo_set_dynamic_switch(pdev, VGA_SWITCHEROO_ON);
        drm_dev->switch_power_state = DRM_SWITCH_POWER_ON;
+
+       /* Monitors may have been connected / disconnected during suspend */
+       schedule_work(&nouveau_drm(drm_dev)->hpd_work);
+
        return ret;
 }

-- 
2.9.3

Reply via email to