文章目录
【WALT】update_task_demand() 代码详解
代码版本:Linux4.9 android-msm-crosshatch-4.9-android12
代码展示
static u64 update_task_demand(struct task_struct *p, struct rq *rq,
int event, u64 wallclock)
{
u64 mark_start = p->ravg.mark_start;
u64 delta, window_start = rq->window_start;
int new_window, nr_full_windows;
u32 window_size = sched_ravg_window;
u64 runtime;
// 用于判断是否进入新窗口的标志位
new_window = mark_start < window_start;
// ⑴ 不累加任务运行时间的条件判断
if (!account_busy_for_task_demand(rq, p, event)) {
if (new_window)
update_history(rq, p, p->ravg.sum, 1, event);
return 0;
}
// ⑵ 仍在旧窗口中
if (!new_window) {
return add_to_task_demand(rq, p
Linux内核中的WALT:update_task_demand函数解析

本文详细介绍了Linux4.9内核中的WALT(WindowedAverageLoadTracking)算法中update_task_demand函数的代码逻辑。函数主要处理任务运行时间的累加和窗口更新,涉及任务在旧窗口和新窗口中的时间处理,以及任务状态的判断。通过对任务运行时间的精确跟踪,WALT算法能够更准确地评估系统负载。
最低0.47元/天 解锁文章
970





