summaryrefslogtreecommitdiff
path: root/kernel/sched/fair.c
diff options
context:
space:
mode:
authorIngo Molnar <mingo@kernel.org>2019-04-30 07:51:54 +0200
committerIngo Molnar <mingo@kernel.org>2019-04-30 07:51:54 +0200
commitd5963d87bf84060ff3fb572bf6d3606f7fd087d1 (patch)
tree5a94c33a56d7bdd91a38aa0ec50e9202914f742e /kernel/sched/fair.c
parent3db6d5a5ecaf0a778d721ccf9809248350d4bfaf (diff)
parent37624b58542fb9f2d9a70e6ea006ef8a5f66c30b (diff)
downloadlinux-d5963d87bf84060ff3fb572bf6d3606f7fd087d1.tar.gz
linux-d5963d87bf84060ff3fb572bf6d3606f7fd087d1.tar.bz2
linux-d5963d87bf84060ff3fb572bf6d3606f7fd087d1.zip
Merge tag 'v5.1-rc7' into x86/mm, to pick up fixes
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/sched/fair.c')
-rw-r--r--kernel/sched/fair.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c
index a4d9e14bf138..35f3ea375084 100644
--- a/kernel/sched/fair.c
+++ b/kernel/sched/fair.c
@@ -2007,6 +2007,10 @@ static u64 numa_get_avg_runtime(struct task_struct *p, u64 *period)
if (p->last_task_numa_placement) {
delta = runtime - p->last_sum_exec_runtime;
*period = now - p->last_task_numa_placement;
+
+ /* Avoid time going backwards, prevent potential divide error: */
+ if (unlikely((s64)*period < 0))
+ *period = 0;
} else {
delta = p->se.avg.load_sum;
*period = LOAD_AVG_MAX;