- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我了解到在 /proc/sys/kernel/sched_child_runs_first
中设置一个非零值将强制子进程在父进程之前运行。但是,我认为它似乎没有用。这是我的代码:
#include <stdio.h>
#include <sys/types.h>
int main(int argc, char **argv)
{
pid_t child_pid;
switch(child_pid = fork())
{
case 0:
printf("In Child\n");
exit(0);
case -1:
printf("Could not fork()\n");
default:
printf("In parent\n");
}
return 0;
}
我得到的输出总是:
In parent
In Child
我这里是不是有什么问题?
PS:我只是在试验看看它是否有效,所以请不要提出其他同步机制或为什么这是个坏主意等。
最佳答案
据我所知,实现 sched_child_runs_first
功能的地方是在 task_fork_fair
函数中,您可以查看其源代码 here .
该函数的关键部分如下所示:
if (curr)
se->vruntime = curr->vruntime;
place_entity(cfs_rq, se, 1);
if (sysctl_sched_child_runs_first && curr && entity_before(curr, se)) {
swap(curr->vruntime, se->vruntime);
resched_task(rq->curr);
}
se 是新的调度实体,curr 是当前任务的调度实体。
请注意,新实体的 vruntime 首先使用与当前任务相同的值进行初始化。这很重要,因为 entity_before
调用正在检查 curr 的 vruntime 是否小于 vruntime < em>se.
因此,条件成功的唯一方法是 place_entity
调用将 se 的 vruntime 设置为更大的值。那么让我们看看source为了那个原因。关键位是:
u64 vruntime = cfs_rq->min_vruntime;
if (initial && sched_feat(START_DEBIT))
vruntime += sched_vslice(cfs_rq, se);
se->vruntime = max_vruntime(se->vruntime, vruntime);
因此,假设设置了 START_DEBIT
功能(seems to be the case),则 vruntime 将设置为运行队列的 min_vruntime 加上无论 sched_vslice
调用返回什么。如果它大于当前的 vruntime,那么我们就设置好了 - 如果不是,我们将保留我们的初始 vruntime 值并且条件不会成功。
我不太了解 Linux 调度,无法肯定地说,但我猜测 min_vruntime 加上 sched_vslice
大多数时候都不够大.
我说大部分时间是因为,当我进行测试时,至少在某些时候我能够让子进程先运行。所以 sched_child_runs_first
参数可能确实有所作为 - 它只是不能保证任何事情。
另一种可能是代码中的错误,他们在计算初始值时应该从当前任务的vruntime开始而不是运行队列的min_vruntime在 place_entity
函数中。那将保证条件会成功。但我怀疑按照他们的方式做事是有原因的,我就是不明白。
关于c -/proc/sys/kernel/sched_child_runs_first 工作吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17391201/
我需要从 kernel/system/do_kill.c (Minix) 将一些信息写入我的特殊日志文件(例如,/home/log.txt) . 我已经尝试过: int filedesc; filed
我正在经历 Uboot 和内核启动过程。 FDT(平面设备树)到底有什么用? 我读过的许多链接都指出,uboot 以 FDT 的形式将板和 SOC 配置信息传递给内核 https://wiki.fre
我的操作系统是Fedora 17。最近,出现内核污染警告“kernel bug at kernel/auditsc.c:1772!-abrt”:不应报告此问题(这可能是一个已知问题)。发生内核问题,但
为 Linux 编译内核模块的教程,使用不同的 Makefile 语法。 Example 1 obj-m += rpi-pwm.o Example 2 obj-m := nothing.o 有什么区别
我正在浏览 Linux 网络设备驱动程序代码,想知道是否可以从驱动程序代码中调用设备层代码。 --- a/drivers/net/ethernet/realtek/8139too.c +++ b/dr
出于工具目的,我尝试附加到 kprobe 事件,但我对 kprobe 事件不太熟悉。我读到注册的 kprobes 列表可以在 /sys/kernel/debug/kprobes/list 中找到,但是
我在其他地方使用 LinK+ 来开发 linux 内核模块。我的开发机器安装了 Linux Mint 18 操作系统,内核版本为 4.4.xx。为了进行测试,我想将内核模块部署到内核版本为 3.16.
我正在玩弄 Android Linux 内核。内核是P970 V30B内核。可用here .我想找出特定的 cmdline 参数到底做了什么。 我知道它是命令行参数,其中有一个参数我找不到它到底做了什
是否可以将 PTE 指向不同的物理页面? 假设我目前在某个进程 A 的上下文中处于内核模式,该进程当前将地址 400k 映射到物理页号。 5. 我可以将该地址 (400k) 映射到物理页号吗? 6 ?
我正在开发一个要在路由器上运行的内核模块。路由器型号为 Netgear 的 DGN2200v2。它在 MIPS 上运行 Linux 2.6.30。我的问题是,当我加载我的模块时,似乎我的 module
关闭。这个问题不符合 Stack Overflow guidelines 。它目前不接受答案。 想改进这个问题?更新问题,使其成为 Stack Overflow 的 on-topic。 6年前关闭。
在大型网格中执行的任务调用两个内核有区别吗 1. for(int i=0;i>>(MatrixA,MatrixB) } 2. dim3 dimBlock(16, 16); dim3 dimGrid(1
在 Linux 中,我生成了一个猜测 VM 并加载了另一个 Linux 实例。 VM 是通过 KVM/libvirt/qemu 生成的。 guest VM 被主机内核视为一个进程。让我们说由于某种原因
我想知道如何设置正确 MACH_TYPE或 arch_id对于内核。我搜索并找到了至少 2 个引用,其中内核会卡在“启动内核...”处。这些都给出了相同的答案。正确设置您的机器类型。但后来都没有提到如
kernel data inpage error蓝屏是一个不常见的问题,一般都是更新失败或者第三方软件冲突导致的,解决方法也非常简单,需要先安全模式进入系统,下面来看看详细的教程吧。 kern
当我用 app/console cache:clear 清除缓存时我收到错误: [Symfony\Component\DependencyInjection\Exception\ParameterNo
我正在玩 Raspberry 3,并尝试使用 U-Boot 启动 Linux 内核。 我构建了一个 Linux 内核(来自 github.com/raspberrypi)和 Busbox-Userla
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
长话短说,我一直在做一个项目,当我使用时我注意到: 1.9.3p392 :001 > `gzip` IRB::Abort: abort then interrupt! from (irb):1
我有一个服务,我在其中注入(inject) TokenStorage 并想要获取当前用户。 /** * * @Service("liip_theme.theme_request_listener"
我是一名优秀的程序员,十分优秀!