diff options
Diffstat (limited to 'meta-r1000/recipes-kernel/linux/linux-yocto-4.14.71/4562-drm-amdkcl-4.7-fix-__drm_atomic_helper_connector_des.patch')
-rw-r--r-- | meta-r1000/recipes-kernel/linux/linux-yocto-4.14.71/4562-drm-amdkcl-4.7-fix-__drm_atomic_helper_connector_des.patch | 434 |
1 files changed, 0 insertions, 434 deletions
diff --git a/meta-r1000/recipes-kernel/linux/linux-yocto-4.14.71/4562-drm-amdkcl-4.7-fix-__drm_atomic_helper_connector_des.patch b/meta-r1000/recipes-kernel/linux/linux-yocto-4.14.71/4562-drm-amdkcl-4.7-fix-__drm_atomic_helper_connector_des.patch deleted file mode 100644 index 224c2642..00000000 --- a/meta-r1000/recipes-kernel/linux/linux-yocto-4.14.71/4562-drm-amdkcl-4.7-fix-__drm_atomic_helper_connector_des.patch +++ /dev/null @@ -1,434 +0,0 @@ -From 5dc2ee59700d23d9a08413e762f6e8cd9db0ac89 Mon Sep 17 00:00:00 2001 -From: Kevin Wang <Kevin1.Wang@amd.com> -Date: Mon, 11 Jun 2018 10:34:48 +0800 -Subject: [PATCH 4562/5725] drm/amdkcl: [4.7] fix - __drm_atomic_helper_connector_destroy_state api changed - -Change-Id: Id6001c09ba5ead870bc8e4bbb37da1c99c8d73bc -Signed-off-by: Kevin Wang <Kevin1.Wang@amd.com> -Reviewed-by: Le Ma <Le.Ma@amd.com> -Signed-off-by: Kalyan Alle <kalyan.alle@amd.com> ---- - drivers/gpu/drm/scheduler/gpu_scheduler.c | 213 ++++++++++++++++++++++++------ - 1 file changed, 172 insertions(+), 41 deletions(-) - -diff --git a/drivers/gpu/drm/scheduler/gpu_scheduler.c b/drivers/gpu/drm/scheduler/gpu_scheduler.c -index be5d321..1edc323 100644 ---- a/drivers/gpu/drm/scheduler/gpu_scheduler.c -+++ b/drivers/gpu/drm/scheduler/gpu_scheduler.c -@@ -21,6 +21,29 @@ - * - */ - -+/** -+ * DOC: Overview -+ * -+ * The GPU scheduler provides entities which allow userspace to push jobs -+ * into software queues which are then scheduled on a hardware run queue. -+ * The software queues have a priority among them. The scheduler selects the entities -+ * from the run queue using a FIFO. The scheduler provides dependency handling -+ * features among jobs. The driver is supposed to provide callback functions for -+ * backend operations to the scheduler like submitting a job to hardware run queue, -+ * returning the dependencies of a job etc. -+ * -+ * The organisation of the scheduler is the following: -+ * -+ * 1. Each hw run queue has one scheduler -+ * 2. Each scheduler has multiple run queues with different priorities -+ * (e.g., HIGH_HW,HIGH_SW, KERNEL, NORMAL) -+ * 3. Each scheduler run queue has a queue of entities to schedule -+ * 4. Entities themselves maintain a queue of jobs that will be scheduled on -+ * the hardware. -+ * -+ * The jobs in a entity are always scheduled in the order that they were pushed. -+ */ -+ - #include <linux/kthread.h> - #include <linux/wait.h> - #include <linux/sched.h> -@@ -39,7 +62,13 @@ static bool drm_sched_entity_is_ready(struct drm_sched_entity *entity); - static void drm_sched_wakeup(struct drm_gpu_scheduler *sched); - static void drm_sched_process_job(struct dma_fence *f, struct dma_fence_cb *cb); - --/* Initialize a given run queue struct */ -+/** -+ * drm_sched_rq_init - initialize a given run queue struct -+ * -+ * @rq: scheduler run queue -+ * -+ * Initializes a scheduler runqueue. -+ */ - static void drm_sched_rq_init(struct drm_sched_rq *rq) - { - spin_lock_init(&rq->lock); -@@ -47,6 +76,14 @@ static void drm_sched_rq_init(struct drm_sched_rq *rq) - rq->current_entity = NULL; - } - -+/** -+ * drm_sched_rq_add_entity - add an entity -+ * -+ * @rq: scheduler run queue -+ * @entity: scheduler entity -+ * -+ * Adds a scheduler entity to the run queue. -+ */ - static void drm_sched_rq_add_entity(struct drm_sched_rq *rq, - struct drm_sched_entity *entity) - { -@@ -57,6 +94,14 @@ static void drm_sched_rq_add_entity(struct drm_sched_rq *rq, - spin_unlock(&rq->lock); - } - -+/** -+ * drm_sched_rq_remove_entity - remove an entity -+ * -+ * @rq: scheduler run queue -+ * @entity: scheduler entity -+ * -+ * Removes a scheduler entity from the run queue. -+ */ - static void drm_sched_rq_remove_entity(struct drm_sched_rq *rq, - struct drm_sched_entity *entity) - { -@@ -70,9 +115,9 @@ static void drm_sched_rq_remove_entity(struct drm_sched_rq *rq, - } - - /** -- * Select an entity which could provide a job to run -+ * drm_sched_rq_select_entity - Select an entity which could provide a job to run - * -- * @rq The run queue to check. -+ * @rq: scheduler run queue to check. - * - * Try to find a ready entity, returns NULL if none found. - */ -@@ -112,14 +157,16 @@ drm_sched_rq_select_entity(struct drm_sched_rq *rq) - } - - /** -- * Init a context entity used by scheduler when submit to HW ring. -+ * drm_sched_entity_init - Init a context entity used by scheduler when -+ * submit to HW ring. - * -- * @sched The pointer to the scheduler -- * @entity The pointer to a valid drm_sched_entity -- * @rq The run queue this entity belongs -- * @kernel If this is an entity for the kernel -+ * @sched: scheduler instance -+ * @entity: scheduler entity to init -+ * @rq: the run queue this entity belongs -+ * @guilty: atomic_t set to 1 when a job on this queue -+ * is found to be guilty causing a timeout - * -- * return 0 if succeed. negative error code on failure -+ * Returns 0 on success or a negative error code on failure. - */ - int drm_sched_entity_init(struct drm_gpu_scheduler *sched, - struct drm_sched_entity *entity, -@@ -148,10 +195,10 @@ int drm_sched_entity_init(struct drm_gpu_scheduler *sched, - EXPORT_SYMBOL(drm_sched_entity_init); - - /** -- * Query if entity is initialized -+ * drm_sched_entity_is_initialized - Query if entity is initialized - * -- * @sched Pointer to scheduler instance -- * @entity The pointer to a valid scheduler entity -+ * @sched: Pointer to scheduler instance -+ * @entity: The pointer to a valid scheduler entity - * - * return true if entity is initialized, false otherwise - */ -@@ -163,11 +210,11 @@ static bool drm_sched_entity_is_initialized(struct drm_gpu_scheduler *sched, - } - - /** -- * Check if entity is idle -+ * drm_sched_entity_is_idle - Check if entity is idle - * -- * @entity The pointer to a valid scheduler entity -+ * @entity: scheduler entity - * -- * Return true if entity don't has any unscheduled jobs. -+ * Returns true if the entity does not have any unscheduled jobs. - */ - static bool drm_sched_entity_is_idle(struct drm_sched_entity *entity) - { -@@ -179,9 +226,9 @@ static bool drm_sched_entity_is_idle(struct drm_sched_entity *entity) - } - - /** -- * Check if entity is ready -+ * drm_sched_entity_is_ready - Check if entity is ready - * -- * @entity The pointer to a valid scheduler entity -+ * @entity: scheduler entity - * - * Return true if entity could provide a job. - */ -@@ -209,12 +256,12 @@ static void drm_sched_entity_kill_jobs_cb(struct dma_fence *f, - - - /** -- * Destroy a context entity -+ * drm_sched_entity_do_release - Destroy a context entity - * -- * @sched Pointer to scheduler instance -- * @entity The pointer to a valid scheduler entity -+ * @sched: scheduler instance -+ * @entity: scheduler entity - * -- * Splitting drm_sched_entity_fini() into two functions, The first one is does the waiting, -+ * Splitting drm_sched_entity_fini() into two functions, The first one does the waiting, - * removes the entity from the runqueue and returns an error when the process was killed. - */ - void drm_sched_entity_do_release(struct drm_gpu_scheduler *sched, -@@ -236,12 +283,13 @@ void drm_sched_entity_do_release(struct drm_gpu_scheduler *sched, - EXPORT_SYMBOL(drm_sched_entity_do_release); - - /** -- * Destroy a context entity -+ * drm_sched_entity_cleanup - Destroy a context entity - * -- * @sched Pointer to scheduler instance -- * @entity The pointer to a valid scheduler entity -+ * @sched: scheduler instance -+ * @entity: scheduler entity - * -- * The second one then goes over the entity and signals all jobs with an error code. -+ * This should be called after @drm_sched_entity_do_release. It goes over the -+ * entity and signals all jobs with an error code if the process was killed. - */ - void drm_sched_entity_cleanup(struct drm_gpu_scheduler *sched, - struct drm_sched_entity *entity) -@@ -280,6 +328,14 @@ void drm_sched_entity_cleanup(struct drm_gpu_scheduler *sched, - } - EXPORT_SYMBOL(drm_sched_entity_cleanup); - -+/** -+ * drm_sched_entity_fini - Destroy a context entity -+ * -+ * @sched: scheduler instance -+ * @entity: scheduler entity -+ * -+ * Calls drm_sched_entity_do_release() and drm_sched_entity_cleanup() -+ */ - void drm_sched_entity_fini(struct drm_gpu_scheduler *sched, - struct drm_sched_entity *entity) - { -@@ -305,6 +361,15 @@ static void drm_sched_entity_clear_dep(struct dma_fence *f, struct dma_fence_cb - dma_fence_put(f); - } - -+/** -+ * drm_sched_entity_set_rq - Sets the run queue for an entity -+ * -+ * @entity: scheduler entity -+ * @rq: scheduler run queue -+ * -+ * Sets the run queue for an entity and removes the entity from the previous -+ * run queue in which was present. -+ */ - void drm_sched_entity_set_rq(struct drm_sched_entity *entity, - struct drm_sched_rq *rq) - { -@@ -324,6 +389,14 @@ void drm_sched_entity_set_rq(struct drm_sched_entity *entity, - } - EXPORT_SYMBOL(drm_sched_entity_set_rq); - -+/** -+ * drm_sched_dependency_optimized -+ * -+ * @fence: the dependency fence -+ * @entity: the entity which depends on the above fence -+ * -+ * Returns true if the dependency can be optimized and false otherwise -+ */ - bool drm_sched_dependency_optimized(struct dma_fence* fence, - struct drm_sched_entity *entity) - { -@@ -407,9 +480,10 @@ drm_sched_entity_pop_job(struct drm_sched_entity *entity) - } - - /** -- * Submit a job to the job queue -+ * drm_sched_entity_push_job - Submit a job to the entity's job queue - * -- * @sched_job The pointer to job required to submit -+ * @sched_job: job to submit -+ * @entity: scheduler entity - * - * Note: To guarantee that the order of insertion to queue matches - * the job's fence sequence number this function should be -@@ -500,6 +574,13 @@ static void drm_sched_job_timedout(struct work_struct *work) - job->sched->ops->timedout_job(job); - } - -+/** -+ * drm_sched_hw_job_reset - stop the scheduler if it contains the bad job -+ * -+ * @sched: scheduler instance -+ * @bad: bad scheduler job -+ * -+ */ - void drm_sched_hw_job_reset(struct drm_gpu_scheduler *sched, struct drm_sched_job *bad) - { - struct drm_sched_job *s_job; -@@ -544,6 +625,12 @@ void drm_sched_hw_job_reset(struct drm_gpu_scheduler *sched, struct drm_sched_jo - } - EXPORT_SYMBOL(drm_sched_hw_job_reset); - -+/** -+ * drm_sched_job_recovery - recover jobs after a reset -+ * -+ * @sched: scheduler instance -+ * -+ */ - void drm_sched_job_recovery(struct drm_gpu_scheduler *sched) - { - struct drm_sched_job *s_job, *tmp; -@@ -593,10 +680,17 @@ void drm_sched_job_recovery(struct drm_gpu_scheduler *sched) - EXPORT_SYMBOL(drm_sched_job_recovery); - - /** -- * Init a sched_job with basic field -+ * drm_sched_job_init - init a scheduler job - * -- * Note: Refer to drm_sched_entity_push_job documentation -+ * @job: scheduler job to init -+ * @sched: scheduler instance -+ * @entity: scheduler entity to use -+ * @owner: job owner for debugging -+ * -+ * Refer to drm_sched_entity_push_job() documentation - * for locking considerations. -+ * -+ * Returns 0 for success, negative error code otherwise. - */ - int drm_sched_job_init(struct drm_sched_job *job, - struct drm_gpu_scheduler *sched, -@@ -620,7 +714,11 @@ int drm_sched_job_init(struct drm_sched_job *job, - EXPORT_SYMBOL(drm_sched_job_init); - - /** -- * Return ture if we can push more jobs to the hw. -+ * drm_sched_ready - is the scheduler ready -+ * -+ * @sched: scheduler instance -+ * -+ * Return true if we can push more jobs to the hw, otherwise false. - */ - static bool drm_sched_ready(struct drm_gpu_scheduler *sched) - { -@@ -629,7 +727,10 @@ static bool drm_sched_ready(struct drm_gpu_scheduler *sched) - } - - /** -- * Wake up the scheduler when it is ready -+ * drm_sched_wakeup - Wake up the scheduler when it is ready -+ * -+ * @sched: scheduler instance -+ * - */ - static void drm_sched_wakeup(struct drm_gpu_scheduler *sched) - { -@@ -638,8 +739,12 @@ static void drm_sched_wakeup(struct drm_gpu_scheduler *sched) - } - - /** -- * Select next entity to process --*/ -+ * drm_sched_select_entity - Select next entity to process -+ * -+ * @sched: scheduler instance -+ * -+ * Returns the entity to process or NULL if none are found. -+ */ - static struct drm_sched_entity * - drm_sched_select_entity(struct drm_gpu_scheduler *sched) - { -@@ -659,6 +764,14 @@ drm_sched_select_entity(struct drm_gpu_scheduler *sched) - return entity; - } - -+/** -+ * drm_sched_process_job - process a job -+ * -+ * @f: fence -+ * @cb: fence callbacks -+ * -+ * Called after job has finished execution. -+ */ - static void drm_sched_process_job(struct dma_fence *f, struct dma_fence_cb *cb) - { - struct drm_sched_fence *s_fence = -@@ -674,6 +787,13 @@ static void drm_sched_process_job(struct dma_fence *f, struct dma_fence_cb *cb) - wake_up_interruptible(&sched->wake_up_worker); - } - -+/** -+ * drm_sched_blocked - check if the scheduler is blocked -+ * -+ * @sched: scheduler instance -+ * -+ * Returns true if blocked, otherwise false. -+*/ - static bool drm_sched_blocked(struct drm_gpu_scheduler *sched) - { - if (kthread_should_park()) { -@@ -684,6 +804,13 @@ static bool drm_sched_blocked(struct drm_gpu_scheduler *sched) - return false; - } - -+/** -+ * drm_sched_main - main scheduler thread -+ * -+ * @param: scheduler instance -+ * -+ * Returns 0. -+ */ - static int drm_sched_main(void *param) - { - struct sched_param sparam = {.sched_priority = 1}; -@@ -738,15 +865,17 @@ static int drm_sched_main(void *param) - } - - /** -- * Init a gpu scheduler instance -+ * drm_sched_init - Init a gpu scheduler instance - * -- * @sched The pointer to the scheduler -- * @ops The backend operations for this scheduler. -- * @hw_submissions Number of hw submissions to do. -- * @name Name used for debugging -+ * @sched: scheduler instance -+ * @ops: backend operations for this scheduler -+ * @hw_submission: number of hw submissions that can be in flight -+ * @hang_limit: number of times to allow a job to hang before dropping it -+ * @timeout: timeout value in jiffies for the scheduler -+ * @name: name used for debugging - * - * Return 0 on success, otherwise error code. --*/ -+ */ - int drm_sched_init(struct drm_gpu_scheduler *sched, - const struct drm_sched_backend_ops *ops, - unsigned hw_submission, -@@ -782,9 +911,11 @@ int drm_sched_init(struct drm_gpu_scheduler *sched, - EXPORT_SYMBOL(drm_sched_init); - - /** -- * Destroy a gpu scheduler -+ * drm_sched_fini - Destroy a gpu scheduler -+ * -+ * @sched: scheduler instance - * -- * @sched The pointer to the scheduler -+ * Tears down and cleans up the scheduler. - */ - void drm_sched_fini(struct drm_gpu_scheduler *sched) - { --- -2.7.4 - |