- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在研究工作队列时,我遇到了在内核中定义的工作队列标志和常量。我有以下疑问,我无法理解。
这里的 draining 和 rescuer 到底是什么意思?
WQ_DRAINING = 1 << 6, /* internal: workqueue is draining */
WQ_RESCUER = 1 << 7, /* internal: workqueue has rescuer */
为未绑定(bind)工作队列定义的 CPU 数量是 4。如果我有八核处理器怎么办。无界的 wq 将如何绑定(bind)到 cpus。他们如何决定运行哪些 CPU,因为他们现在有 8 个 CPU 而不是 4 个 CPU。是吗,它们可以在 8 个或仅 4 个特定 cpu 中的任何一个上运行?
WQ_MAX_UNBOUND_PER_CPU = 4,/* 4 * #cpus for unbound wq */
最佳答案
这个标志用来表示内核当前正在刷新工作队列和新的工作项不能在上面排队。在此阶段只允许当前挂起或正在运行的工作项,直到整个工作队列完全为空。
有关详细信息,请查看 drain_workqueue()
的实现 在 kernel/workqueue.c
中。
这个标志在最新的内核中已经被这个 patch 弃用了 并且该行为现在由 WQ_MEM_RECLAIM
标志决定。
就“救援者”功能而言,这里是kernel/workqueue.c
文档的相关部分,
Workqueue rescuer thread function. There's one rescuer for each workqueue which has WQ_MEM_RECLAIM set.
Regular work processing on a pool may block trying to create a new worker which uses GFP_KERNEL allocation which has slight chance of developing into deadlock if some works currently on the same queue need to be processed to satisfy the GFP_KERNEL allocation. This is the problem rescuer solves.
When such condition is possible, the pool summons rescuers of all workqueues which have works queued on the pool and let them process those works so that forward progress can be guaranteed.
(与您的解释相反,WQ_MAX_UNBOUND_PER_CPU 不是 cpu 的数量。它是可以与 cpu 关联的工作队列的数量。)
工作队列传统上是每个 CPU 的,即每个工作队列都与一个特定的 CPU 相关联,从而由于缓存局部性而获得更好的性能。内核调度程序别无选择,只能始终在其定义的 cpu 上调度它。在当前的体系结构中,这会导致功耗增加,因为即使是单个工作队列也可以防止 CPU 空闲和关闭。因此引入了未绑定(bind)的工作队列。调度程序可以根据需要在任何 CPU 上自由地重新调度未绑定(bind)的工作队列。
此类工作队列的总数限制为 WQ_UNBOUND_MAX_ACTIVE
,定义为 num_possible_cpus() * WQ_MAX_UNBOUND_PER_CPU
(系统中工作队列总数的上限由 确定>WQ_MAX_ACTIVE
).
关于c - 工作队列的这些标志是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17780477/
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
在main()中声明其原型(prototype)的函数的返回数据类型为void。它包含一个指令返回;如 main() { void create(int *p); *some code
我想知道这个 scala 符号是什么:_@。 (搜索引擎无法识别奇怪的字符,因此很难在 google 上找到任何内容...) 这里是上下文: def doNodeParse(json: JValue)
在尝试编译我的项目时,它使用了一些第三方头文件,使用 mingw 4.4,我遇到了以下错误: Assembler messages: Error: junk at end of line, first
我正在解决 picoCTF 上的二进制漏洞利用挑战,并遇到了这段代码: ((void (*)())buf)(); 哪里buf是一个字符数组。 我解决了挑战,但似乎无法理解它到底在做什么。我看了this
我正在浏览 React Navigation docs我在那里遇到了这样的事情: import Ionicons from 'react-native-vector-icons/Ionicons';
selenium 中以下命令的含义是什么? 我尝试创建一个自动测试用例。然后如下://button[@type='submit'] 我在 selenium 工具中看到的语法。 最佳答案 这是一个 XP
我刚开始看书学习 C 语言,对他们讨论指针和数组的部分并没有感到困惑。如果有一个名为 a[NUM_ROW][NUM_COLS] 的多维数组(我只是将此数组讨论为特定的二维数组),那么 a[0] 是什么
这个问题在这里已经有了答案: How does "while(*s++ = *t++)" copy a string? (17 个答案) 关闭 9 年前。 我有一个代码块: int main ()
我没有在我的代码中处理 SIGCHLD。我的进程在终止后仍然立即被删除。我希望它成为僵尸进程。 如果我将 SIGCHLD 设置为 SIG_DFL 那么它会起作用吗?如何将 SIGCHLD 设置为 SI
我已经使用 matplotlib 一段时间了,但我并不真正理解这一行的作用。 fig, ax = plt.subplots() 谁能解释一下? 最佳答案 plt.subplots() 基本上是一个(非
我很难理解以下声明的含义。这个申报标准吗? double* (*p[3]) (void* (*)()); 谁能帮我理解这个声明的意思? 最佳答案 阅读复杂声明的规则:找到最左边的标识符并向外工作,记住
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我正在学习如何并行运行多个进程 ./script1.sh param1 1>/dev/null 2>&1 & pid1=$! ./script1.sh param2 1>/dev/null
我看到这些事件散布在 chaplin 示例代码中,但在文档或源代码中没有任何解释。似乎这意味着它是一个全局事件,触发了一个 Action 。那是对的吗?它们只是一个惯例,还是以某种方式强制执行? #
((void(*)(void))0)(); 所以我们将整数 0 类型转换为这个棘手的类型 (void(*))(void) 然后执行它。消息来源声称这应该有效,但实际上是什么? 我想这一定是像 #def
这个问题在这里已经有了答案: How does this JavaScript/jQuery syntax work: (function( window, undefined ) { })(win
if(a .feq. 5.0_dp) then **** if(a .fne. 5.2_dp) then ***我遇到了一些这样的代码。 .feq 有什么作用?或.fne。意思?是“=”还是“\=”?
所以我在阅读泛型方法时感到很困惑。先说一下这里的问题: 在这个例子中:假设我需要一个适用于任何类型 T 的 selectionSort 版本,方法是使用调用者提供的外部可比较对象。 第一次尝试: pu
我是一名优秀的程序员,十分优秀!