- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我想改变 Linux 内核,以便每次当前 PID 发生变化时——即,切换到一个新进程——执行一些诊断代码(下面有详细解释,如果好奇的话)。我做了一些挖掘,似乎每次调度程序选择一个新进程时,函数 context_switch()
都会被调用,这是有道理的(这只是来自对 sched 的粗略分析.c/schedule()
).
问题是,Linux 调度程序现在对我来说基本上是黑魔法,所以我想知道这个假设是否正确。是否保证每次选择新进程以在 CPU 上获得一些时间时,都会调用 context_switch() 函数?或者在内核源代码中是否有其他地方可以在其他情况下处理调度? (或者我完全误解了这一切?)
为了提供一些背景信息,我正在使用 MARSS x86 模拟器尝试对某些程序进行一些检测和测量。问题是我的仪器需要知道某些代码事件对应于哪个执行过程,以避免误解数据。这个想法是使用 MARSS 中的一些内置消息传递系统在每次上下文切换时传递新进程的 PID,因此它始终知道当前正在执行的 PID。如果有人能想到一种更简单的方法来实现这一点,我们也将不胜感激。
最佳答案
是的,你是对的。
schedule()
将调用 context_switch()
,它负责在 schedule() 选择新进程时从一个任务切换到另一个任务
。
context_switch()
基本上做了两件事。它调用 switch_mm()
和 switch_to()
。
switch_mm()
- 切换到新进程的虚拟内存映射
switch_to()
- 将处理器状态从前一个进程切换到新进程(保存/恢复寄存器、堆栈信息和其他架构特定的东西)
至于你的做法,我觉得还可以。重要的是在使用内核时保持良好和干净,并尽量保持相对简单,直到您获得更多知识。
关于c - kernel/sched.c/context_switch() 是否保证每次进程切换时都会被调用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11075910/
我使用 perf sched record 来记录一些东西。 我从 perf sched script 得到了一些context switch 事件 filebench 2646 [000] 211
当我执行 ls/usr/src/linux-headers-4.10.0-38-generic/include/linux/sched 时,我得到以下结果: deadline.h jobctl.h
我已经在 Windows 中使用 python 创建了在后台运行的调度程序的数量。谁能告诉我任何命令来检查 Windows 上运行的调度程序数量以及如何删除它们? 最佳答案 如果您使用sched.sc
我对 mongodb 很陌生。通过以下方式安装后:brew intall mongodb 然后在终端中键入 mongod,错误抛出:kern.sched unavailable。 我使用的是 mac
我最近开始学习 Python,我正在制作的简单应用程序的一部分包括一个在其自己的线程中运行的带有 hh:mm:ss 显示的计时器。 环顾网络,我发现了两种实现方法: 使用 sched.schedule
我正在编写一个需要在两个给定时间之间运行的 python 脚本。我需要使用 sched 模块中的构建,因为此脚本需要能够直接在任何具有 python 2.7 的机器上运行,以减少配置时间。 (所以 C
tl;dr:在 emacs 组织模式议程 View 中,我不明白为什么我的一些待办事项告诉我他们比预定日期多天数,而其他人则没有。 在 emacs 组织模式下,如果我输入 C-c a a我看到了我今天
我一直在尝试分析 perf sched record 的输出但我不明白我用什么引用系来理解“20624.983302 秒”。现在肯定不是 Unix 时间,那是什么?我将如何将其转换为 Unix 时间?
我需要证明,当进程运行时,我删除了这个进程的 ELF 文件,文件系统中的空闲 block 和节点数不会增加,而在我终止进程后,它们会增加。我还需要显示此过程的整个生命周期中的延迟,因此我正在使用 pe
Linux3.2.0 鉴于以下来源: #include #include int main(void) { printf("%i \n", CLONE_PTRACE);
我正在尝试将列表添加到 linux 内核 (2.4.14-18) 的 sched.h 中的任务结构。 我已经添加了成员 list_t waitList 在task_struct中,添加 waitL
我正在我的 Ubuntu 服务器上寻找 ached.h 文件,但我找不到它。在线它说它在 include/linux/sched.h 但我没有包含文件/不知道它在哪里。有人可以在这里指出我正确的方向吗
我想研究如何将线程手动分配给多核计算机上的特定核心。我发现 include/sched.h 定义了一些可以帮助解决此问题的宏和函数(sched_setaffinity 等)。然而,这些函数是外部的,我
在sched.h ,task_struct 有以下 2 个字段:thread_group 和 thread_node。他们保留了列表的第一个元素,但我找不到它们包含哪种类型的变量。 1511 stru
我正在尝试对 Linux 内核的 sched.h 进行一些更改。默认代码有 struct rq *rq ,它是事件运行队列列表,我需要为每个进程 p 迭代运行队列列表 rq 。有什么办法可以做到吗?
我要把linux程序移植到windows中。但我不知道Windows中的sched.h头相当于什么。任何人都可以帮忙吗? 最佳答案 libpthread是 Windows 的 POSIX 线程的实现。
import sched, time s = sched.scheduler(time.time, time.sleep) def do_something(sc): print("Doing
我正在研究 linux 内核。我修改了 sched.c 以指定我自己的调度策略。但是重新编译成我的自定义内核需要 50 多分钟。为什么我必须编译未修改的源代码?有没有办法只编译sched.c? 我键入
我有一个golang代码示例如下(xx.go): package main import "runtime" func main() { c2 := make(chan int) g
我想改变 Linux 内核,以便每次当前 PID 发生变化时——即,切换到一个新进程——执行一些诊断代码(下面有详细解释,如果好奇的话)。我做了一些挖掘,似乎每次调度程序选择一个新进程时,函数 con
我是一名优秀的程序员,十分优秀!