aboutsummaryrefslogtreecommitdiffstats
path: root/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3377-drm-amdkfd-use-a-high-priority-workqueue-for-IH-work.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3377-drm-amdkfd-use-a-high-priority-workqueue-for-IH-work.patch')
-rw-r--r--meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3377-drm-amdkfd-use-a-high-priority-workqueue-for-IH-work.patch79
1 files changed, 79 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3377-drm-amdkfd-use-a-high-priority-workqueue-for-IH-work.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3377-drm-amdkfd-use-a-high-priority-workqueue-for-IH-work.patch
new file mode 100644
index 00000000..af0a1816
--- /dev/null
+++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3377-drm-amdkfd-use-a-high-priority-workqueue-for-IH-work.patch
@@ -0,0 +1,79 @@
+From b4bfdaf9671336fe2fa575dab1ef6645bb706234 Mon Sep 17 00:00:00 2001
+From: Andres Rodriguez <andres.rodriguez@amd.com>
+Date: Fri, 27 Oct 2017 19:35:34 -0400
+Subject: [PATCH 3377/4131] drm/amdkfd: use a high priority workqueue for IH
+ work
+
+In systems under heavy load the IH work may experience significant
+scheduling delays.
+
+Under load + system workqueue:
+ Max Latency: 7.023695 ms
+ Avg Latency: 0.263994 ms
+
+Under load + high priority workqueue:
+ Max Latency: 1.162568 ms
+ Avg Latency: 0.163213 ms
+
+Further work is required to measure the impact of per-cpu settings on IH
+performance.
+
+Signed-off-by: Andres Rodriguez <andres.rodriguez@amd.com>
+Signed-off-by: Felix Kuehling <Felix.Kuehling@amd.com>
+Acked-by: Oded Gabbay <oded.gabbay@gmail.com>
+Signed-off-by: Oded Gabbay <oded.gabbay@gmail.com>
+---
+ drivers/gpu/drm/amd/amdkfd/kfd_device.c | 2 +-
+ drivers/gpu/drm/amd/amdkfd/kfd_interrupt.c | 3 ++-
+ drivers/gpu/drm/amd/amdkfd/kfd_priv.h | 1 +
+ 3 files changed, 4 insertions(+), 2 deletions(-)
+
+diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_device.c b/drivers/gpu/drm/amd/amdkfd/kfd_device.c
+index 46049f0..621a3b5 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_device.c
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_device.c
+@@ -403,7 +403,7 @@ void kgd2kfd_interrupt(struct kfd_dev *kfd, const void *ih_ring_entry)
+ if (kfd->interrupts_active
+ && interrupt_is_wanted(kfd, ih_ring_entry)
+ && enqueue_ih_ring_entry(kfd, ih_ring_entry))
+- schedule_work(&kfd->interrupt_work);
++ queue_work(kfd->ih_wq, &kfd->interrupt_work);
+
+ spin_unlock(&kfd->interrupt_lock);
+ }
+diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_interrupt.c b/drivers/gpu/drm/amd/amdkfd/kfd_interrupt.c
+index 9c08d46..035c351 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_interrupt.c
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_interrupt.c
+@@ -61,6 +61,7 @@ int kfd_interrupt_init(struct kfd_dev *kfd)
+ return r;
+ }
+
++ kfd->ih_wq = alloc_workqueue("KFD IH", WQ_HIGHPRI, 1);
+ spin_lock_init(&kfd->interrupt_lock);
+
+ INIT_WORK(&kfd->interrupt_work, interrupt_wq);
+@@ -95,7 +96,7 @@ void kfd_interrupt_exit(struct kfd_dev *kfd)
+ * work-queue items that will access interrupt_ring. New work items
+ * can't be created because we stopped interrupt handling above.
+ */
+- flush_work(&kfd->interrupt_work);
++ flush_workqueue(kfd->ih_wq);
+
+ kfifo_free(&kfd->ih_fifo);
+ }
+diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_priv.h b/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
+index 0aec5ca..6a91a60 100644
+--- a/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
++++ b/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
+@@ -184,6 +184,7 @@ struct kfd_dev {
+
+ /* Interrupts */
+ struct kfifo ih_fifo;
++ struct workqueue_struct *ih_wq;
+ struct work_struct interrupt_work;
+ spinlock_t interrupt_lock;
+
+--
+2.7.4
+