aboutsummaryrefslogtreecommitdiffstats
path: root/mm/vmscan.c
diff options
context:
space:
mode:
authorKirill Tkhai <ktkhai@virtuozzo.com>2018-10-05 18:52:10 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2018-10-05 19:32:05 -0400
commitb8e57efa2c98cc56c49461c4950cf026422c29e9 (patch)
tree844349c6cbf468687ffb737aba763c6fe8fd3bcf /mm/vmscan.c
parent58bc4c34d249bf1bc50730a9a209139347cfacfe (diff)
mm/vmscan.c: fix int overflow in callers of do_shrink_slab()
do_shrink_slab() returns unsigned long value, and the placing into int variable cuts high bytes off. Then we compare ret and 0xfffffffe (since SHRINK_EMPTY is converted to ret type). Thus a large number of objects returned by do_shrink_slab() may be interpreted as SHRINK_EMPTY, if low bytes of their value are equal to 0xfffffffe. Fix that by declaration ret as unsigned long in these functions. Link: http://lkml.kernel.org/r/153813407177.17544.14888305435570723973.stgit@localhost.localdomain Signed-off-by: Kirill Tkhai <ktkhai@virtuozzo.com> Reported-by: Cyrill Gorcunov <gorcunov@openvz.org> Acked-by: Cyrill Gorcunov <gorcunov@openvz.org> Reviewed-by: Josef Bacik <josef@toxicpanda.com> Cc: Michal Hocko <mhocko@suse.com> Cc: Andrey Ryabinin <aryabinin@virtuozzo.com> Cc: Johannes Weiner <hannes@cmpxchg.org> Cc: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp> Cc: Shakeel Butt <shakeelb@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'mm/vmscan.c')
-rw-r--r--mm/vmscan.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/mm/vmscan.c b/mm/vmscan.c
index c7ce2c161225..c5ef7240cbcb 100644
--- a/mm/vmscan.c
+++ b/mm/vmscan.c
@@ -580,8 +580,8 @@ static unsigned long shrink_slab_memcg(gfp_t gfp_mask, int nid,
580 struct mem_cgroup *memcg, int priority) 580 struct mem_cgroup *memcg, int priority)
581{ 581{
582 struct memcg_shrinker_map *map; 582 struct memcg_shrinker_map *map;
583 unsigned long freed = 0; 583 unsigned long ret, freed = 0;
584 int ret, i; 584 int i;
585 585
586 if (!memcg_kmem_enabled() || !mem_cgroup_online(memcg)) 586 if (!memcg_kmem_enabled() || !mem_cgroup_online(memcg))
587 return 0; 587 return 0;
@@ -677,9 +677,8 @@ static unsigned long shrink_slab(gfp_t gfp_mask, int nid,
677 struct mem_cgroup *memcg, 677 struct mem_cgroup *memcg,
678 int priority) 678 int priority)
679{ 679{
680 unsigned long ret, freed = 0;
680 struct shrinker *shrinker; 681 struct shrinker *shrinker;
681 unsigned long freed = 0;
682 int ret;
683 682
684 if (!mem_cgroup_is_root(memcg)) 683 if (!mem_cgroup_is_root(memcg))
685 return shrink_slab_memcg(gfp_mask, nid, memcg, priority); 684 return shrink_slab_memcg(gfp_mask, nid, memcg, priority);