drm/nouveau: Resume hotplug interrupts earlier
authorLyude Paul <lyude@redhat.com>
Mon, 30 Sep 2019 23:03:29 +0000 (19:03 -0400)
committerLyude Paul <lyude@redhat.com>
Thu, 24 Oct 2019 18:28:06 +0000 (14:28 -0400)
Currently, we enable hotplug detection only after we re-enable the
display. However, this is too late if we're planning on sending sideband
messages during the resume process - which we'll need to do in order to
reprobe the topology on resume.

So, enable hotplug events before reinitializing the display.

Cc: Juston Li <juston.li@intel.com>
Cc: Imre Deak <imre.deak@intel.com>
Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Cc: Harry Wentland <hwentlan@amd.com>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Reviewed-by: Sean Paul <sean@poorly.run>
Signed-off-by: Lyude Paul <lyude@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20191022023641.8026-11-lyude@redhat.com
drivers/gpu/drm/nouveau/nouveau_display.c

index 6f03851..53f9bce 100644 (file)
@@ -407,6 +407,17 @@ nouveau_display_init(struct drm_device *dev, bool resume, bool runtime)
        struct drm_connector_list_iter conn_iter;
        int ret;
 
+       /*
+        * Enable hotplug interrupts (done as early as possible, since we need
+        * them for MST)
+        */
+       drm_connector_list_iter_begin(dev, &conn_iter);
+       nouveau_for_each_non_mst_connector_iter(connector, &conn_iter) {
+               struct nouveau_connector *conn = nouveau_connector(connector);
+               nvif_notify_get(&conn->hpd);
+       }
+       drm_connector_list_iter_end(&conn_iter);
+
        ret = disp->init(dev, resume, runtime);
        if (ret)
                return ret;
@@ -416,14 +427,6 @@ nouveau_display_init(struct drm_device *dev, bool resume, bool runtime)
         */
        drm_kms_helper_poll_enable(dev);
 
-       /* enable hotplug interrupts */
-       drm_connector_list_iter_begin(dev, &conn_iter);
-       nouveau_for_each_non_mst_connector_iter(connector, &conn_iter) {
-               struct nouveau_connector *conn = nouveau_connector(connector);
-               nvif_notify_get(&conn->hpd);
-       }
-       drm_connector_list_iter_end(&conn_iter);
-
        return ret;
 }