diff options
author | Ingo Molnar <mingo@elte.hu> | 2007-08-09 05:16:46 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2007-08-09 05:16:46 -0400 |
commit | fd8bb43e27bbba1b6d49552c3d588cf741dd44af (patch) | |
tree | 04d24cf8604abe591d34b84da8aed0eeb4a0240d /kernel/sched_fair.c | |
parent | c5dcfe72aa8d26e924cccca9725a9f7be0d4ab01 (diff) |
sched: delta_exec accounting fix
small delta_exec accounting fix: increase delta_exec and increase
sum_exec_runtime even if the task is not on the runqueue anymore.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched_fair.c')
-rw-r--r-- | kernel/sched_fair.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c index 037b8245e533..16511e9e5528 100644 --- a/kernel/sched_fair.c +++ b/kernel/sched_fair.c | |||
@@ -287,15 +287,15 @@ __update_curr(struct cfs_rq *cfs_rq, struct sched_entity *curr, u64 now) | |||
287 | struct load_weight *lw = &cfs_rq->load; | 287 | struct load_weight *lw = &cfs_rq->load; |
288 | unsigned long load = lw->weight; | 288 | unsigned long load = lw->weight; |
289 | 289 | ||
290 | if (unlikely(!load)) | ||
291 | return; | ||
292 | |||
293 | delta_exec = curr->delta_exec; | 290 | delta_exec = curr->delta_exec; |
294 | schedstat_set(curr->exec_max, max((u64)delta_exec, curr->exec_max)); | 291 | schedstat_set(curr->exec_max, max((u64)delta_exec, curr->exec_max)); |
295 | 292 | ||
296 | curr->sum_exec_runtime += delta_exec; | 293 | curr->sum_exec_runtime += delta_exec; |
297 | cfs_rq->exec_clock += delta_exec; | 294 | cfs_rq->exec_clock += delta_exec; |
298 | 295 | ||
296 | if (unlikely(!load)) | ||
297 | return; | ||
298 | |||
299 | delta_fair = calc_delta_fair(delta_exec, lw); | 299 | delta_fair = calc_delta_fair(delta_exec, lw); |
300 | delta_mine = calc_delta_mine(delta_exec, curr->load.weight, lw); | 300 | delta_mine = calc_delta_mine(delta_exec, curr->load.weight, lw); |
301 | 301 | ||