Since there are no clients using these threads,
cleaning it up.

changes in v2:
        - switch all the dependent clients to use system wq
          before removing the disp_threads (Sean Paul)
changes in v3:
        - none
changes in v4:
        - none
changes in v5:
        - Rebase on latest tip with [1] (Sean Paul)

[1] https://patchwork.freedesktop.org/patch/255105/

Signed-off-by: Jeykumar Sankaran <jsa...@codeaurora.org>
---
 drivers/gpu/drm/msm/msm_drv.c | 43 ++-----------------------------------------
 drivers/gpu/drm/msm/msm_drv.h |  1 -
 2 files changed, 2 insertions(+), 42 deletions(-)

diff --git a/drivers/gpu/drm/msm/msm_drv.c b/drivers/gpu/drm/msm/msm_drv.c
index c61ce06..f7cb2c7 100644
--- a/drivers/gpu/drm/msm/msm_drv.c
+++ b/drivers/gpu/drm/msm/msm_drv.c
@@ -287,13 +287,8 @@ static int msm_drm_uninit(struct device *dev)
                kfree(vbl_ev);
        }
 
-       /* clean up display commit/event worker threads */
+       /* clean up event worker threads */
        for (i = 0; i < priv->num_crtcs; i++) {
-               if (priv->disp_thread[i].thread) {
-                       kthread_destroy_worker(&priv->disp_thread[i].worker);
-                       priv->disp_thread[i].thread = NULL;
-               }
-
                if (priv->event_thread[i].thread) {
                        kthread_destroy_worker(&priv->event_thread[i].worker);
                        priv->event_thread[i].thread = NULL;
@@ -551,26 +546,6 @@ static int msm_drm_init(struct device *dev, struct 
drm_driver *drv)
         */
        param.sched_priority = 16;
        for (i = 0; i < priv->num_crtcs; i++) {
-
-               /* initialize display thread */
-               priv->disp_thread[i].crtc_id = priv->crtcs[i]->base.id;
-               kthread_init_worker(&priv->disp_thread[i].worker);
-               priv->disp_thread[i].dev = ddev;
-               priv->disp_thread[i].thread =
-                       kthread_run(kthread_worker_fn,
-                               &priv->disp_thread[i].worker,
-                               "crtc_commit:%d", priv->disp_thread[i].crtc_id);
-               ret = sched_setscheduler(priv->disp_thread[i].thread,
-                                                       SCHED_FIFO, &param);
-               if (ret)
-                       pr_warn("display thread priority update failed: %d\n",
-                                                                       ret);
-
-               if (IS_ERR(priv->disp_thread[i].thread)) {
-                       DRM_DEV_ERROR(dev, "failed to create crtc_commit 
kthread\n");
-                       priv->disp_thread[i].thread = NULL;
-               }
-
                /* initialize event thread */
                priv->event_thread[i].crtc_id = priv->crtcs[i]->base.id;
                kthread_init_worker(&priv->event_thread[i].worker);
@@ -580,13 +555,6 @@ static int msm_drm_init(struct device *dev, struct 
drm_driver *drv)
                                &priv->event_thread[i].worker,
                                "crtc_event:%d", priv->event_thread[i].crtc_id);
 
-               /**
-                * event thread should also run at same priority as disp_thread
-                * because it is handling frame_done events. A lower priority
-                * event thread and higher priority disp_thread can causes
-                * frame_pending counters beyond 2. This can lead to commit
-                * failure at crtc commit level.
-                */
                ret = sched_setscheduler(priv->event_thread[i].thread,
                                                        SCHED_FIFO, &param);
                if (ret)
@@ -598,16 +566,9 @@ static int msm_drm_init(struct device *dev, struct 
drm_driver *drv)
                        priv->event_thread[i].thread = NULL;
                }
 
-               if ((!priv->disp_thread[i].thread) ||
-                               !priv->event_thread[i].thread) {
+               if (!priv->event_thread[i].thread) {
                        /* clean up previously created threads if any */
                        for ( ; i >= 0; i--) {
-                               if (priv->disp_thread[i].thread) {
-                                       kthread_stop(
-                                               priv->disp_thread[i].thread);
-                                       priv->disp_thread[i].thread = NULL;
-                               }
-
                                if (priv->event_thread[i].thread) {
                                        kthread_stop(
                                                priv->event_thread[i].thread);
diff --git a/drivers/gpu/drm/msm/msm_drv.h b/drivers/gpu/drm/msm/msm_drv.h
index 8fad151..2a30fc4 100644
--- a/drivers/gpu/drm/msm/msm_drv.h
+++ b/drivers/gpu/drm/msm/msm_drv.h
@@ -199,7 +199,6 @@ struct msm_drm_private {
        unsigned int num_crtcs;
        struct drm_crtc *crtcs[MAX_CRTCS];
 
-       struct msm_drm_thread disp_thread[MAX_CRTCS];
        struct msm_drm_thread event_thread[MAX_CRTCS];
 
        unsigned int num_encoders;
-- 
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
a Linux Foundation Collaborative Project

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to