drm/scheduler: do not keep a copy of sched list
authorNirmoy Das <nirmoy.das@amd.com>
Mon, 9 Dec 2019 21:52:25 +0000 (22:52 +0100)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 18 Dec 2019 21:09:12 +0000 (16:09 -0500)
entity should not keep copy and maintain sched list for
itself.

Signed-off-by: Nirmoy Das <nirmoy.das@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/scheduler/sched_entity.c

index f9b6ce29c58f134479dfb67ac8f9e685208639e2..2e3a058fc2398b7a4414e1050986f42cd99956b4 100644 (file)
@@ -56,8 +56,6 @@ int drm_sched_entity_init(struct drm_sched_entity *entity,
                          unsigned int num_sched_list,
                          atomic_t *guilty)
 {
-       int i;
-
        if (!(entity && sched_list && (num_sched_list == 0 || sched_list[0])))
                return -EINVAL;
 
@@ -67,22 +65,14 @@ int drm_sched_entity_init(struct drm_sched_entity *entity,
        entity->guilty = guilty;
        entity->num_sched_list = num_sched_list;
        entity->priority = priority;
-       entity->sched_list =  kcalloc(num_sched_list,
-                                     sizeof(struct drm_gpu_scheduler *), GFP_KERNEL);
+       entity->sched_list = num_sched_list > 1 ? sched_list : NULL;
+       entity->last_scheduled = NULL;
 
-       if(!entity->sched_list)
-               return -ENOMEM;
+       if(num_sched_list)
+               entity->rq = &sched_list[0]->sched_rq[entity->priority];
 
        init_completion(&entity->entity_idle);
 
-       for (i = 0; i < num_sched_list; i++)
-               entity->sched_list[i] = sched_list[i];
-
-       if (num_sched_list)
-               entity->rq = &entity->sched_list[0]->sched_rq[entity->priority];
-
-       entity->last_scheduled = NULL;
-
        spin_lock_init(&entity->rq_lock);
        spsc_queue_init(&entity->job_queue);
 
@@ -312,7 +302,6 @@ void drm_sched_entity_fini(struct drm_sched_entity *entity)
 
        dma_fence_put(entity->last_scheduled);
        entity->last_scheduled = NULL;
-       kfree(entity->sched_list);
 }
 EXPORT_SYMBOL(drm_sched_entity_fini);