All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] mm,writeback: fix divide by zero in pos_ratio_polynom
@ 2014-04-29 19:19 ` Rik van Riel
  0 siblings, 0 replies; 56+ messages in thread
From: Rik van Riel @ 2014-04-29 19:19 UTC (permalink / raw)
  To: linux-kernel
  Cc: linux-mm, sandeen, akpm, jweiner, kosaki.motohiro, mhocko,
	fengguang.wu, mpatlasov

It is possible for "limit - setpoint + 1" to equal zero, leading to a
divide by zero error. Blindly adding 1 to "limit - setpoint" is not
working, so we need to actually test the divisor before calling div64.

Signed-off-by: Rik van Riel <riel@redhat.com>
Cc: stable@vger.kernel.org
---
 mm/page-writeback.c | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/mm/page-writeback.c b/mm/page-writeback.c
index ef41349..2682516 100644
--- a/mm/page-writeback.c
+++ b/mm/page-writeback.c
@@ -597,11 +597,16 @@ static inline long long pos_ratio_polynom(unsigned long setpoint,
 					  unsigned long dirty,
 					  unsigned long limit)
 {
+	unsigned int divisor;
 	long long pos_ratio;
 	long x;
 
+	divisor = limit - setpoint;
+	if (!divisor)
+		divisor = 1;
+
 	x = div_s64(((s64)setpoint - (s64)dirty) << RATELIMIT_CALC_SHIFT,
-		    limit - setpoint + 1);
+		    divisor);
 	pos_ratio = x;
 	pos_ratio = pos_ratio * x >> RATELIMIT_CALC_SHIFT;
 	pos_ratio = pos_ratio * x >> RATELIMIT_CALC_SHIFT;

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

end of thread, other threads:[~2014-05-08 10:17 UTC | newest]

Thread overview: 56+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-04-29 19:19 [PATCH] mm,writeback: fix divide by zero in pos_ratio_polynom Rik van Riel
2014-04-29 19:19 ` Rik van Riel
2014-04-29 19:43 ` Motohiro Kosaki
2014-04-29 19:43   ` Motohiro Kosaki
2014-04-29 22:39 ` Andrew Morton
2014-04-29 22:39   ` Andrew Morton
2014-04-29 22:48   ` Rik van Riel
2014-04-29 22:48     ` Rik van Riel
2014-04-29 22:53     ` Andrew Morton
2014-04-29 22:53       ` Andrew Morton
2014-04-30  8:04 ` Maxim Patlasov
2014-04-30  8:04   ` Maxim Patlasov
2014-04-30  8:12   ` Michal Hocko
2014-04-30  8:12     ` Michal Hocko
2014-04-30  8:34     ` Maxim Patlasov
2014-04-30  8:34       ` Maxim Patlasov
2014-04-30 10:01 ` Masayoshi Mizuma
2014-04-30 10:01   ` Masayoshi Mizuma
2014-04-30 13:30   ` [PATCH v2] " Rik van Riel
2014-04-30 13:30     ` Rik van Riel
2014-04-30 13:48     ` Michal Hocko
2014-04-30 13:48       ` Michal Hocko
2014-04-30 14:26       ` Rik van Riel
2014-04-30 14:26         ` Rik van Riel
2014-04-30 14:31       ` Rik van Riel
2014-04-30 14:31         ` Rik van Riel
2014-04-30 14:49         ` Michal Hocko
2014-04-30 14:49           ` Michal Hocko
2014-04-30 14:52           ` Rik van Riel
2014-04-30 14:52             ` Rik van Riel
2014-04-30 14:41       ` [PATCH v3] " Rik van Riel
2014-04-30 14:41         ` Rik van Riel
2014-04-30 19:00         ` Andrew Morton
2014-04-30 19:00           ` Andrew Morton
2014-04-30 19:30           ` Rik van Riel
2014-04-30 19:30             ` Rik van Riel
2014-04-30 19:35             ` Andrew Morton
2014-04-30 19:35               ` Andrew Morton
2014-04-30 20:02               ` [PATCH v4] " Rik van Riel
2014-04-30 20:02                 ` Rik van Riel
2014-04-30 20:13                 ` Andrew Morton
2014-04-30 20:13                   ` Andrew Morton
2014-04-30 20:32                   ` Rik van Riel
2014-04-30 20:32                     ` Rik van Riel
2014-04-30 20:42                   ` [PATCH v5] " Rik van Riel
2014-04-30 20:42                     ` Rik van Riel
2014-04-30 21:00                     ` Andrew Morton
2014-04-30 21:00                       ` Andrew Morton
2014-04-30 21:21                       ` Rik van Riel
2014-04-30 21:21                         ` Rik van Riel
2014-04-30 21:32                     ` Andrew Morton
2014-04-30 21:32                       ` Andrew Morton
2014-05-02  9:16                     ` Michal Hocko
2014-05-02  9:16                       ` Michal Hocko
2014-05-08 10:17                     ` Masayoshi Mizuma
2014-05-08 10:17                       ` Masayoshi Mizuma

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.