diff options
author | David Rientjes | 2012-06-20 12:52:58 -0700 |
---|---|---|
committer | Linus Torvalds | 2012-06-20 14:39:35 -0700 |
commit | 61eafb00d55dfbccdfce543c6b60e369ff4f8f18 (patch) | |
tree | e2be309a7412de35dd8414ea030b6650d2ea8b75 /mm/memcontrol.c | |
parent | fbb24a3a915f105016f1c828476be11aceac8504 (diff) |
mm, oom: fix and cleanup oom score calculations
The divide in p->signal->oom_score_adj * totalpages / 1000 within
oom_badness() was causing an overflow of the signed long data type.
This adds both the root bias and p->signal->oom_score_adj before doing the
normalization which fixes the issue and also cleans up the calculation.
Tested-by: Dave Jones <davej@redhat.com>
Signed-off-by: David Rientjes <rientjes@google.com>
Cc: KOSAKI Motohiro <kosaki.motohiro@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/memcontrol.c')
0 files changed, 0 insertions, 0 deletions