All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] mm, page_alloc: Fix a division by zero error when boosting watermarks
@ 2019-02-13 13:19 ` Mel Gorman
  0 siblings, 0 replies; 12+ messages in thread
From: Mel Gorman @ 2019-02-13 13:19 UTC (permalink / raw)
  To: Andrew Morton
  Cc: Yury Norov, Vlastimil Babka, Andrea Arcangeli, David Rientjes,
	Michal Hocko, Will Deacon, Catalin Marinas, linux-kernel,
	linux-arm-kernel, linux-mm

Yury Norov reported that an arm64 KVM instance could not boot since after
v5.0-rc1 and could addressed by reverting the patches

1c30844d2dfe272d58c ("mm: reclaim small amounts of memory when an external
73444bc4d8f92e46a20 ("mm, page_alloc: do not wake kswapd with zone lock held")

The problem is that a division by zero error is possible if boosting occurs
either very early in boot or if the high watermark is very small. This
patch checks for the conditions and avoids boosting in those cases.

Fixes: 1c30844d2dfe ("mm: reclaim small amounts of memory when an external fragmentation event occurs")
Reported-and-tested-by: Yury Norov <yury.norov@gmail.com>
Signed-off-by: Mel Gorman <mgorman@techsingularity.net>
---
 mm/page_alloc.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index d295c9bc01a8..ae7e4ba5b9f5 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -2170,6 +2170,11 @@ static inline void boost_watermark(struct zone *zone)
 
 	max_boost = mult_frac(zone->_watermark[WMARK_HIGH],
 			watermark_boost_factor, 10000);
+
+	/* high watermark be be uninitialised or very small */
+	if (!max_boost)
+		return;
+
 	max_boost = max(pageblock_nr_pages, max_boost);
 
 	zone->watermark_boost = min(zone->watermark_boost + pageblock_nr_pages,

-- 
Mel Gorman
SUSE Labs

^ permalink raw reply related	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2019-02-13 14:32 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-02-13 13:19 [PATCH] mm, page_alloc: Fix a division by zero error when boosting watermarks Mel Gorman
2019-02-13 13:19 ` Mel Gorman
2019-02-13 13:20 ` Will Deacon
2019-02-13 13:20   ` Will Deacon
2019-02-13 13:42 ` Vlastimil Babka
2019-02-13 13:42   ` Vlastimil Babka
2019-02-13 14:15   ` Mel Gorman
2019-02-13 14:15     ` Mel Gorman
2019-02-13 14:30 ` [PATCH] mm, page_alloc: Fix a division by zero error when boosting watermarks v2 Mel Gorman
2019-02-13 14:30   ` Mel Gorman
2019-02-13 14:31   ` Vlastimil Babka
2019-02-13 14:31     ` Vlastimil Babka

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.