aboutsummaryrefslogtreecommitdiffstats
path: root/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3359-drm-amdkfd-Clean-up-process-queue-management.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3359-drm-amdkfd-Clean-up-process-queue-management.patch')
-rw-r--r--meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3359-drm-amdkfd-Clean-up-process-queue-management.patch131
1 files changed, 131 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3359-drm-amdkfd-Clean-up-process-queue-management.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3359-drm-amdkfd-Clean-up-process-queue-management.patch
new file mode 100644
index 00000000..5094c07a
--- /dev/null
+++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3359-drm-amdkfd-Clean-up-process-queue-management.patch
@@ -0,0 +1,131 @@
+From f526210e7dbd0102fbaddc3dc39122375786605c Mon Sep 17 00:00:00 2001
+From: Felix Kuehling <Felix.Kuehling@amd.com>
+Date: Wed, 27 Sep 2017 00:09:54 -0400
+Subject: [PATCH 3359/4131] drm/amdkfd: Clean up process queue management
+
+Removed unused num_concurrent_processes.
+
+Implemented counting of queues in QPD. This makes counting the queue
+list repeatedly in several places unnecessary.
+
+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>
+---
+ drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c | 5 +++++
+ drivers/gpu/drm/amd/amdkfd/kfd_packet_manager.c | 7 +------
+ drivers/gpu/drm/amd/amdkfd/kfd_priv.h | 1 -
+ drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c | 9 ++-------
+ 4 files changed, 8 insertions(+), 14 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 dd7e445..c0685cd 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c
+@@ -189,6 +189,7 @@ static int create_queue_nocpsch(struct device_queue_manager *dqm,
+ }
+
+ list_add(&q->list, &qpd->queues_list);
++ qpd->queue_count++;
+ if (q->properties.is_active)
+ dqm->queue_count++;
+
+@@ -347,6 +348,7 @@ static int destroy_queue_nocpsch_locked(struct device_queue_manager *dqm,
+
+ deallocate_vmid(dqm, qpd, q);
+ }
++ qpd->queue_count--;
+ if (q->properties.is_active)
+ dqm->queue_count--;
+
+@@ -856,6 +858,7 @@ static int create_queue_cpsch(struct device_queue_manager *dqm, struct queue *q,
+ goto out;
+
+ list_add(&q->list, &qpd->queues_list);
++ qpd->queue_count++;
+ if (q->properties.is_active) {
+ dqm->queue_count++;
+ retval = execute_queues_cpsch(dqm,
+@@ -1014,6 +1017,7 @@ static int destroy_queue_cpsch(struct device_queue_manager *dqm,
+ dqm->sdma_queue_count--;
+
+ list_del(&q->list);
++ qpd->queue_count--;
+ if (q->properties.is_active)
+ dqm->queue_count--;
+
+@@ -1204,6 +1208,7 @@ static int process_termination_cpsch(struct device_queue_manager *dqm,
+ goto out;
+ }
+ list_del(&q->list);
++ qpd->queue_count--;
+ mqd->uninit_mqd(mqd, q->mqd, q->mqd_mem_obj);
+ }
+
+diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_packet_manager.c b/drivers/gpu/drm/amd/amdkfd/kfd_packet_manager.c
+index e5a15ba..5d1770e 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_packet_manager.c
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_packet_manager.c
+@@ -140,8 +140,6 @@ static int pm_create_map_process(struct packet_manager *pm, uint32_t *buffer,
+ struct qcm_process_device *qpd)
+ {
+ struct pm4_mes_map_process *packet;
+- struct queue *cur;
+- uint32_t num_queues;
+
+ packet = (struct pm4_mes_map_process *)buffer;
+
+@@ -156,10 +154,7 @@ static int pm_create_map_process(struct packet_manager *pm, uint32_t *buffer,
+ packet->bitfields10.gds_size = qpd->gds_size;
+ packet->bitfields10.num_gws = qpd->num_gws;
+ packet->bitfields10.num_oac = qpd->num_oac;
+- num_queues = 0;
+- list_for_each_entry(cur, &qpd->queues_list, list)
+- num_queues++;
+- packet->bitfields10.num_queues = (qpd->is_debug) ? 0 : num_queues;
++ packet->bitfields10.num_queues = (qpd->is_debug) ? 0 : qpd->queue_count;
+
+ packet->sh_mem_config = qpd->sh_mem_config;
+ packet->sh_mem_bases = qpd->sh_mem_bases;
+diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_priv.h b/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
+index 7f14173..7d86ec9 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
+@@ -405,7 +405,6 @@ struct scheduling_resources {
+ struct process_queue_manager {
+ /* data */
+ struct kfd_process *process;
+- unsigned int num_concurrent_processes;
+ struct list_head queues;
+ unsigned long *queue_slot_bitmap;
+ };
+diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c b/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
+index 39ca64b..492d69a 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
+@@ -149,8 +149,6 @@ int pqm_create_queue(struct process_queue_manager *pqm,
+ struct queue *q;
+ struct process_queue_node *pqn;
+ struct kernel_queue *kq;
+- int num_queues = 0;
+- struct queue *cur;
+ enum kfd_queue_type type = properties->type;
+
+ q = NULL;
+@@ -168,11 +166,8 @@ int pqm_create_queue(struct process_queue_manager *pqm,
+ * If we are just about to create DIQ, the is_debug flag is not set yet
+ * Hence we also check the type as well
+ */
+- if ((pdd->qpd.is_debug) ||
+- (type == KFD_QUEUE_TYPE_DIQ)) {
+- list_for_each_entry(cur, &pdd->qpd.queues_list, list)
+- num_queues++;
+- if (num_queues >= dev->device_info->max_no_of_hqd/2)
++ if ((pdd->qpd.is_debug) || (type == KFD_QUEUE_TYPE_DIQ)) {
++ if (pdd->qpd.queue_count >= dev->device_info->max_no_of_hqd/2)
+ return -ENOSPC;
+ }
+
+--
+2.7.4
+