diff options
| author | Andrea Righi <arighi@nvidia.com> | 2025-02-14 22:40:03 +0300 | 
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2025-02-16 19:52:20 +0300 | 
| commit | f09177ca5f242a32368a2e9414dce4c90dc1d405 (patch) | |
| tree | 4e28e9227a074cbb72b873260d094fe9fd971b43 /tools/perf/scripts/python/parallel-perf.py | |
| parent | 16d79f2a4f155b54e7580563c6c03832506b3b09 (diff) | |
| download | linux-f09177ca5f242a32368a2e9414dce4c90dc1d405.tar.xz | |
sched/topology: Introduce for_each_node_numadist() iterator
Introduce the new helper for_each_node_numadist() to iterate over node
IDs in order of increasing NUMA distance from a given starting node.
This iterator is somehow similar to for_each_numa_hop_mask(), but
instead of providing a cpumask at each iteration, it provides a node ID.
Example usage:
  nodemask_t unvisited = NODE_MASK_ALL;
  int node, start = cpu_to_node(smp_processor_id());
  node = start;
  for_each_node_numadist(node, unvisited)
  	pr_info("node (%d, %d) -> %d\n",
  		 start, node, node_distance(start, node));
On a system with equidistant nodes:
 $ numactl -H
 ...
 node distances:
 node     0    1    2    3
    0:   10   20   20   20
    1:   20   10   20   20
    2:   20   20   10   20
    3:   20   20   20   10
Output of the example above (on node 0):
[    7.367022] node (0, 0) -> 10
[    7.367151] node (0, 1) -> 20
[    7.367186] node (0, 2) -> 20
[    7.367247] node (0, 3) -> 20
On a system with non-equidistant nodes (simulated using virtme-ng):
 $ numactl -H
 ...
 node distances:
 node     0    1    2    3
    0:   10   51   31   41
    1:   51   10   21   61
    2:   31   21   10   11
    3:   41   61   11   10
Output of the example above (on node 0):
 [    8.953644] node (0, 0) -> 10
 [    8.953712] node (0, 2) -> 31
 [    8.953764] node (0, 3) -> 41
 [    8.953817] node (0, 1) -> 51
Suggested-by: Yury Norov [NVIDIA] <yury.norov@gmail.com>
Signed-off-by: Andrea Righi <arighi@nvidia.com>
Acked-by: Yury Norov [NVIDIA] <yury.norov@gmail.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/parallel-perf.py')
0 files changed, 0 insertions, 0 deletions
