diff options
author | Davidlohr Bueso <dave@gnu.org> | 2012-10-04 17:13:18 -0700 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-10-13 05:28:03 +0900 |
commit | 7151b69f69f84e66c550b3033f4e2cc301b66f86 (patch) | |
tree | 65e9bebdbbf1df1941ce42220c867ddee1bbf7e8 | |
parent | 073c05b26374bcd3a7b033fa88087d721b080a75 (diff) | |
download | lwn-7151b69f69f84e66c550b3033f4e2cc301b66f86.tar.gz lwn-7151b69f69f84e66c550b3033f4e2cc301b66f86.zip |
lib/gcd.c: prevent possible div by 0
commit e96875677fb2b7cb739c5d7769824dff7260d31d upstream.
Account for all properties when a and/or b are 0:
gcd(0, 0) = 0
gcd(a, 0) = a
gcd(0, b) = b
Fixes no known problems in current kernels.
Signed-off-by: Davidlohr Bueso <dave@gnu.org>
Cc: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | lib/gcd.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/lib/gcd.c b/lib/gcd.c index f879033d9822..433d89bd9d89 100644 --- a/lib/gcd.c +++ b/lib/gcd.c @@ -9,6 +9,9 @@ unsigned long gcd(unsigned long a, unsigned long b) if (a < b) swap(a, b); + + if (!b) + return a; while ((r = a % b) != 0) { a = b; b = r; |