On Wed, Jan 24, 2018 at 04:15:49AM +0000, Sasha Levin wrote:
> From: Jiang Biao <[email protected]>
>
> [ Upstream commit d5dabd633922ac5ee5bcc67748f7defb8b211469 ]
>
> When running ltp stress test for 7*24 hours, vmscan occasionally emits
> the following warning continuously:
>
> mb_cache_scan+0x0/0x3f0 negative objects to delete
> nr=-9232265467809300450
> ...
>
> Tracing shows the freeable(mb_cache_count returns) is -1, which causes
> the continuous accumulation and overflow of total_scan.
>
> This patch makes sure that mb_cache_count() cannot return a negative
> value, which makes the mbcache shrinker more robust.
>
> Link:
> http://lkml.kernel.org/r/[email protected]
> Signed-off-by: Jiang Biao <[email protected]>
> Cc: Al Viro <[email protected]>
> Cc: Minchan Kim <[email protected]>
> Cc: Michal Hocko <[email protected]>
> Cc: <[email protected]>
> Signed-off-by: Andrew Morton <[email protected]>
> Signed-off-by: Linus Torvalds <[email protected]>
> Signed-off-by: Sasha Levin <[email protected]>
> ---
> fs/mbcache.c | 3 +++
> 1 file changed, 3 insertions(+)
>
> diff --git a/fs/mbcache.c b/fs/mbcache.c
> index c5bd19ffa326..35ab4187bfe1 100644
> --- a/fs/mbcache.c
> +++ b/fs/mbcache.c
> @@ -269,6 +269,9 @@ static unsigned long mb_cache_count(struct shrinker
> *shrink,
> struct mb_cache *cache = container_of(shrink, struct mb_cache,
> c_shrink);
>
> + /* Unlikely, but not impossible */
> + if (unlikely(cache->c_entry_count < 0))
> + return 0;
> return cache->c_entry_count;
> }
This patch is broken and is reverted in linux-next, via ext4/dev:
bbe45d2460da ("mbcache: revert "fs/mbcache.c: make count_objects() more
robust"")
Can you please update your "autosel" script/process/whatever to not select
commits that are reverted?