diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2018-11-19 01:07:43 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2018-11-19 01:07:43 +0100 |
commit | 24c0a02a18d35dbd4f7715018bfffb11241bce7b (patch) | |
tree | 298e71ed490274aacb14a856ae86bdba721d3d67 /kern/thread.c | |
parent | 2eec9a3688ab8a673a058312388cfff640acdd13 (diff) | |
download | gnumach-24c0a02a18d35dbd4f7715018bfffb11241bce7b.tar.gz gnumach-24c0a02a18d35dbd4f7715018bfffb11241bce7b.tar.bz2 gnumach-24c0a02a18d35dbd4f7715018bfffb11241bce7b.zip |
Fix task and thread collection frequency
sched_tick is incremented only once per second, not once per tick.
* kern/task.c (consider_task_collect): Divide task_collect_max_rate by
(hz / 1) to get a number of scheduler ticks.
* kern/thread.c (consider_thread_collect): Divide thread_collect_max_rate by
(hz / 1) to get a number of scheduler ticks.
Diffstat (limited to 'kern/thread.c')
-rw-r--r-- | kern/thread.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/kern/thread.c b/kern/thread.c index 29c26d44..86b76103 100644 --- a/kern/thread.c +++ b/kern/thread.c @@ -2326,7 +2326,8 @@ void consider_thread_collect(void) if (thread_collect_allowed && (sched_tick > - (thread_collect_last_tick + thread_collect_max_rate))) { + (thread_collect_last_tick + + thread_collect_max_rate / (hz / 1)))) { thread_collect_last_tick = sched_tick; thread_collect_scan(); } |