Re: [PATCH] dmatest: add CPU binding parameter

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On 9/6/2022 7:27 AM, Alexander Fomichev wrote:
Hi Dave,

Thanks for the comment. Maybe it makes sense to add a note (or comment) that choosing CPU from the same NUMA node as the DMA channel is recommended.
Anyway we can assign a different CPU for every DMA channel.
Having that option probably be best.

On Mon, Aug 22, 2022 at 08:40:35AM -0700, Dave Jiang wrote:
I don't think this would work for multi-socket systems given when it's
on you bind all threads to a single CPU even if you may have channels on
a different NUMA node. One possible way to do this is perhaps using
on_cpu for Nth core for the NUMA node the channel is on? Just throwing
out ideas.


Signed-off-by: Alexander Fomichev <a.fomichev@xxxxxxxxx>
---
   drivers/dma/dmatest.c | 23 +++++++++++++++++++++--
   1 file changed, 21 insertions(+), 2 deletions(-)

diff --git a/drivers/dma/dmatest.c b/drivers/dma/dmatest.c
index f696246f57fd..c91cbc9e5d1a 100644
--- a/drivers/dma/dmatest.c
+++ b/drivers/dma/dmatest.c
@@ -89,6 +89,10 @@ static bool polled;
   module_param(polled, bool, S_IRUGO | S_IWUSR);
   MODULE_PARM_DESC(polled, "Use polling for completion instead of interrupts");

+static int on_cpu = -1;
+module_param(on_cpu, int, 0644);
+MODULE_PARM_DESC(on_cpu, "Bind CPU to run threads on (default: auto scheduled (-1))");
+
   /**
    * struct dmatest_params - test parameters.
    * @buf_size:               size of the memcpy test buffer
@@ -237,6 +241,7 @@ struct dmatest_thread {
   struct dmatest_chan {
       struct list_head        node;
       struct dma_chan         *chan;
+     int                                     cpu;
       struct list_head        threads;
   };

@@ -602,6 +607,7 @@ static int dmatest_func(void *data)
       ret = -ENOMEM;

       smp_rmb();
+

Stray blank line

       thread->pending = false;
       info = thread->info;
       params = &info->params;
@@ -1010,6 +1016,7 @@ static int dmatest_add_channel(struct dmatest_info *info,
       struct dmatest_chan     *dtc;
       struct dma_device       *dma_dev = chan->device;
       unsigned int            thread_count = 0;
+     char    cpu_str[20];
       int cnt;

       dtc = kmalloc(sizeof(struct dmatest_chan), GFP_KERNEL);
@@ -1018,6 +1025,13 @@ static int dmatest_add_channel(struct dmatest_info *info,
               return -ENOMEM;
       }

+     memset(cpu_str, 0, sizeof(cpu_str));
+     if (on_cpu >= nr_cpu_ids || on_cpu < -1)
+             on_cpu = -1;
+     dtc->cpu = on_cpu;
+     if (dtc->cpu != -1)
+             snprintf(cpu_str, sizeof(cpu_str) - 1, " on CPU #%d", dtc->cpu);
+
       dtc->chan = chan;
       INIT_LIST_HEAD(&dtc->threads);

@@ -1050,8 +1064,8 @@ static int dmatest_add_channel(struct dmatest_info *info,
               thread_count += cnt > 0 ? cnt : 0;
       }

-     pr_info("Added %u threads using %s\n",
-             thread_count, dma_chan_name(chan));
+     pr_info("Added %u threads using %s%s\n",
+             thread_count, dma_chan_name(chan), cpu_str);

       list_add_tail(&dtc->node, &info->channels);
       info->nr_channels++;
@@ -1125,6 +1139,11 @@ static void run_pending_tests(struct dmatest_info *info)

               thread_count = 0;
               list_for_each_entry(thread, &dtc->threads, node) {
+                     if (dtc->cpu != -1) {
+                             if (!thread->pending)
+                                     continue;
+                             kthread_bind(thread->task, dtc->cpu);
+                     }
                       wake_up_process(thread->task);
                       thread_count++;
               }
All the best,
Alexander.



[Index of Archives]     [Linux Kernel]     [Linux ARM (vger)]     [Linux ARM MSM]     [Linux Omap]     [Linux Arm]     [Linux Tegra]     [Fedora ARM]     [Linux for Samsung SOC]     [eCos]     [Linux PCI]     [Linux Fastboot]     [Gcc Help]     [Git]     [DCCP]     [IETF Announce]     [Security]     [Linux MIPS]     [Yosemite Campsites]

  Powered by Linux