void init_cfs_rq(struct cfs_rq *cfs_rq) { cfs_rq->tasks_timeline = RB_ROOT_CACHED; cfs_rq->min_vruntime = (u64)(-(1LL << 20)); #ifndef CONFIG_64BIT cfs_rq->min_vruntime_copy = cfs_rq->min_vruntime; #endif #ifdef CONFIG_SMP raw_spin_lock_init(&cfs_rq->removed.lock); #endif }
时间: 2023-08-26 15:04:03 浏览: 285
这是一个函数,用于初始化 CFS(Completely Fair Scheduler)调度器的运行队列(cfs_rq)。它的具体作用如下:
1. 将 tasks_timeline 属性初始化为一个空的红黑树,这个红黑树用于按照每个任务的虚拟运行时间(vruntime)进行排序,以实现公平调度。
2. 将 min_vruntime 属性初始化为一个较小的值,这个值是一个 64 位整数,表示虚拟运行时间的最小值。这是为了避免出现负数的情况,因为虚拟运行时间是一个无符号数。
3. 如果不是 64 位系统,还会将 min_vruntime_copy 属性设置为 min_vruntime,用于备份。
4. 如果是多核系统,还会初始化 removed 属性的锁,这个锁用于保护运行队列中被移除的任务。
5. 函数没有返回值,它只是初始化了 cfs_rq 结构体中的一些属性。
相关问题
init_cfs_rq 做了哪些事情
根据我所了解到的信息,"init_cfs_rq" 是 Linux 内核中调度器部分的函数,其作用是初始化一个 cfs_rq 结构体,该结构体用于跟踪一组任务(task)的调度情况。在调用 "init_cfs_rq" 函数时,会初始化该结构体的各个字段,如 min_vruntime、curr、load 等,并将其加入到调度器的红黑树中。这样,就可以在进程调度时使用 cfs_rq 结构体中的信息来进行调度策略的决策。
/* rq on which this entity is (to be) queued: */ struct cfs_rq *cfs_rq; /* rq "owned" by this entity/group: */ struct cfs_rq *my_q; /* cached value of my_q->h_nr_running */ unsigned long runnable_weight;
在Linux内核中,sched_entity是进程调度器中的一个结构体,用于描述进程的调度实体。其中,cfs_rq是一个指针,表示该进程所在的CFS调度队列。CFS调度器是Linux内核中的一种公平调度算法,用于分配CPU时间片给各个进程。每个CFS调度队列由一个cfs_rq结构体来表示,该结构体中维护了一个红黑树,用于按照进程的优先级进行有序排列。当一个进程被加入CFS调度队列中时,它的sched_entity中的cfs_rq指针就会被设置为该队列的指针。而my_q指针则表示该进程所“拥有”的CFS调度队列,即当该进程创建子进程时,子进程的CFS调度队列就会被设置为该进程所拥有的队列。runnable_weight是一个权重值,表示该进程的可运行状态所占的CPU时间片比例。该值的计算方式和CFS调度算法的实现有关。
阅读全文