Currently, nouveau tries to go through the drm_dp_mst_port structures
itself in order to retrieve the relevant payload and VCPI information
that it needs to report to the GPU. This is wrong: mstc->port could be
destroyed at any point, and additionally the payload could be changed at
any point because it doesn't bother trying to grab the payload lock. So;
remove nv50_msto_payload entirely and use the new
drm_dp_get_payload_info() helper.

Signed-off-by: Lyude Paul <ly...@redhat.com>
---
 drivers/gpu/drm/nouveau/dispnv50/disp.c | 55 ++++++++++---------------
 1 file changed, 21 insertions(+), 34 deletions(-)

diff --git a/drivers/gpu/drm/nouveau/dispnv50/disp.c 
b/drivers/gpu/drm/nouveau/dispnv50/disp.c
index 6cbbae3f438b..e6f72ca0b1fa 100644
--- a/drivers/gpu/drm/nouveau/dispnv50/disp.c
+++ b/drivers/gpu/drm/nouveau/dispnv50/disp.c
@@ -665,41 +665,24 @@ struct nv50_msto {
        bool disabled;
 };
 
-static struct drm_dp_payload *
-nv50_msto_payload(struct nv50_msto *msto)
-{
-       struct nouveau_drm *drm = nouveau_drm(msto->encoder.dev);
-       struct nv50_mstc *mstc = msto->mstc;
-       struct nv50_mstm *mstm = mstc->mstm;
-       int vcpi = mstc->port->vcpi.vcpi, i;
-
-       NV_ATOMIC(drm, "%s: vcpi %d\n", msto->encoder.name, vcpi);
-       for (i = 0; i < mstm->mgr.max_payloads; i++) {
-               struct drm_dp_payload *payload = &mstm->mgr.payloads[i];
-               NV_ATOMIC(drm, "%s: %d: vcpi %d start 0x%02x slots 0x%02x\n",
-                         mstm->outp->base.base.name, i, payload->vcpi,
-                         payload->start_slot, payload->num_slots);
-       }
-
-       for (i = 0; i < mstm->mgr.max_payloads; i++) {
-               struct drm_dp_payload *payload = &mstm->mgr.payloads[i];
-               if (payload->vcpi == vcpi)
-                       return payload;
-       }
-
-       return NULL;
-}
-
 static void
 nv50_msto_cleanup(struct nv50_msto *msto)
 {
        struct nouveau_drm *drm = nouveau_drm(msto->encoder.dev);
        struct nv50_mstc *mstc = msto->mstc;
        struct nv50_mstm *mstm = mstc->mstm;
+       struct drm_dp_payload payload;
+       struct drm_dp_vcpi vcpi;
+       int ret;
 
        NV_ATOMIC(drm, "%s: msto cleanup\n", msto->encoder.name);
-       if (mstc->port && mstc->port->vcpi.vcpi > 0 && !nv50_msto_payload(msto))
-               drm_dp_mst_deallocate_vcpi(&mstm->mgr, mstc->port);
+       if (mstc->port) {
+               ret = drm_dp_get_payload_info(&mstm->mgr, mstc->port,
+                                             &vcpi, &payload);
+               if (!ret)
+                       drm_dp_mst_deallocate_vcpi(&mstm->mgr, mstc->port);
+       }
+
        if (msto->disabled) {
                msto->mstc = NULL;
                msto->head = NULL;
@@ -713,6 +696,9 @@ nv50_msto_prepare(struct nv50_msto *msto)
        struct nouveau_drm *drm = nouveau_drm(msto->encoder.dev);
        struct nv50_mstc *mstc = msto->mstc;
        struct nv50_mstm *mstm = mstc->mstm;
+       struct drm_dp_payload payload;
+       struct drm_dp_vcpi vcpi;
+       int ret;
        struct {
                struct nv50_disp_mthd_v1 base;
                struct nv50_disp_sor_dp_mst_vcpi_v0 vcpi;
@@ -725,13 +711,14 @@ nv50_msto_prepare(struct nv50_msto *msto)
        };
 
        NV_ATOMIC(drm, "%s: msto prepare\n", msto->encoder.name);
-       if (mstc->port && mstc->port->vcpi.vcpi > 0) {
-               struct drm_dp_payload *payload = nv50_msto_payload(msto);
-               if (payload) {
-                       args.vcpi.start_slot = payload->start_slot;
-                       args.vcpi.num_slots = payload->num_slots;
-                       args.vcpi.pbn = mstc->port->vcpi.pbn;
-                       args.vcpi.aligned_pbn = mstc->port->vcpi.aligned_pbn;
+       if (mstc->port) {
+               ret = drm_dp_get_payload_info(&mstm->mgr, mstc->port,
+                                             &vcpi, &payload);
+               if (!ret) {
+                       args.vcpi.start_slot = payload.start_slot;
+                       args.vcpi.num_slots = payload.num_slots;
+                       args.vcpi.pbn = vcpi.pbn;
+                       args.vcpi.aligned_pbn = vcpi.aligned_pbn;
                }
        }
 
-- 
2.19.1

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to