一尘不染

如何在Linux中从C使用sched_getaffinity和sched_setaffinity?

linux

我在尝试着:

  • 与处理器固定同时运行16个副本(每个内核2个副本)

  • 在某些功能说功能1完成后,与处理器固定同时运行8个副本(每个内核2个副本),并将处理器内核翻转到最远的内核。

我面临的问题是如何选择最远的处理器。

一些朋友建议使用sched_getaffinity和sched_setaffinity,但我认为找不到任何好的示例。


阅读 419

收藏
2020-06-02

共1个答案

一尘不染

要使用sched_setaffinity使当前进程在核心7上运行,请执行以下操作:

cpu_set_t my_set;        /* Define your cpu_set bit mask. */
CPU_ZERO(&my_set);       /* Initialize it all to 0, i.e. no CPUs selected. */
CPU_SET(7, &my_set);     /* set the bit that represents core 7. */
sched_setaffinity(0, sizeof(cpu_set_t), &my_set); /* Set affinity of tihs process to */
                                                  /* the defined mask, i.e. only 7. */

有关更多信息,请参见http://linux.die.net/man/2/sched_setaffinityhttp://www.gnu.org/software/libc/manual/html_node/CPU-
Affinity.html。

2020-06-02