当前位置: 首页 > 面试题库 >

sched_setaffinity()如何工作?

孟振
2023-03-14
问题内容

我正在尝试了解linux syscallsched_setaffinity()的工作方式。这是我在这里提出的问题的后续。

我有本指南,该指南说明了如何使用syscall并有一个非常简洁(工作!)的示例。

因此,我下载了Linux 2.6.27.19 内核源代码。

我对包含该html" target="_blank">系统调用的行进行了“ grep”操作,得到了91个结果。没有希望。

最终,我试图了解内核如何 为特定内核 (或处理器)设置指令指针。

我熟悉单核单线程程序的工作方式。可能会发出“ jmp foo”指令,这基本上将IP设置为“
foo”标签的内存地址。但是,当一个具有多个内核时,必须说“在内存地址foo处获取下一条指令,并设置 2号内核 的指令指针以在那里开始执行”。

我们在汇编代码中的哪个位置指定执行该操作的内核?

回到内核代码:这里重要的是什么?文件“ kernel / sched.c”具有一个名为sched_setaffinity()的函数,但返回的类型为“
long”-与手册页不一致。那么这里重要的是什么?以下哪个模块显示了发出的组装说明?哪个模块正在读取“
task_struct”,查看“ cpus_allowed”成员,然后将其转换为指令?(我也翻阅过glibc源代码-
但我认为它只是调用内核代码来完成此任务。)


问题答案:

sched_setaffinity() 只需告诉调度程序允许该进程/线程在哪个CPU上运行,然后调用重新调度即可。

调度程序实际上在每个CPU上运行,因此有机会决定在该特定CPU上下一步执行什么任务。

如果您对如何在其他CPU上实际调用某些代码感兴趣,建议您参考一下smp_call_function_single()。如果我们要在另一个CPU上调用某个东西,则调用generic_exec_single()。后者只是将函数添加到目标CPU的调用队列中,并通过一些IPI东西(如果队列为空)来强制重新计划。

底线是:该_jmp_指令没有实际的SMP变体。相反,在其他CPU上运行的代码可以协作完成任务。



 类似资料:
  • 问题内容: 我在尝试着: 与处理器固定同时运行16个副本(每个内核2个副本) 在某些功能说功能1完成后,与处理器固定同时运行8个副本(每个内核2个副本),并将处理器内核翻转到最远的内核。 我面临的问题是如何选择最远的处理器。 一些朋友建议使用sched_getaffinity和sched_setaffinity,但我认为找不到任何好的示例。 问题答案: 要使用sched_setaffinity使当

  • 问题内容: 我对如何使用动作监听器和实现它们有一个想法,但是我想知道是否有人可以告诉我他们如何监听事件?有某种轮询机制吗? 问题答案: 动作侦听器使用观察者模式注册事件,主事件循环会将它们注册的所有事件通知它们。所以不,这不是轮询(拉)机制,而是相反的(推)回调。这是“不给我们打电话,我们给您打电话”编程的一个例子。因为代码中的所有内容都在单个线程(事件循环)上运行,所以您不必担心不同事件之间的同

  • 问题内容: 我试图了解Collections.binarySearch如何在Java中工作。我不太明白我得到的输出。 此代码的输出为-1。 当按此顺序插入元素时 结果是0。我认为如果找不到该元素,则结果为负数。有人可以澄清我收到的输出吗? 问题答案: 您的数据必须根据给定的比较器进行排序,以使二进制搜索能够按预期工作。(如果不是,则行为是不确定的。) 在进行此调用之前,必须根据指定的比较器(通过方

  • 问题内容: 我刚刚了解到。它用于动态加载扩展的驱动程序。然后我们得到使用方法的连接。 那么整个事情如何运作? DriverManager类如何知道如何在不使用实际驱动程序的类名的情况下获取连接。 我们也可以将Class.forName()用于自定义应用程序…如果通过示例进行解释,我将非常高兴。 问题答案: 只需加载一个类,包括运行其静态初始化程序,如下所示: 您正在谈论的所有其余过程都是特定于JD

  • 问题内容: ArrayList在内部使用什么数据结构? 问题答案: 内部使用。 在向中添加项目时,列表会检查后备阵列是否还有剩余空间。如果有空间,则将新项目添加到下一个空白处。如果没有空间,则会创建一个更大的新阵列,并将旧阵列复制到新阵列中。 现在,还有更多空间,新元素将添加到下一个空白空间。 由于人们真的很喜欢源代码: 直接跳出JDK。

  • 问题内容: 为了清楚起见,我试图找出Collections.sort(list,new MyComp())方法如何按顺序调用compare方法。 我有一个带有雇员及其个人号码(k)的LinkedList:这些号码是:{1,2,3,4,5,6} MyComparator中的compare(Object o1,Object o2)方法返回一些数字(即与该问题无关)。sort()如何比较方法?它使用参数