diff options
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3354-drm-amdkfd-Pass-filter-params-to-unmap_queues_cpsch.patch')
-rw-r--r-- | meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3354-drm-amdkfd-Pass-filter-params-to-unmap_queues_cpsch.patch | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3354-drm-amdkfd-Pass-filter-params-to-unmap_queues_cpsch.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3354-drm-amdkfd-Pass-filter-params-to-unmap_queues_cpsch.patch new file mode 100644 index 00000000..3e405b75 --- /dev/null +++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3354-drm-amdkfd-Pass-filter-params-to-unmap_queues_cpsch.patch @@ -0,0 +1,86 @@ +From e22a6cfcbbabe8af8c96727ac822f0d9e5c6915b Mon Sep 17 00:00:00 2001 +From: Yong Zhao <yong.zhao@amd.com> +Date: Sun, 8 Oct 2017 14:57:52 +0300 +Subject: [PATCH 3354/4131] drm/amdkfd: Pass filter params to + unmap_queues_cpsch + +Signed-off-by: Yong Zhao <yong.zhao@amd.com> +Signed-off-by: Felix Kuehling <Felix.Kuehling@amd.com> +Reviewed-by: Oded Gabbay <oded.gabbay@gmail.com> +Signed-off-by: Oded Gabbay <oded.gabbay@gmail.com> +--- + .../gpu/drm/amd/amdkfd/kfd_device_queue_manager.c | 20 +++++++++----------- + 1 file changed, 9 insertions(+), 11 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c b/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c +index 0f9c39b..be925a4 100644 +--- a/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c ++++ b/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c +@@ -46,7 +46,8 @@ static int create_compute_queue_nocpsch(struct device_queue_manager *dqm, + + static int execute_queues_cpsch(struct device_queue_manager *dqm); + static int unmap_queues_cpsch(struct device_queue_manager *dqm, +- bool static_queues_included); ++ enum kfd_unmap_queues_filter filter, ++ uint32_t filter_param); + + static int create_sdma_queue_nocpsch(struct device_queue_manager *dqm, + struct queue *q, +@@ -710,7 +711,7 @@ static int start_cpsch(struct device_queue_manager *dqm) + static int stop_cpsch(struct device_queue_manager *dqm) + { + mutex_lock(&dqm->lock); +- unmap_queues_cpsch(dqm, true); ++ unmap_queues_cpsch(dqm, KFD_UNMAP_QUEUES_FILTER_ALL_QUEUES, 0); + mutex_unlock(&dqm->lock); + + kfd_gtt_sa_free(dqm->dev, dqm->fence_mem); +@@ -754,7 +755,7 @@ static void destroy_kernel_queue_cpsch(struct device_queue_manager *dqm, + { + mutex_lock(&dqm->lock); + /* here we actually preempt the DIQ */ +- unmap_queues_cpsch(dqm, true); ++ unmap_queues_cpsch(dqm, KFD_UNMAP_QUEUES_FILTER_ALL_QUEUES, 0); + list_del(&kq->list); + dqm->queue_count--; + qpd->is_debug = false; +@@ -863,10 +864,10 @@ static int unmap_sdma_queues(struct device_queue_manager *dqm, + + /* dqm->lock mutex has to be locked before calling this function */ + static int unmap_queues_cpsch(struct device_queue_manager *dqm, +- bool static_queues_included) ++ enum kfd_unmap_queues_filter filter, ++ uint32_t filter_param) + { + int retval; +- enum kfd_unmap_queues_filter filter; + struct kfd_process_device *pdd; + + retval = 0; +@@ -882,12 +883,8 @@ static int unmap_queues_cpsch(struct device_queue_manager *dqm, + unmap_sdma_queues(dqm, 1); + } + +- filter = static_queues_included ? +- KFD_UNMAP_QUEUES_FILTER_ALL_QUEUES : +- KFD_UNMAP_QUEUES_FILTER_DYNAMIC_QUEUES; +- + retval = pm_send_unmap_queue(&dqm->packets, KFD_QUEUE_TYPE_COMPUTE, +- filter, 0, false, 0); ++ filter, filter_param, false, 0); + if (retval) + return retval; + +@@ -914,7 +911,8 @@ static int execute_queues_cpsch(struct device_queue_manager *dqm) + { + int retval; + +- retval = unmap_queues_cpsch(dqm, false); ++ retval = unmap_queues_cpsch(dqm, KFD_UNMAP_QUEUES_FILTER_DYNAMIC_QUEUES, ++ 0); + if (retval) { + pr_err("The cp might be in an unrecoverable state due to an unsuccessful queues preemption"); + return retval; +-- +2.7.4 + |